This patch adds the timestamping mechanism in the ltt.h arch header file. The new timestamp functions use the TMU channel 1. This code only works if the TMU channel 1 is initialized during the kernel boot Note from Mathieu : This patch seems to assume TMU channel 1 is setup at boot. Is it always true on all SuperH boards ? Is there some Kconfig selection that should be done here ? We could probably extract part of this patch into get_cycles() and remove CONFIG_LTT dependency. From: Giuseppe Cavallaro <peppe.cavallaro@xxxxxx> Signed-off-by: Giuseppe Cavallaro <peppe.cavallaro@xxxxxx> Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@xxxxxxxxxx> CC: Paul Mundt <lethal@xxxxxxxxxxxx> CC: linux-sh@xxxxxxxxxxxxxxx --- arch/sh/Kconfig | 2 + arch/sh/include/asm/ltt.h | 45 ++++++++++++++++++++++++++++++++++++++++++++ arch/sh/include/asm/timex.h | 8 ++++++- 3 files changed, 54 insertions(+), 1 deletion(-) Index: linux-2.6-lttng/arch/sh/include/asm/ltt.h =================================================================== --- /dev/null 1970-01-01 00:00:00.000000000 +0000 +++ linux-2.6-lttng/arch/sh/include/asm/ltt.h 2008-10-16 18:54:57.000000000 -0400 @@ -0,0 +1,45 @@ +/* + * Copyright (C) 2007, Giuseppe Cavallaro <peppe.cavallaro@xxxxxx> + * Mathieu Desnoyers <mathieu.desnoyers@xxxxxxxxxx> + * + * SuperH definitions for tracing system + */ + +#ifndef _ASM_SH_LTT_H +#define _ASM_SH_LTT_H + +#include <linux/timer.h> +#include <asm/clock.h> + +extern u64 ltt_read_synthetic_tsc(void); + +static inline u32 ltt_get_timestamp32(void) +{ + return get_cycles(); +} + +static inline u64 ltt_get_timestamp64(void) +{ + return ltt_read_synthetic_tsc(); +} + +static inline void ltt_add_timestamp(unsigned long ticks) +{ } + +static inline unsigned int ltt_frequency(void) +{ + unsigned long rate; + struct clk *tmu1_clk; + + tmu1_clk = clk_get(NULL, "tmu1_clk"); + rate = (clk_get_rate(tmu1_clk)); + + return (unsigned int)(rate); +} + +static inline u32 ltt_freq_scale(void) +{ + return 1; +} + +#endif /* _ASM_SH_LTT_H */ Index: linux-2.6-lttng/arch/sh/include/asm/timex.h =================================================================== --- linux-2.6-lttng.orig/arch/sh/include/asm/timex.h 2008-10-16 18:53:59.000000000 -0400 +++ linux-2.6-lttng/arch/sh/include/asm/timex.h 2008-10-16 18:54:51.000000000 -0400 @@ -6,12 +6,18 @@ #ifndef __ASM_SH_TIMEX_H #define __ASM_SH_TIMEX_H -#define CLOCK_TICK_RATE (CONFIG_SH_PCLK_FREQ / 4) /* Underlying HZ */ +#include <linux/io.h> +#include <asm/cpu/timer.h> + +#define CLOCK_TICK_RATE (HZ * 100000UL) typedef unsigned long long cycles_t; static __inline__ cycles_t get_cycles (void) { +#ifdef CONFIG_LTT + return 0xffffffff - ctrl_inl(TMU1_TCNT); +#endif return 0; } Index: linux-2.6-lttng/arch/sh/Kconfig =================================================================== --- linux-2.6-lttng.orig/arch/sh/Kconfig 2008-10-16 18:53:59.000000000 -0400 +++ linux-2.6-lttng/arch/sh/Kconfig 2008-10-16 18:54:51.000000000 -0400 @@ -11,6 +11,8 @@ config SUPERH select HAVE_CLK select HAVE_IDE select HAVE_OPROFILE + select HAVE_LTT_CLOCK + select HAVE_LTT_SYNTHETIC_TSC select HAVE_GENERIC_DMA_COHERENT help The SuperH is a RISC processor targeted for use in embedded systems -- Mathieu Desnoyers Computer Engineering Ph.D. Student, Ecole Polytechnique de Montreal OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68 -- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html