reg_fsl_emb.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /*
  2. * Contains register definitions for the Freescale Embedded Performance
  3. * Monitor.
  4. */
  5. #ifdef __KERNEL__
  6. #ifndef __ASM_POWERPC_REG_FSL_EMB_H__
  7. #define __ASM_POWERPC_REG_FSL_EMB_H__
  8. #ifndef __ASSEMBLY__
  9. /* Performance Monitor Registers */
  10. #define mfpmr(rn) ({unsigned int rval; \
  11. asm volatile("mfpmr %0," __stringify(rn) \
  12. : "=r" (rval)); rval;})
  13. #define mtpmr(rn, v) asm volatile("mtpmr " __stringify(rn) ",%0" : : "r" (v))
  14. #endif /* __ASSEMBLY__ */
  15. /* Freescale Book E Performance Monitor APU Registers */
  16. #define PMRN_PMC0 0x010 /* Performance Monitor Counter 0 */
  17. #define PMRN_PMC1 0x011 /* Performance Monitor Counter 1 */
  18. #define PMRN_PMC2 0x012 /* Performance Monitor Counter 2 */
  19. #define PMRN_PMC3 0x013 /* Performance Monitor Counter 3 */
  20. #define PMRN_PMC4 0x014 /* Performance Monitor Counter 4 */
  21. #define PMRN_PMC5 0x015 /* Performance Monitor Counter 5 */
  22. #define PMRN_PMLCA0 0x090 /* PM Local Control A0 */
  23. #define PMRN_PMLCA1 0x091 /* PM Local Control A1 */
  24. #define PMRN_PMLCA2 0x092 /* PM Local Control A2 */
  25. #define PMRN_PMLCA3 0x093 /* PM Local Control A3 */
  26. #define PMRN_PMLCA4 0x094 /* PM Local Control A4 */
  27. #define PMRN_PMLCA5 0x095 /* PM Local Control A5 */
  28. #define PMLCA_FC 0x80000000 /* Freeze Counter */
  29. #define PMLCA_FCS 0x40000000 /* Freeze in Supervisor */
  30. #define PMLCA_FCU 0x20000000 /* Freeze in User */
  31. #define PMLCA_FCM1 0x10000000 /* Freeze when PMM==1 */
  32. #define PMLCA_FCM0 0x08000000 /* Freeze when PMM==0 */
  33. #define PMLCA_CE 0x04000000 /* Condition Enable */
  34. #define PMLCA_FGCS1 0x00000002 /* Freeze in guest state */
  35. #define PMLCA_FGCS0 0x00000001 /* Freeze in hypervisor state */
  36. #define PMLCA_EVENT_MASK 0x01ff0000 /* Event field */
  37. #define PMLCA_EVENT_SHIFT 16
  38. #define PMRN_PMLCB0 0x110 /* PM Local Control B0 */
  39. #define PMRN_PMLCB1 0x111 /* PM Local Control B1 */
  40. #define PMRN_PMLCB2 0x112 /* PM Local Control B2 */
  41. #define PMRN_PMLCB3 0x113 /* PM Local Control B3 */
  42. #define PMRN_PMLCB4 0x114 /* PM Local Control B4 */
  43. #define PMRN_PMLCB5 0x115 /* PM Local Control B5 */
  44. #define PMLCB_THRESHMUL_MASK 0x0700 /* Threshold Multiple Field */
  45. #define PMLCB_THRESHMUL_SHIFT 8
  46. #define PMLCB_THRESHOLD_MASK 0x003f /* Threshold Field */
  47. #define PMLCB_THRESHOLD_SHIFT 0
  48. #define PMRN_PMGC0 0x190 /* PM Global Control 0 */
  49. #define PMGC0_FAC 0x80000000 /* Freeze all Counters */
  50. #define PMGC0_PMIE 0x40000000 /* Interrupt Enable */
  51. #define PMGC0_FCECE 0x20000000 /* Freeze countes on
  52. Enabled Condition or
  53. Event */
  54. #define PMRN_UPMC0 0x000 /* User Performance Monitor Counter 0 */
  55. #define PMRN_UPMC1 0x001 /* User Performance Monitor Counter 1 */
  56. #define PMRN_UPMC2 0x002 /* User Performance Monitor Counter 2 */
  57. #define PMRN_UPMC3 0x003 /* User Performance Monitor Counter 3 */
  58. #define PMRN_UPMC4 0x004 /* User Performance Monitor Counter 4 */
  59. #define PMRN_UPMC5 0x005 /* User Performance Monitor Counter 5 */
  60. #define PMRN_UPMLCA0 0x080 /* User PM Local Control A0 */
  61. #define PMRN_UPMLCA1 0x081 /* User PM Local Control A1 */
  62. #define PMRN_UPMLCA2 0x082 /* User PM Local Control A2 */
  63. #define PMRN_UPMLCA3 0x083 /* User PM Local Control A3 */
  64. #define PMRN_UPMLCA4 0x084 /* User PM Local Control A4 */
  65. #define PMRN_UPMLCA5 0x085 /* User PM Local Control A5 */
  66. #define PMRN_UPMLCB0 0x100 /* User PM Local Control B0 */
  67. #define PMRN_UPMLCB1 0x101 /* User PM Local Control B1 */
  68. #define PMRN_UPMLCB2 0x102 /* User PM Local Control B2 */
  69. #define PMRN_UPMLCB3 0x103 /* User PM Local Control B3 */
  70. #define PMRN_UPMLCB4 0x104 /* User PM Local Control B4 */
  71. #define PMRN_UPMLCB5 0x105 /* User PM Local Control B5 */
  72. #define PMRN_UPMGC0 0x180 /* User PM Global Control 0 */
  73. #endif /* __ASM_POWERPC_REG_FSL_EMB_H__ */
  74. #endif /* __KERNEL__ */