blob: 312b596b9731f477ac1c2238ef7ad92478c626dd [file] [log] [blame]
Robin Getz669b7922007-06-21 16:34:08 +08001/*
2 * Common header file for blackfin family of processors.
3 *
4 */
5
6#ifndef _BLACKFIN_TRACE_
7#define _BLACKFIN_TRACE_
8
Robin Getz518039b2007-07-25 11:03:28 +08009/* Normally, we use ON, but you can't turn on software expansion until
10 * interrupts subsystem is ready
11 */
12
13#define BFIN_TRACE_INIT ((CONFIG_DEBUG_BFIN_HWTRACE_COMPRESSION << 4) | 0x03)
14#ifdef CONFIG_DEBUG_BFIN_HWTRACE_EXPAND
15#define BFIN_TRACE_ON (BFIN_TRACE_INIT | (CONFIG_DEBUG_BFIN_HWTRACE_EXPAND << 2))
16#else
17#define BFIN_TRACE_ON (BFIN_TRACE_INIT)
18#endif
19
Robin Getz669b7922007-06-21 16:34:08 +080020#ifndef __ASSEMBLY__
Robin Getz518039b2007-07-25 11:03:28 +080021extern unsigned long trace_buff_offset;
22extern unsigned long software_trace_buff[];
23
Robin Getz669b7922007-06-21 16:34:08 +080024/* Trace Macros for C files */
25
Robin Getz518039b2007-07-25 11:03:28 +080026#ifdef CONFIG_DEBUG_BFIN_HWTRACE_ON
27
Robin Getz669b7922007-06-21 16:34:08 +080028#define trace_buffer_save(x) \
Robin Getz518039b2007-07-25 11:03:28 +080029 do { \
30 (x) = bfin_read_TBUFCTL(); \
31 bfin_write_TBUFCTL((x) & ~TBUFEN); \
32 } while (0)
Robin Getz669b7922007-06-21 16:34:08 +080033
34#define trace_buffer_restore(x) \
Robin Getz518039b2007-07-25 11:03:28 +080035 do { \
36 bfin_write_TBUFCTL((x)); \
37 } while (0)
38#else /* DEBUG_BFIN_HWTRACE_ON */
39
40#define trace_buffer_save(x)
41#define trace_buffer_restore(x)
42#endif /* CONFIG_DEBUG_BFIN_HWTRACE_ON */
Robin Getz669b7922007-06-21 16:34:08 +080043
44#else
45/* Trace Macros for Assembly files */
46
Robin Getz518039b2007-07-25 11:03:28 +080047#ifdef CONFIG_DEBUG_BFIN_HWTRACE_ON
48
Robin Getz669b7922007-06-21 16:34:08 +080049#define trace_buffer_stop(preg, dreg) \
50 preg.L = LO(TBUFCTL); \
51 preg.H = HI(TBUFCTL); \
52 dreg = 0x1; \
53 [preg] = dreg;
54
Robin Getz518039b2007-07-25 11:03:28 +080055#define trace_buffer_init(preg, dreg) \
56 preg.L = LO(TBUFCTL); \
57 preg.H = HI(TBUFCTL); \
58 dreg = BFIN_TRACE_INIT; \
59 [preg] = dreg;
60
Mike Frysinger80f31c82008-02-02 15:47:24 +080061#define trace_buffer_save(preg, dreg) \
62 preg.L = LO(TBUFCTL); \
63 preg.H = HI(TBUFCTL); \
64 dreg = [preg]; \
Bernd Schmidt2a0c4fd2008-04-23 07:17:34 +080065 [--sp] = dreg; \
Mike Frysinger80f31c82008-02-02 15:47:24 +080066 dreg = 0x1; \
67 [preg] = dreg;
68
69#define trace_buffer_restore(preg, dreg) \
70 preg.L = LO(TBUFCTL); \
71 preg.H = HI(TBUFCTL); \
Bernd Schmidt2a0c4fd2008-04-23 07:17:34 +080072 dreg = [sp++]; \
Mike Frysinger80f31c82008-02-02 15:47:24 +080073 [preg] = dreg;
74
Robin Getz518039b2007-07-25 11:03:28 +080075#else /* CONFIG_DEBUG_BFIN_HWTRACE_ON */
76
77#define trace_buffer_stop(preg, dreg)
Robin Getz518039b2007-07-25 11:03:28 +080078#define trace_buffer_init(preg, dreg)
Mike Frysinger80f31c82008-02-02 15:47:24 +080079#define trace_buffer_save(preg, dreg)
80#define trace_buffer_restore(preg, dreg)
Robin Getz518039b2007-07-25 11:03:28 +080081
82#endif /* CONFIG_DEBUG_BFIN_HWTRACE_ON */
83
Robin Getz669b7922007-06-21 16:34:08 +080084#ifdef CONFIG_DEBUG_BFIN_NO_KERN_HWTRACE
Mike Frysinger80f31c82008-02-02 15:47:24 +080085# define DEBUG_HWTRACE_SAVE(preg, dreg) trace_buffer_save(preg, dreg)
86# define DEBUG_HWTRACE_RESTORE(preg, dreg) trace_buffer_restore(preg, dreg)
Robin Getz669b7922007-06-21 16:34:08 +080087#else
Mike Frysinger80f31c82008-02-02 15:47:24 +080088# define DEBUG_HWTRACE_SAVE(preg, dreg)
89# define DEBUG_HWTRACE_RESTORE(preg, dreg)
Robin Getz669b7922007-06-21 16:34:08 +080090#endif
91
92#endif /* __ASSEMBLY__ */
93
94#endif /* _BLACKFIN_TRACE_ */