Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

tracing,x86: Add a TSC trace_clock

In order to promote interoperability between userspace tracers and ftrace,
add a trace_clock that reports raw TSC values which will then be recorded
in the ring buffer. Userspace tracers that also record TSCs are then on
exactly the same time base as the kernel and events can be unambiguously
interlaced.

Tested: Enabled a tracepoint and the "tsc" trace_clock and saw very large
timestamp values.

v2:
Move arch-specific bits out of generic code.
v3:
Rename "x86-tsc", cleanups
v7:
Generic arch bits in Kbuild.

Google-Bug-Id: 6980623
Link: http://lkml.kernel.org/r/1352837903-32191-1-git-send-email-dhsharp@google.com

Acked-by: Ingo Molnar <mingo@kernel.org>
Cc: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: "H. Peter Anvin" <hpa@linux.intel.com>
Signed-off-by: David Sharp <dhsharp@google.com>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>

authored by

David Sharp and committed by
Steven Rostedt
8cbd9cc6 7bcfaf54

+88
+1
arch/alpha/include/asm/Kbuild
··· 11 11 header-y += regdef.h 12 12 header-y += sysinfo.h 13 13 generic-y += exec.h 14 + generic-y += trace_clock.h
+1
arch/arm/include/asm/Kbuild
··· 31 31 generic-y += termbits.h 32 32 generic-y += termios.h 33 33 generic-y += timex.h 34 + generic-y += trace_clock.h 34 35 generic-y += types.h 35 36 generic-y += unaligned.h
+1
arch/arm64/include/asm/Kbuild
··· 43 43 generic-y += termbits.h 44 44 generic-y += termios.h 45 45 generic-y += topology.h 46 + generic-y += trace_clock.h 46 47 generic-y += types.h 47 48 generic-y += unaligned.h 48 49 generic-y += user.h
+1
arch/avr32/include/asm/Kbuild
··· 1 1 2 2 generic-y += clkdev.h 3 3 generic-y += exec.h 4 + generic-y += trace_clock.h
+1
arch/blackfin/include/asm/Kbuild
··· 38 38 generic-y += termbits.h 39 39 generic-y += termios.h 40 40 generic-y += topology.h 41 + generic-y += trace_clock.h 41 42 generic-y += types.h 42 43 generic-y += ucontext.h 43 44 generic-y += unaligned.h
+1
arch/c6x/include/asm/Kbuild
··· 49 49 generic-y += termios.h 50 50 generic-y += tlbflush.h 51 51 generic-y += topology.h 52 + generic-y += trace_clock.h 52 53 generic-y += types.h 53 54 generic-y += ucontext.h 54 55 generic-y += user.h
+1
arch/cris/include/asm/Kbuild
··· 11 11 generic-y += clkdev.h 12 12 generic-y += exec.h 13 13 generic-y += module.h 14 + generic-y += trace_clock.h
+1
arch/frv/include/asm/Kbuild
··· 1 1 2 2 generic-y += clkdev.h 3 3 generic-y += exec.h 4 + generic-y += trace_clock.h
+1
arch/h8300/include/asm/Kbuild
··· 3 3 generic-y += clkdev.h 4 4 generic-y += exec.h 5 5 generic-y += module.h 6 + generic-y += trace_clock.h
+1
arch/hexagon/include/asm/Kbuild
··· 48 48 generic-y += termbits.h 49 49 generic-y += termios.h 50 50 generic-y += topology.h 51 + generic-y += trace_clock.h 51 52 generic-y += types.h 52 53 generic-y += ucontext.h 53 54 generic-y += unaligned.h
+1
arch/ia64/include/asm/Kbuild
··· 2 2 generic-y += clkdev.h 3 3 generic-y += exec.h 4 4 generic-y += kvm_para.h 5 + generic-y += trace_clock.h
+1
arch/m32r/include/asm/Kbuild
··· 3 3 generic-y += clkdev.h 4 4 generic-y += exec.h 5 5 generic-y += module.h 6 + generic-y += trace_clock.h
+1
arch/m68k/include/asm/Kbuild
··· 24 24 generic-y += siginfo.h 25 25 generic-y += statfs.h 26 26 generic-y += topology.h 27 + generic-y += trace_clock.h 27 28 generic-y += types.h 28 29 generic-y += word-at-a-time.h 29 30 generic-y += xor.h
+1
arch/microblaze/include/asm/Kbuild
··· 3 3 header-y += elf.h 4 4 generic-y += clkdev.h 5 5 generic-y += exec.h 6 + generic-y += trace_clock.h
+1
arch/mips/include/asm/Kbuild
··· 1 1 # MIPS headers 2 + generic-y += trace_clock.h
+1
arch/mn10300/include/asm/Kbuild
··· 1 1 2 2 generic-y += clkdev.h 3 3 generic-y += exec.h 4 + generic-y += trace_clock.h
+1
arch/openrisc/include/asm/Kbuild
··· 60 60 generic-y += termbits.h 61 61 generic-y += termios.h 62 62 generic-y += topology.h 63 + generic-y += trace_clock.h 63 64 generic-y += types.h 64 65 generic-y += ucontext.h 65 66 generic-y += user.h
+1
arch/parisc/include/asm/Kbuild
··· 3 3 segment.h topology.h vga.h device.h percpu.h hw_irq.h mutex.h \ 4 4 div64.h irq_regs.h kdebug.h kvm_para.h local64.h local.h param.h \ 5 5 poll.h xor.h clkdev.h exec.h 6 + generic-y += trace_clock.h
+1
arch/powerpc/include/asm/Kbuild
··· 2 2 3 3 generic-y += clkdev.h 4 4 generic-y += rwsem.h 5 + generic-y += trace_clock.h
+1
arch/s390/include/asm/Kbuild
··· 1 1 2 2 3 3 generic-y += clkdev.h 4 + generic-y += trace_clock.h
+1
arch/score/include/asm/Kbuild
··· 3 3 header-y += 4 4 5 5 generic-y += clkdev.h 6 + generic-y += trace_clock.h
+1
arch/sh/include/asm/Kbuild
··· 31 31 generic-y += statfs.h 32 32 generic-y += termbits.h 33 33 generic-y += termios.h 34 + generic-y += trace_clock.h 34 35 generic-y += ucontext.h 35 36 generic-y += xor.h
+1
arch/sparc/include/asm/Kbuild
··· 8 8 generic-y += irq_regs.h 9 9 generic-y += local.h 10 10 generic-y += module.h 11 + generic-y += trace_clock.h 11 12 generic-y += word-at-a-time.h
+1
arch/tile/include/asm/Kbuild
··· 34 34 generic-y += statfs.h 35 35 generic-y += termbits.h 36 36 generic-y += termios.h 37 + generic-y += trace_clock.h 37 38 generic-y += types.h 38 39 generic-y += xor.h
+1
arch/um/include/asm/Kbuild
··· 2 2 generic-y += hw_irq.h irq_regs.h kdebug.h percpu.h sections.h topology.h xor.h 3 3 generic-y += ftrace.h pci.h io.h param.h delay.h mutex.h current.h exec.h 4 4 generic-y += switch_to.h clkdev.h 5 + generic-y += trace_clock.h
+1
arch/unicore32/include/asm/Kbuild
··· 54 54 generic-y += termbits.h 55 55 generic-y += termios.h 56 56 generic-y += topology.h 57 + generic-y += trace_clock.h 57 58 generic-y += types.h 58 59 generic-y += ucontext.h 59 60 generic-y += unaligned.h
+20
arch/x86/include/asm/trace_clock.h
··· 1 + #ifndef _ASM_X86_TRACE_CLOCK_H 2 + #define _ASM_X86_TRACE_CLOCK_H 3 + 4 + #include <linux/compiler.h> 5 + #include <linux/types.h> 6 + 7 + #ifdef CONFIG_X86_TSC 8 + 9 + extern u64 notrace trace_clock_x86_tsc(void); 10 + 11 + # define ARCH_TRACE_CLOCKS \ 12 + { trace_clock_x86_tsc, "x86-tsc" }, 13 + 14 + #else /* !CONFIG_X86_TSC */ 15 + 16 + #define ARCH_TRACE_CLOCKS 17 + 18 + #endif 19 + 20 + #endif /* _ASM_X86_TRACE_CLOCK_H */
+1
arch/x86/kernel/Makefile
··· 61 61 obj-$(CONFIG_DYNAMIC_FTRACE) += ftrace.o 62 62 obj-$(CONFIG_FUNCTION_GRAPH_TRACER) += ftrace.o 63 63 obj-$(CONFIG_FTRACE_SYSCALLS) += ftrace.o 64 + obj-$(CONFIG_X86_TSC) += trace_clock.o 64 65 obj-$(CONFIG_KEXEC) += machine_kexec_$(BITS).o 65 66 obj-$(CONFIG_KEXEC) += relocate_kernel_$(BITS).o crash.o 66 67 obj-$(CONFIG_CRASH_DUMP) += crash_dump_$(BITS).o
+21
arch/x86/kernel/trace_clock.c
··· 1 + /* 2 + * X86 trace clocks 3 + */ 4 + #include <asm/trace_clock.h> 5 + #include <asm/barrier.h> 6 + #include <asm/msr.h> 7 + 8 + /* 9 + * trace_clock_x86_tsc(): A clock that is just the cycle counter. 10 + * 11 + * Unlike the other clocks, this is not in nanoseconds. 12 + */ 13 + u64 notrace trace_clock_x86_tsc(void) 14 + { 15 + u64 ret; 16 + 17 + rdtsc_barrier(); 18 + rdtscll(ret); 19 + 20 + return ret; 21 + }
+1
arch/xtensa/include/asm/Kbuild
··· 25 25 generic-y += statfs.h 26 26 generic-y += termios.h 27 27 generic-y += topology.h 28 + generic-y += trace_clock.h 28 29 generic-y += xor.h
+16
include/asm-generic/trace_clock.h
··· 1 + #ifndef _ASM_GENERIC_TRACE_CLOCK_H 2 + #define _ASM_GENERIC_TRACE_CLOCK_H 3 + /* 4 + * Arch-specific trace clocks. 5 + */ 6 + 7 + /* 8 + * Additional trace clocks added to the trace_clocks 9 + * array in kernel/trace/trace.c 10 + * None if the architecture has not defined it. 11 + */ 12 + #ifndef ARCH_TRACE_CLOCKS 13 + # define ARCH_TRACE_CLOCKS 14 + #endif 15 + 16 + #endif /* _ASM_GENERIC_TRACE_CLOCK_H */
+2
include/linux/trace_clock.h
··· 12 12 #include <linux/compiler.h> 13 13 #include <linux/types.h> 14 14 15 + #include <asm/trace_clock.h> 16 + 15 17 extern u64 notrace trace_clock_local(void); 16 18 extern u64 notrace trace_clock(void); 17 19 extern u64 notrace trace_clock_global(void);
+1
kernel/trace/trace.c
··· 488 488 { trace_clock_local, "local" }, 489 489 { trace_clock_global, "global" }, 490 490 { trace_clock_counter, "counter" }, 491 + ARCH_TRACE_CLOCKS 491 492 }; 492 493 493 494 int trace_clock_id;