do { \
trace_var(_e, 1, 0, NULL); \
} while ( 0 )
-
-#define TRACE_1D(_e,d1) \
- do { \
- if ( unlikely(tb_init_done) ) \
- { \
- u32 _d[1]; \
- _d[0] = d1; \
- __trace_var(_e, 1, sizeof(_d), _d); \
- } \
- } while ( 0 )
-
-#define TRACE_2D(_e,d1,d2) \
- do { \
- if ( unlikely(tb_init_done) ) \
- { \
- u32 _d[2]; \
- _d[0] = d1; \
- _d[1] = d2; \
- __trace_var(_e, 1, sizeof(_d), _d); \
- } \
- } while ( 0 )
-
-#define TRACE_3D(_e,d1,d2,d3) \
- do { \
- if ( unlikely(tb_init_done) ) \
- { \
- u32 _d[3]; \
- _d[0] = d1; \
- _d[1] = d2; \
- _d[2] = d3; \
- __trace_var(_e, 1, sizeof(_d), _d); \
- } \
- } while ( 0 )
-
-#define TRACE_4D(_e,d1,d2,d3,d4) \
- do { \
- if ( unlikely(tb_init_done) ) \
- { \
- u32 _d[4]; \
- _d[0] = d1; \
- _d[1] = d2; \
- _d[2] = d3; \
- _d[3] = d4; \
- __trace_var(_e, 1, sizeof(_d), _d); \
- } \
- } while ( 0 )
-
-#define TRACE_5D(_e,d1,d2,d3,d4,d5) \
- do { \
- if ( unlikely(tb_init_done) ) \
- { \
- u32 _d[5]; \
- _d[0] = d1; \
- _d[1] = d2; \
- _d[2] = d3; \
- _d[3] = d4; \
- _d[4] = d5; \
- __trace_var(_e, 1, sizeof(_d), _d); \
- } \
- } while ( 0 )
-#define TRACE_6D(_e,d1,d2,d3,d4,d5,d6) \
- do { \
- if ( unlikely(tb_init_done) ) \
- { \
- u32 _d[6]; \
- _d[0] = d1; \
- _d[1] = d2; \
- _d[2] = d3; \
- _d[3] = d4; \
- _d[4] = d5; \
- _d[5] = d6; \
- __trace_var(_e, 1, sizeof(_d), _d); \
- } \
+/* Common helper for TRACE_{1..6}D() below. */
+#define TRACE_varD(_e, ...) \
+ do { \
+ if ( unlikely(tb_init_done) ) \
+ { \
+ uint32_t _d[] = { __VA_ARGS__ }; \
+ __trace_var(_e, true, sizeof(_d), _d); \
+ } \
} while ( 0 )
+#define TRACE_1D(_e, d1) \
+ TRACE_varD(_e, d1)
+
+#define TRACE_2D(_e, d1, d2) \
+ TRACE_varD(_e, d1, d2)
+
+#define TRACE_3D(_e, d1, d2, d3) \
+ TRACE_varD(_e, d1, d2, d3)
+
+#define TRACE_4D(_e, d1, d2, d3, d4) \
+ TRACE_varD(_e, d1, d2, d3, d4)
+
+#define TRACE_5D(_e, d1, d2, d3, d4, d5) \
+ TRACE_varD(_e, d1, d2, d3, d4, d5)
+
+#define TRACE_6D(_e, d1, d2, d3, d4, d5, d6) \
+ TRACE_varD(_e, d1, d2, d3, d4, d5, d6)
+
#endif /* __XEN_TRACE_H__ */