Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp841290pxj; Thu, 20 May 2021 23:51:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy4alAYx0wAvOrMkEijeJDBOEjBRrLg8+vpECXcHCQuVLEyZYEUmtzsbgEIlcEBSCnhL2ZE X-Received: by 2002:a17:906:d285:: with SMTP id ay5mr8715157ejb.418.1621579889248; Thu, 20 May 2021 23:51:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621579889; cv=none; d=google.com; s=arc-20160816; b=TdjcoX494rmDhDfAPYBCAVDiz/fOTqH2J84jI3vC/I20MA7KHzStIR4MpjR1AZb8Ht HOIi4fNZiXTzyF69O3jVZNc3OIsQrX/F3uairvoGPoiagMWwVM6UNaU9gExHYcO/SUi/ i6AMUzopYRaIp67gFHybTu6Rjf9gDiTxbU5xzA3ZJNhtUEVnXWVy5Y/bL5Q2zBrIrVmU NZHYH/4vj1tZK9+3LyXwBlT72CzUiZsr6Ko5LYHhVwJQl8ECuA068jxTU6bqxi8z1IXN XqwSPtNEp7oW4Ng6WHUffF5ZMmwB8angRFq7IDNpN8RS9Kpvn5vvmlvhKFXcIG6M8EXS +xWg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=4IeqRze6LqoFntvBJQwYFAUxsGaW8tPS/g5/AWJMqAY=; b=QIZcT8EQUkNKfx39zc2me07cLf5XOuCYZf8MYw1H++FCDojij9bG+0yvbsIKTrby9n Q/9nka35D9GdRHeMAcXtanAPsAY/pZx7OD9ncWtpyVzk50yo2s7AqEQbeWCxXvr3byHP bbKeIkbnuwAKYkXbu1782QBSZYISjp2QlFu3PH2Vl9kBt3UVZQI/45EXcTYEDfQm1MKr LulEtaYLfZ1ynvY9l8kMmBJV9VYmE5FvqKcfE25kqBCbBELCOQlcXiB1ingXUBL/do/Y SuMZOnVgG3lMOfInqONJNPx2YOrwdpn1Yabds/FSmkV/aPiVu2PNlZWaOWTGjjISf74s Wj2w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=mnjyjb+x; 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 f18si4697088ejx.483.2021.05.20.23.51.06; Thu, 20 May 2021 23:51:29 -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=mnjyjb+x; 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 S235839AbhETSsr (ORCPT + 99 others); Thu, 20 May 2021 14:48:47 -0400 Received: from mail.kernel.org ([198.145.29.99]:39352 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235810AbhETSsp (ORCPT ); Thu, 20 May 2021 14:48:45 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id E640E606A5; Thu, 20 May 2021 18:47:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1621536442; bh=Ty9aIb6o8gMXPzSHHmrqzigJgT7fYJt18EsmQyx3I/E=; h=From:To:Cc:Subject:Date:From; b=mnjyjb+xJtr4Y5Cw27i7TaA0OR+QqHDEcNQFd+NiV0PTYkXSwj/zDu7+goGcqpvRR LTfJL9AvGUYVd50dkbRkqeTLWtzadPYumAErEqxzDYad+Asa7/LihhvSdqPz7+MRpB TozXQbKF1XxQFx1o8NQSUQH3yohNut70zZhi+SQ+J0ikG3S3h2Q88LSWStlsfDNAAy Asfo4SvRdcHcg+HZqlSJ5EjQ+JdoDxUMvoYBZeqWeGvkFPXjVRbbFTPCSZkMeOYIDd OPpei2nCIIQjXwXHgNyWdnAZWdGa7qz4+FwoSw6zzEvzmS/mEIL9/ihuzwXcgGuCYa g9Ly+kytmXWtg== From: Will Deacon To: linux-arm-kernel@lists.infradead.org Cc: linux-kernel@vger.kernel.org, Will Deacon , Frederic Weisbecker , Thomas Gleixner , Marc Zyngier , Lorenzo Colitti , John Stultz , Stephen Boyd , kernel-team@android.com Subject: [PATCH 0/5] tick/broadcast: Allow per-cpu timers to be used instead of broadcast Date: Thu, 20 May 2021 19:47:00 +0100 Message-Id: <20210520184705.10845-1-will@kernel.org> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi all, This patch series adds support for hardware where the per-cpu tick timer cannot wake up from deep idle states (i.e. CLOCK_EVT_FEAT_C3STOP is set) yet there is a secondary per-cpu timer which is generally less preferable (i.e. slow to access) yet capable of delivering the wakeup. The meat and potatoes are in patches 3 and 4, but since I've not hacked on this part of the kernel before I would appreciate feedback on any of the changes I'm proposing. Cheers, Will Cc: Frederic Weisbecker Cc: Thomas Gleixner Cc: Marc Zyngier Cc: Lorenzo Colitti Cc: John Stultz Cc: Stephen Boyd Cc: kernel-team@android.com --->8 Will Deacon (5): tick/broadcast: Drop unneeded CONFIG_GENERIC_CLOCKEVENTS_BROADCAST guard tick/broadcast: Split __tick_broadcast_oneshot_control() into a helper tick/broadcast: Prefer per-cpu oneshot wakeup timers to broadcast tick/broadcast: Program wakeup timer when entering idle if required timer_list: Print name of per-cpu wakeup device kernel/time/tick-broadcast.c | 135 ++++++++++++++++++++++++++++++----- kernel/time/tick-common.c | 2 +- kernel/time/tick-internal.h | 5 +- kernel/time/timer_list.c | 11 ++- 4 files changed, 133 insertions(+), 20 deletions(-) -- 2.31.1.818.g46aad6cb9e-goog