blob: b156ebadd2e7b44e47b2f529fed25a2d1adff297 [file] [log] [blame]
Pratik Patele7b35aa2012-10-24 17:34:43 -07001#ifndef _LINUX_CORESIGHT_STM_H
2#define _LINUX_CORESIGHT_STM_H
Pratik Patel5ecf6a12012-04-25 18:34:59 -07003
4enum {
Pratik Patel8e1e6b62012-06-29 12:24:49 -07005 OST_ENTITY_NONE = 0x00,
6 OST_ENTITY_FTRACE_EVENTS = 0x01,
7 OST_ENTITY_TRACE_PRINTK = 0x02,
8 OST_ENTITY_TRACE_MARKER = 0x04,
9 OST_ENTITY_DEV_NODE = 0x08,
Pratik Patel9e0a0f52012-11-05 09:41:01 -080010 OST_ENTITY_QVIEW = 0xFE,
Pratik Patele7b35aa2012-10-24 17:34:43 -070011 OST_ENTITY_MAX = 0xFF,
Pratik Patel5ecf6a12012-04-25 18:34:59 -070012};
13
14enum {
15 STM_OPTION_NONE = 0x0,
16 STM_OPTION_TIMESTAMPED = 0x08,
17 STM_OPTION_GUARANTEED = 0x80,
18};
19
David Ng8fce1322012-10-05 10:28:19 -070020#ifdef __KERNEL__
Pratik Patel5ecf6a12012-04-25 18:34:59 -070021#define stm_log_inv(entity_id, proto_id, data, size) \
22 stm_trace(STM_OPTION_NONE, entity_id, proto_id, data, size)
23
24#define stm_log_inv_ts(entity_id, proto_id, data, size) \
25 stm_trace(STM_OPTION_TIMESTAMPED, entity_id, proto_id, \
26 data, size)
27
28#define stm_log_gtd(entity_id, proto_id, data, size) \
29 stm_trace(STM_OPTION_GUARANTEED, entity_id, proto_id, \
30 data, size)
31
32#define stm_log_gtd_ts(entity_id, proto_id, data, size) \
33 stm_trace(STM_OPTION_GUARANTEED | STM_OPTION_TIMESTAMPED, \
34 entity_id, proto_id, data, size)
35
36#define stm_log(entity_id, data, size) \
37 stm_log_inv_ts(entity_id, 0, data, size)
38
39#ifdef CONFIG_MSM_QDSS
40extern int stm_trace(uint32_t options, uint8_t entity_id, uint8_t proto_id,
41 const void *data, uint32_t size);
42#else
43static inline int stm_trace(uint32_t options, uint8_t entity_id,
44 uint8_t proto_id, const void *data, uint32_t size)
45{
46 return 0;
47}
48#endif
David Ng8fce1322012-10-05 10:28:19 -070049#endif /* __KERNEL__ */
Pratik Patel5ecf6a12012-04-25 18:34:59 -070050
51#endif