From patchwork Tue Jun 6 14:37:45 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Thomas Gleixner X-Patchwork-Id: 103918 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:994d:0:b0:3d9:f83d:47d9 with SMTP id k13csp3468293vqr; Tue, 6 Jun 2023 08:13:30 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ72vS/Sl0aXH2zs4mnNa17vfFjWFnY2Fd3qx6XCctN5/ADVmC6OKMaPP3OJIaw86Uvk4bQB X-Received: by 2002:a17:90a:fa3:b0:258:fe26:9721 with SMTP id 32-20020a17090a0fa300b00258fe269721mr1170105pjz.17.1686064410036; Tue, 06 Jun 2023 08:13:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686064410; cv=none; d=google.com; s=arc-20160816; b=XHvKcVVi2lzMhbwVjg3EdWAvg/GdOObO3aYj/KztIVVG7aYWeFpMB/Jm+ieyobxvw4 DfZGEnhPa5b2+5lNy0nUcw3DuNww5D8yQXEzDfi5QgDI6KPtKhBR4P2aBDP9dGN7nqaH cbpxvrpMgI6IZ0F+a74AhEUp977B+IL+z3QkiN01SwrzyjmCTnv7HRVmESSRCi4e81V/ 5hfh8IqTG11+XI5p01CCm8tECCpw4kibgQk/NH52uvwTNNoMU+rVtG7lyzwzDamLfL+5 pEL0N8sCmKMxvNDY/BS4rulDSLMTURgN0VWvoMJ9QX7T624jeDELX7D0GWb9cjPaosu/ lDXw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:date:mime-version:references:subject:cc:to:from :dkim-signature:dkim-signature:message-id; bh=lbMmZ14JuZ/krQR6RrGQ1HvOBRw0gNG6TW4Rb4ueY4Q=; b=Wod9JDY6Fu6m1aNtmkVyyWbsKuXN0mUpR19Z1x7wuCR8ElCNWqE12rWxEumb3M0/M+ CNPIblYybv9Q530u2m0RtkRSWgrluefJ9VoXFvAmXB5233owoFWQtk4KvUuO/t2NUY4T 1BpYGOIuZuxRoQAMbB4WM+cjIcLcXCfSMI0D8FZdnx6fW+YpUDXarW5KW30LTApLzKw6 Y8hAQWu0ezOzNEH7l6yqmim4+j2AP/ipD3oI9qu7pCw6Q9plwHu2WYUPvU2tGiLU/VhE bkeyMNtpOnQNc1mwO7EylzhDawDHWhi8M3kyED2H3++EiN2v6ksVE79WaBpZhE0DYDwQ H/2w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=fr07iI8e; dkim=neutral (no key) header.i=@linutronix.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id np6-20020a17090b4c4600b00256cf521fd0si5462824pjb.147.2023.06.06.08.13.17; Tue, 06 Jun 2023 08:13:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=fr07iI8e; dkim=neutral (no key) header.i=@linutronix.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238176AbjFFOig (ORCPT + 99 others); Tue, 6 Jun 2023 10:38:36 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41964 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238164AbjFFOiM (ORCPT ); Tue, 6 Jun 2023 10:38:12 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CC9421993 for ; Tue, 6 Jun 2023 07:37:47 -0700 (PDT) Message-ID: <20230606142031.983662966@linutronix.de> DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1686062266; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: references:references; bh=lbMmZ14JuZ/krQR6RrGQ1HvOBRw0gNG6TW4Rb4ueY4Q=; b=fr07iI8eiGqzm9c4spmDHsJoDzM4I3AshKTKn0B4qfJFd1pupaIcWrQv+EkERqd+s1WZXs wiyFUStOfDusf4fsevgOi6yqYiPcD5rIPfMqwufQ+O7nln7PpgKlnpIsyYAcPND2lKlfxA nqTeBws/rzNYwbtQMmrjRpBIwSy9mfkZP3jls4azpkFz+v692Oj9/0ucQAW5A1hsEuN5EF 77uSwrbqgHYNvjBVYwOLZiuiSyeD2bDxvYe2gtARLMvpw5pOtrBLYk66YAeNkHilPxXN4m wMa16b0ivC9t/ywD/tYI0O1OYDxFMyZvUBXy4WPxPwgFAiCo2OzMTsscmUMgsg== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1686062266; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: references:references; bh=lbMmZ14JuZ/krQR6RrGQ1HvOBRw0gNG6TW4Rb4ueY4Q=; b=C/BEPwo7ibfW/Qaq98/UdgpbTp1XbZou+bEA3mK0iDko1X3WaoZgGPVPm/FyOape4HgzCU wfAtQ770fIo9KsDg== From: Thomas Gleixner To: LKML Cc: Frederic Weisbecker , Anna-Maria Behnsen , John Stultz , Peter Zijlstra , Ingo Molnar , Stephen Boyd , Eric Biederman , Oleg Nesterov Subject: [patch 17/45] posix-cpu-timers: Make k_itimer::it_active consistent References: <20230606132949.068951363@linutronix.de> MIME-Version: 1.0 Date: Tue, 6 Jun 2023 16:37:45 +0200 (CEST) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1767966674565048655?= X-GMAIL-MSGID: =?utf-8?q?1767966674565048655?= Posix CPU timers are not updating k_itimer::it_active which makes it impossible to base decisions in the common posix timer code on it. Update it when queueing or dequeueing posix CPU timers. Signed-off-by: Thomas Gleixner --- kernel/time/posix-cpu-timers.c | 6 ++++++ 1 file changed, 6 insertions(+) --- a/kernel/time/posix-cpu-timers.c +++ b/kernel/time/posix-cpu-timers.c @@ -453,6 +453,7 @@ static void disarm_timer(struct k_itimer struct cpu_timer *ctmr = &timer->it.cpu; struct posix_cputimer_base *base; + timer->it_active = 0; if (!cpu_timer_dequeue(ctmr)) return; @@ -559,6 +560,7 @@ static void arm_timer(struct k_itimer *t struct cpu_timer *ctmr = &timer->it.cpu; u64 newexp = cpu_timer_getexpires(ctmr); + timer->it_active = 1; if (!cpu_timer_enqueue(&base->tqhead, ctmr)) return; @@ -668,6 +670,7 @@ static int posix_cpu_timer_set(struct k_ ret = TIMER_RETRY; } else { cpu_timer_dequeue(ctmr); + timer->it_active = 0; } /* @@ -787,6 +790,7 @@ static u64 collect_timerqueue(struct tim while ((next = timerqueue_getnext(head))) { struct cpu_timer *ctmr; + struct k_itimer *ktmr; u64 expires; ctmr = container_of(next, struct cpu_timer, node); @@ -799,6 +803,8 @@ static u64 collect_timerqueue(struct tim /* See posix_cpu_timer_wait_running() */ rcu_assign_pointer(ctmr->handling, current); cpu_timer_dequeue(ctmr); + ktmr = container_of(ctmr, struct k_itimer, it.cpu); + ktmr->it_active = 0; list_add_tail(&ctmr->elist, firing); }