[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1357742770-15028-1-git-send-email-mark.rutland@arm.com>
Date: Wed, 9 Jan 2013 14:46:06 +0000
From: Mark Rutland <mark.rutland@....com>
To: linux-kernel@...r.kernel.org
Cc: linux-arm-kernel@...ts.infradead.org, tglx@...utronix.de,
nico@...aro.org, will.deacon@....com, marc.zyngier@....com,
john.stultz@...aro.org, mark.rutland@....com
Subject: [PATCHv2 0/4] clockevents: decouple broadcast mechanism from drivers
This is an updated version of the series I posted back in December:
http://lists.infradead.org/pipermail/linux-arm-kernel/2012-December/137929.html
Changes since v1:
* Drop removal of guards in smp.c
* Removed useless evt->evt_handler check in tick_receive_broadcast
* Fix up tick_receive_broadcast when !GENERIC_CLOCKEVENTS_BROADCAST
* Fix checkpatch issues (multi-line strings)
Thanks go to Stephen Boyd and Santosh Shilimkar for their commments.
In some SMP systems, cpu-local timers may stop delivering interrupts
when in low power states, or not all CPUs may have local timers. To
support these systems we have a mechanism for broadcasting timer ticks
to other CPUs. This mechanism relies on the struct
clock_event_device::broadcast function pointer, which is a
driver-specific mechanism for broadcasting ticks to other CPUs.
As the broadcast mechanism is architecture-specific, placing the
broadcast function on struct clock_event_device ties each driver to a
single architecture. Additionally the driver or architecture backend
must handle the routing of broadcast ticks to the correct
clock_event_device, leading to duplication of the list of active
clock_event_devices.
These patches introduce a generic mechanism for handling the receipt of
timer broadcasts, and an optional architecture-specific broadcast
function which allows drivers to be decoupled from a particular
architecture will retaining support for timer tick broadcasts. These
mechanisms are wired up for the arm port, and have been boot-tested on a
pandaboard.
Thanks,
Mark.
Mark Rutland (4):
clockevents: Add generic timer broadcast receiver
arm: Use generic timer broadcast receiver
clockevents: Add generic timer broadcast function
arm: Add generic timer broadcast support
arch/arm/Kconfig | 1 +
arch/arm/kernel/smp.c | 11 ++---------
include/linux/clockchips.h | 14 ++++++++++++++
kernel/time/Kconfig | 4 ++++
kernel/time/tick-broadcast.c | 25 +++++++++++++++++++++++++
5 files changed, 46 insertions(+), 9 deletions(-)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists