61 lines
2.1 KiB
C
61 lines
2.1 KiB
C
|
/*
|
||
|
* Copyright 2014, Michael Ellerman, IBM Corp.
|
||
|
* Licensed under GPLv2.
|
||
|
*/
|
||
|
|
||
|
#ifndef _SELFTESTS_POWERPC_REG_H
|
||
|
#define _SELFTESTS_POWERPC_REG_H
|
||
|
|
||
|
#define __stringify_1(x) #x
|
||
|
#define __stringify(x) __stringify_1(x)
|
||
|
|
||
|
#define mfspr(rn) ({unsigned long rval; \
|
||
|
asm volatile("mfspr %0," _str(rn) \
|
||
|
: "=r" (rval)); rval; })
|
||
|
#define mtspr(rn, v) asm volatile("mtspr " _str(rn) ",%0" : \
|
||
|
: "r" ((unsigned long)(v)) \
|
||
|
: "memory")
|
||
|
|
||
|
#define mb() asm volatile("sync" : : : "memory");
|
||
|
|
||
|
#define SPRN_MMCR2 769
|
||
|
#define SPRN_MMCRA 770
|
||
|
#define SPRN_MMCR0 779
|
||
|
#define MMCR0_PMAO 0x00000080
|
||
|
#define MMCR0_PMAE 0x04000000
|
||
|
#define MMCR0_FC 0x80000000
|
||
|
#define SPRN_EBBHR 804
|
||
|
#define SPRN_EBBRR 805
|
||
|
#define SPRN_BESCR 806 /* Branch event status & control register */
|
||
|
#define SPRN_BESCRS 800 /* Branch event status & control set (1 bits set to 1) */
|
||
|
#define SPRN_BESCRSU 801 /* Branch event status & control set upper */
|
||
|
#define SPRN_BESCRR 802 /* Branch event status & control REset (1 bits set to 0) */
|
||
|
#define SPRN_BESCRRU 803 /* Branch event status & control REset upper */
|
||
|
|
||
|
#define BESCR_PMEO 0x1 /* PMU Event-based exception Occurred */
|
||
|
#define BESCR_PME (0x1ul << 32) /* PMU Event-based exception Enable */
|
||
|
#define BESCR_LME (0x1ul << 34) /* Load Monitor Enable */
|
||
|
#define BESCR_LMEO (0x1ul << 2) /* Load Monitor Exception Occurred */
|
||
|
|
||
|
#define SPRN_LMRR 813 /* Load Monitor Region Register */
|
||
|
#define SPRN_LMSER 814 /* Load Monitor Section Enable Register */
|
||
|
|
||
|
#define SPRN_PMC1 771
|
||
|
#define SPRN_PMC2 772
|
||
|
#define SPRN_PMC3 773
|
||
|
#define SPRN_PMC4 774
|
||
|
#define SPRN_PMC5 775
|
||
|
#define SPRN_PMC6 776
|
||
|
|
||
|
#define SPRN_SIAR 780
|
||
|
#define SPRN_SDAR 781
|
||
|
#define SPRN_SIER 768
|
||
|
|
||
|
#define SPRN_TEXASR 0x82
|
||
|
#define SPRN_TFIAR 0x81 /* Transaction Failure Inst Addr */
|
||
|
#define SPRN_TFHAR 0x80 /* Transaction Failure Handler Addr */
|
||
|
#define TEXASR_FS 0x08000000
|
||
|
#define SPRN_TAR 0x32f
|
||
|
|
||
|
#endif /* _SELFTESTS_POWERPC_REG_H */
|