|
@@ -24,45 +24,45 @@
|
|
|
#define ARCH_P4_CNTRVAL_MASK ((1ULL << ARCH_P4_CNTRVAL_BITS) - 1)
|
|
|
#define ARCH_P4_UNFLAGGED_BIT ((1ULL) << (ARCH_P4_CNTRVAL_BITS - 1))
|
|
|
|
|
|
-#define P4_ESCR_EVENT_MASK 0x7e000000U
|
|
|
+#define P4_ESCR_EVENT_MASK 0x7e000000ULL
|
|
|
#define P4_ESCR_EVENT_SHIFT 25
|
|
|
-#define P4_ESCR_EVENTMASK_MASK 0x01fffe00U
|
|
|
+#define P4_ESCR_EVENTMASK_MASK 0x01fffe00ULL
|
|
|
#define P4_ESCR_EVENTMASK_SHIFT 9
|
|
|
-#define P4_ESCR_TAG_MASK 0x000001e0U
|
|
|
+#define P4_ESCR_TAG_MASK 0x000001e0ULL
|
|
|
#define P4_ESCR_TAG_SHIFT 5
|
|
|
-#define P4_ESCR_TAG_ENABLE 0x00000010U
|
|
|
-#define P4_ESCR_T0_OS 0x00000008U
|
|
|
-#define P4_ESCR_T0_USR 0x00000004U
|
|
|
-#define P4_ESCR_T1_OS 0x00000002U
|
|
|
-#define P4_ESCR_T1_USR 0x00000001U
|
|
|
+#define P4_ESCR_TAG_ENABLE 0x00000010ULL
|
|
|
+#define P4_ESCR_T0_OS 0x00000008ULL
|
|
|
+#define P4_ESCR_T0_USR 0x00000004ULL
|
|
|
+#define P4_ESCR_T1_OS 0x00000002ULL
|
|
|
+#define P4_ESCR_T1_USR 0x00000001ULL
|
|
|
|
|
|
#define P4_ESCR_EVENT(v) ((v) << P4_ESCR_EVENT_SHIFT)
|
|
|
#define P4_ESCR_EMASK(v) ((v) << P4_ESCR_EVENTMASK_SHIFT)
|
|
|
#define P4_ESCR_TAG(v) ((v) << P4_ESCR_TAG_SHIFT)
|
|
|
|
|
|
-#define P4_CCCR_OVF 0x80000000U
|
|
|
-#define P4_CCCR_CASCADE 0x40000000U
|
|
|
-#define P4_CCCR_OVF_PMI_T0 0x04000000U
|
|
|
-#define P4_CCCR_OVF_PMI_T1 0x08000000U
|
|
|
-#define P4_CCCR_FORCE_OVF 0x02000000U
|
|
|
-#define P4_CCCR_EDGE 0x01000000U
|
|
|
-#define P4_CCCR_THRESHOLD_MASK 0x00f00000U
|
|
|
+#define P4_CCCR_OVF 0x80000000ULL
|
|
|
+#define P4_CCCR_CASCADE 0x40000000ULL
|
|
|
+#define P4_CCCR_OVF_PMI_T0 0x04000000ULL
|
|
|
+#define P4_CCCR_OVF_PMI_T1 0x08000000ULL
|
|
|
+#define P4_CCCR_FORCE_OVF 0x02000000ULL
|
|
|
+#define P4_CCCR_EDGE 0x01000000ULL
|
|
|
+#define P4_CCCR_THRESHOLD_MASK 0x00f00000ULL
|
|
|
#define P4_CCCR_THRESHOLD_SHIFT 20
|
|
|
-#define P4_CCCR_COMPLEMENT 0x00080000U
|
|
|
-#define P4_CCCR_COMPARE 0x00040000U
|
|
|
-#define P4_CCCR_ESCR_SELECT_MASK 0x0000e000U
|
|
|
+#define P4_CCCR_COMPLEMENT 0x00080000ULL
|
|
|
+#define P4_CCCR_COMPARE 0x00040000ULL
|
|
|
+#define P4_CCCR_ESCR_SELECT_MASK 0x0000e000ULL
|
|
|
#define P4_CCCR_ESCR_SELECT_SHIFT 13
|
|
|
-#define P4_CCCR_ENABLE 0x00001000U
|
|
|
-#define P4_CCCR_THREAD_SINGLE 0x00010000U
|
|
|
-#define P4_CCCR_THREAD_BOTH 0x00020000U
|
|
|
-#define P4_CCCR_THREAD_ANY 0x00030000U
|
|
|
-#define P4_CCCR_RESERVED 0x00000fffU
|
|
|
+#define P4_CCCR_ENABLE 0x00001000ULL
|
|
|
+#define P4_CCCR_THREAD_SINGLE 0x00010000ULL
|
|
|
+#define P4_CCCR_THREAD_BOTH 0x00020000ULL
|
|
|
+#define P4_CCCR_THREAD_ANY 0x00030000ULL
|
|
|
+#define P4_CCCR_RESERVED 0x00000fffULL
|
|
|
|
|
|
#define P4_CCCR_THRESHOLD(v) ((v) << P4_CCCR_THRESHOLD_SHIFT)
|
|
|
#define P4_CCCR_ESEL(v) ((v) << P4_CCCR_ESCR_SELECT_SHIFT)
|
|
|
|
|
|
#define P4_GEN_ESCR_EMASK(class, name, bit) \
|
|
|
- class##__##name = ((1 << bit) << P4_ESCR_EVENTMASK_SHIFT)
|
|
|
+ class##__##name = ((1ULL << bit) << P4_ESCR_EVENTMASK_SHIFT)
|
|
|
#define P4_ESCR_EMASK_BIT(class, name) class##__##name
|
|
|
|
|
|
/*
|
|
@@ -107,7 +107,7 @@
|
|
|
* P4_PEBS_CONFIG_MASK and related bits on
|
|
|
* modification.)
|
|
|
*/
|
|
|
-#define P4_CONFIG_ALIASABLE (1 << 9)
|
|
|
+#define P4_CONFIG_ALIASABLE (1ULL << 9)
|
|
|
|
|
|
/*
|
|
|
* The bits we allow to pass for RAW events
|
|
@@ -784,17 +784,17 @@ enum P4_ESCR_EMASKS {
|
|
|
* Note we have UOP and PEBS bits reserved for now
|
|
|
* just in case if we will need them once
|
|
|
*/
|
|
|
-#define P4_PEBS_CONFIG_ENABLE (1 << 7)
|
|
|
-#define P4_PEBS_CONFIG_UOP_TAG (1 << 8)
|
|
|
-#define P4_PEBS_CONFIG_METRIC_MASK 0x3f
|
|
|
-#define P4_PEBS_CONFIG_MASK 0xff
|
|
|
+#define P4_PEBS_CONFIG_ENABLE (1ULL << 7)
|
|
|
+#define P4_PEBS_CONFIG_UOP_TAG (1ULL << 8)
|
|
|
+#define P4_PEBS_CONFIG_METRIC_MASK 0x3FLL
|
|
|
+#define P4_PEBS_CONFIG_MASK 0xFFLL
|
|
|
|
|
|
/*
|
|
|
* mem: Only counters MSR_IQ_COUNTER4 (16) and
|
|
|
* MSR_IQ_COUNTER5 (17) are allowed for PEBS sampling
|
|
|
*/
|
|
|
-#define P4_PEBS_ENABLE 0x02000000U
|
|
|
-#define P4_PEBS_ENABLE_UOP_TAG 0x01000000U
|
|
|
+#define P4_PEBS_ENABLE 0x02000000ULL
|
|
|
+#define P4_PEBS_ENABLE_UOP_TAG 0x01000000ULL
|
|
|
|
|
|
#define p4_config_unpack_metric(v) (((u64)(v)) & P4_PEBS_CONFIG_METRIC_MASK)
|
|
|
#define p4_config_unpack_pebs(v) (((u64)(v)) & P4_PEBS_CONFIG_MASK)
|