Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1032525pxj; Fri, 4 Jun 2021 04:34:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy0lIkfZ4uisS1S1d4u1Um6CqdEWNdRNJkj/dy0ieO8fupetZjGQ8uVBXlm4aquE/lqmTLa X-Received: by 2002:a17:906:1e15:: with SMTP id g21mr3657209ejj.241.1622806450676; Fri, 04 Jun 2021 04:34:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622806450; cv=none; d=google.com; s=arc-20160816; b=iQNw1589aRBNodUAKnV26WVjbLUriY6cFMRSaN6vuvpAfBbzl3Z7KyTqc2S3j29xOB hc7aISWQTBPfkSdV0Pts6fgyHP6KIAcGBnVyRfTsw8bswpTzCK3CaqzQOTkWQODoA2am zkfSpZr67k5gYlNfk0hspL5dCGPxzUPXsHNQUlZ7yudF03CW8TGbN04tVsDZG4lcS6qw 6iAUpMkvsIW8cvYwj77lkuPXCkuEBcRjrrL/HiyhFIlE5CfVWxGqpVADVrLSaSqRsWvs sGPlOlnz9HNHcBS0BhL5m1W4xqeYKITNSbwmFTzx4Sd4aMw3tacQ+NyZOGqsFPEqXLX0 dd2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=//SlqZlJ9HmWvQ3HyBAiVHOZk7eNjzotv6lZKQljsK0=; b=fIQsrOxDyM18/WXChW04MgwBeT6azHUs3fS8uEYsgcp2l82TEus8e68oX3g7dDh1Ko wv9Qzvsn4Joo4wa+HgVVJAgD+NAlGykD3vg8RaoJfSTh8jdw+WOZ5AzWVJZ3yf4HqmlE 60HYvgh66Kh6FyatCmem62A1G19Azs6F4nKOqVEmi0uGpwecsPNwxS18kdHy5p+lQa5M MfBIQ9kuqNI237YQ/CFYI7NtY0BFCP3OgmuCR1+U56lGPBd2p2lXYiqIlUQETknrqFoY jyyGpO9Wc1hBHqZsLII7on8WM4F/AKZU+3oJtn7w/3SqUX9pxGSb2w5MyCEKuI7b9FdY NxaA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=OvhflCfg; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c11si5188143edy.550.2021.06.04.04.33.47; Fri, 04 Jun 2021 04:34:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=OvhflCfg; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230188AbhFDLd4 (ORCPT + 99 others); Fri, 4 Jun 2021 07:33:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:34398 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230150AbhFDLd4 (ORCPT ); Fri, 4 Jun 2021 07:33:56 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 0177261414; Fri, 4 Jun 2021 11:32:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1622806330; bh=KlLBEMEdqi0epe6fPxGlME4m214IZeWzy7tdD9dk7R4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=OvhflCfgsRWz1vXdD0HuXT2NCiquWBUX85eW4PwMCkFoTpV/jajgNBQqNA/CfYRm4 b+672Gqsc+Dg6AUGN77DvzdyY6Qn7B90mW1x+smeCslZe3/9Ut4pNqgkZcgWxgLry1 MaRVOEWaa8d7Q+jfYqAmy4ZFr7Y0RVHwu7opzheG2l5IDUdDAE7mvyxDah48VHo9Ew MYiacGbpeBaInVbloJar55XA0Pxn0AtwpQ0MdYGZUC9wc38NKNmLB6ah5V0RqyORYU H9GRkkI0WJBpQ6RqtUcOZ4oT04eDXIAH6q4EszW1WZ20T4Zc2Q+qNQsYIh+rLkMfqK Nf/J/BePb9rYw== From: Frederic Weisbecker To: Thomas Gleixner Cc: LKML , Frederic Weisbecker , Peter Zijlstra , "Eric W . Biederman" , Oleg Nesterov , Ingo Molnar Subject: [PATCH 3/6] posix-cpu-timers: Force next_expiration recalc after timer deletion Date: Fri, 4 Jun 2021 13:31:56 +0200 Message-Id: <20210604113159.26177-4-frederic@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210604113159.26177-1-frederic@kernel.org> References: <20210604113159.26177-1-frederic@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org A timer deletion only dequeues the timer but it doesn't shutdown the related costly process wide cputimer counter and the tick dependency. The following code snippet keeps this overhead around for one week after the timer deletion: void trigger_process_counter(void) { timer_t id; struct itimerspec val = { }; val.it_value.tv_sec = 604800; timer_create(CLOCK_PROCESS_CPUTIME_ID, NULL, &id); timer_settime(id, 0, &val, NULL); timer_delete(id); } Make sure the next target's tick recalculates the nearest expiration and clears the process wide counter and tick dependency if necessary. Signed-off-by: Frederic Weisbecker Cc: Oleg Nesterov Cc: Thomas Gleixner Cc: Peter Zijlstra (Intel) Cc: Ingo Molnar Cc: Eric W. Biederman --- include/linux/posix-timers.h | 4 +++- kernel/time/posix-cpu-timers.c | 29 ++++++++++++++++++++++++++++- 2 files changed, 31 insertions(+), 2 deletions(-) diff --git a/include/linux/posix-timers.h b/include/linux/posix-timers.h index 896c16d2c5fb..4cf1fbe8d1bc 100644 --- a/include/linux/posix-timers.h +++ b/include/linux/posix-timers.h @@ -82,12 +82,14 @@ static inline bool cpu_timer_enqueue(struct timerqueue_head *head, return timerqueue_add(head, &ctmr->node); } -static inline void cpu_timer_dequeue(struct cpu_timer *ctmr) +static inline bool cpu_timer_dequeue(struct cpu_timer *ctmr) { if (ctmr->head) { timerqueue_del(ctmr->head, &ctmr->node); ctmr->head = NULL; + return true; } + return false; } static inline u64 cpu_timer_getexpires(struct cpu_timer *ctmr) diff --git a/kernel/time/posix-cpu-timers.c b/kernel/time/posix-cpu-timers.c index 132fd56fb1cd..bb1f862c785e 100644 --- a/kernel/time/posix-cpu-timers.c +++ b/kernel/time/posix-cpu-timers.c @@ -405,6 +405,33 @@ static int posix_cpu_timer_create(struct k_itimer *new_timer) return 0; } +/* + * Dequeue the timer and reset the base if it was its earliest expiration. + * It makes sure the next tick recalculates the base next expiration so we + * don't keep the costly process wide cputime counter around for a random + * amount of time, along with the tick dependency. + */ +static void disarm_timer(struct k_itimer *timer, struct task_struct *p) +{ + struct cpu_timer *ctmr = &timer->it.cpu; + struct posix_cputimer_base *base; + int clkidx; + + if (!cpu_timer_dequeue(ctmr)) + return; + + clkidx = CPUCLOCK_WHICH(timer->it_clock); + + if (CPUCLOCK_PERTHREAD(timer->it_clock)) + base = p->posix_cputimers.bases + clkidx; + else + base = p->signal->posix_cputimers.bases + clkidx; + + if (cpu_timer_getexpires(ctmr) == base->nextevt) + base->nextevt = 0; +} + + /* * Clean up a CPU-clock timer that is about to be destroyed. * This is called from timer deletion with the timer already locked. @@ -439,7 +466,7 @@ static int posix_cpu_timer_del(struct k_itimer *timer) if (timer->it.cpu.firing) ret = TIMER_RETRY; else - cpu_timer_dequeue(ctmr); + disarm_timer(timer, p); unlock_task_sighand(p, &flags); } -- 2.25.1