powerpc/perf: Add new BHRB related instructions for POWER8
authorAnshuman Khandual <khandual@linux.vnet.ibm.com>
Mon, 22 Apr 2013 19:42:40 +0000 (19:42 +0000)
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>
Fri, 26 Apr 2013 06:11:11 +0000 (16:11 +1000)
This patch adds new POWER8 instruction encoding for reading
and clearing Branch History Rolling Buffer entries. The new
instruction 'mfbhrbe' (move from branch history rolling buffer
entry) is used to read BHRB buffer entries and instruction
'clrbhrb' (clear branch history rolling buffer) is used to
clear the entire buffer. The instruction 'clrbhrb' has straight
forward encoding. But the instruction encoding format for
reading the BHRB entries is like 'mfbhrbe RT, BHRBE' where it
takes two arguments, i.e the index for the BHRB buffer entry to
read and a general purpose register to put the value which was
read from the buffer entry.

Signed-off-by: Anshuman Khandual <khandual@linux.vnet.ibm.com>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
arch/powerpc/include/asm/ppc-opcode.h

index 8752bc8e34a33a99af07de3e11f874045dc09d65..0c34e4803499f9f6e3900a72725fe469cef10e1e 100644 (file)
@@ -82,6 +82,8 @@
 #define        __REGA0_R31     31
 
 /* sorted alphabetically */
+#define PPC_INST_BHRBE                 0x7c00025c
+#define PPC_INST_CLRBHRB               0x7c00035c
 #define PPC_INST_DCBA                  0x7c0005ec
 #define PPC_INST_DCBA_MASK             0xfc0007fe
 #define PPC_INST_DCBAL                 0x7c2005ec
 #define PPC_NAP                        stringify_in_c(.long PPC_INST_NAP)
 #define PPC_SLEEP              stringify_in_c(.long PPC_INST_SLEEP)
 
+/* BHRB instructions */
+#define PPC_CLRBHRB            stringify_in_c(.long PPC_INST_CLRBHRB)
+#define PPC_MFBHRBE(r, n)      stringify_in_c(.long PPC_INST_BHRBE | \
+                                               __PPC_RT(r) | \
+                                                       (((n) & 0x3ff) << 11))
+
 /* Transactional memory instructions */
 #define TRECHKPT               stringify_in_c(.long PPC_INST_TRECHKPT)
 #define TRECLAIM(r)            stringify_in_c(.long PPC_INST_TRECLAIM \