linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v4 0/3] x86/delay: Introduce TPAUSE instruction
@ 2020-04-24 19:37 Kyung Min Park
  2020-04-24 19:37 ` [PATCH v4 1/3] x86/delay: Preparatory code cleanup Kyung Min Park
                   ` (2 more replies)
  0 siblings, 3 replies; 7+ messages in thread
From: Kyung Min Park @ 2020-04-24 19:37 UTC (permalink / raw)
  To: x86, linux-kernel
  Cc: tglx, mingo, hpa, gregkh, ak, tony.luck, ashok.raj,
	ravi.v.shankar, fenghua.yu, kyung.min.park

Intel processors that support the WAITPKG feature implement
the TPAUSE instruction that suspends execution in a lower power
state until the TSC (Time Stamp Counter) exceeds a certain value.

Update the udelay() function to use TPAUSE on systems where it
is available. Note that we hard code the deeper (C0.2) sleep
state because exit latency is small compared to the "microseconds"
that usleep() will delay.

ChangeLog:
- Change from v3 to v4:
  1. Add binutils version to support tpause as suggested by Peter Zijlstra.
  2. Use arch/x86/Kconfig.assembler to set up a CONFIG_AS_TPAUSE
     suggested by Tony Luck.
  3. Fix build issue for make ARCH=i386.

- Change from v2 to v3:
  1. Add Thomas' cleanup patch to this patchset.
  2. Implement use_tpause_delay() to use TPAUSE.
  3. Call use_tpause_delay() during x86_late_time_init().
  4. Use APIs lower_32_bits(), upper_32_bits() as suggested by Joe Perch.
  5. Change __tpause() argument integer type from unsigned int to u32.

- Change from v1 to v2:
  1. Change function/variable names as suggested by Thomas Gleixner i.e.
     a. Change to delay_halt_fn/delay_halt_mwaitx/delay_halt_tpause from
        wait_func/mwaitx/tpause.
     b. Change variable name loops to cycles.
     c. Change back to the original name delay_fn from delay_platform.
  2. Organize comments to use full width.
  3. Add __ro_after_init for the function pointer delay_halt_fn.
  4. Change patch titles as suggested by Thomas Gleixner.

Kyung Min Park (2):
  x86/delay: Refactor delay_mwaitx() for TPAUSE support
  x86/delay: Introduce TPAUSE delay

Thomas Gleixner (1):
  x86/delay: Preparatory code cleanup

 arch/x86/Kconfig.assembler   |   4 ++
 arch/x86/include/asm/delay.h |   4 +-
 arch/x86/include/asm/mwait.h |  24 ++++++++-
 arch/x86/kernel/time.c       |   3 ++
 arch/x86/lib/delay.c         | 114 +++++++++++++++++++++++++++++--------------
 5 files changed, 111 insertions(+), 38 deletions(-)

-- 
2.7.4


^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2020-05-07 14:13 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-04-24 19:37 [PATCH v4 0/3] x86/delay: Introduce TPAUSE instruction Kyung Min Park
2020-04-24 19:37 ` [PATCH v4 1/3] x86/delay: Preparatory code cleanup Kyung Min Park
2020-05-07 14:13   ` [tip: x86/timers] " tip-bot2 for Thomas Gleixner
2020-04-24 19:37 ` [PATCH v4 2/3] x86/delay: Refactor delay_mwaitx() for TPAUSE support Kyung Min Park
2020-05-07 14:13   ` [tip: x86/timers] " tip-bot2 for Kyung Min Park
2020-04-24 19:37 ` [PATCH v4 3/3] x86/delay: Introduce TPAUSE delay Kyung Min Park
2020-05-07 14:13   ` [tip: x86/timers] " tip-bot2 for Kyung Min Park

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).