Rev 1787 | Rev 1851 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 1787 | Rev 1789 | ||
|---|---|---|---|
| Line 30... | Line 30... | ||
| 30 | * @{ |
30 | * @{ |
| 31 | */ |
31 | */ |
| 32 | /** @file |
32 | /** @file |
| 33 | */ |
33 | */ |
| 34 | 34 | ||
| 35 | #ifndef KERN_sparc64_REGISTER_H_ |
35 | #ifndef KERN_sparc64_REGDEF_H_ |
| 36 | #define KERN_sparc64_REGISTER_H_ |
36 | #define KERN_sparc64_REGDEF_H_ |
| 37 | 37 | ||
| 38 | #ifdef __ASM__ |
- | |
| 39 | #define PSTATE_IE_BIT 2 |
38 | #define PSTATE_IE_BIT 2 |
| 40 | #define PSTATE_AM_BIT 8 |
39 | #define PSTATE_AM_BIT 8 |
| 41 | #else |
- | |
| 42 | - | ||
| 43 | #include <arch/types.h> |
- | |
| 44 | - | ||
| 45 | /** Version Register. */ |
- | |
| 46 | union ver_reg { |
- | |
| 47 | uint64_t value; |
- | |
| 48 | struct { |
- | |
| 49 | uint16_t manuf; /**< Manufacturer code. */ |
- | |
| 50 | uint16_t impl; /**< Implementation code. */ |
- | |
| 51 | uint8_t mask; /**< Mask set revision. */ |
- | |
| 52 | unsigned : 8; |
- | |
| 53 | uint8_t maxtl; |
- | |
| 54 | unsigned : 3; |
- | |
| 55 | unsigned maxwin : 5; |
- | |
| 56 | } __attribute__ ((packed)); |
- | |
| 57 | }; |
- | |
| 58 | typedef union ver_reg ver_reg_t; |
- | |
| 59 | - | ||
| 60 | /** Processor State Register. */ |
- | |
| 61 | union pstate_reg { |
- | |
| 62 | uint64_t value; |
- | |
| 63 | struct { |
- | |
| 64 | uint64_t : 52; |
- | |
| 65 | unsigned ig : 1; /**< Interrupt Globals. */ |
- | |
| 66 | unsigned mg : 1; /**< MMU Globals. */ |
- | |
| 67 | unsigned cle : 1; /**< Current Little Endian. */ |
- | |
| 68 | unsigned tle : 1; /**< Trap Little Endian. */ |
- | |
| 69 | unsigned mm : 2; /**< Memory Model. */ |
- | |
| 70 | unsigned red : 1; /**< RED state. */ |
- | |
| 71 | unsigned pef : 1; /**< Enable floating-point. */ |
- | |
| 72 | unsigned am : 1; /**< 32-bit Address Mask. */ |
- | |
| 73 | unsigned priv : 1; /**< Privileged Mode. */ |
- | |
| 74 | unsigned ie : 1; /**< Interrupt Enable. */ |
- | |
| 75 | unsigned ag : 1; /**< Alternate Globals*/ |
- | |
| 76 | } __attribute__ ((packed)); |
- | |
| 77 | }; |
- | |
| 78 | typedef union pstate_reg pstate_reg_t; |
- | |
| 79 | - | ||
| 80 | /** TICK Register. */ |
- | |
| 81 | union tick_reg { |
- | |
| 82 | uint64_t value; |
- | |
| 83 | struct { |
- | |
| 84 | unsigned npt : 1; /**< Non-privileged Trap enable. */ |
- | |
| 85 | uint64_t counter : 63; /**< Elapsed CPU clck cycle counter. */ |
- | |
| 86 | } __attribute__ ((packed)); |
- | |
| 87 | }; |
- | |
| 88 | typedef union tick_reg tick_reg_t; |
- | |
| 89 | - | ||
| 90 | /** TICK_compare Register. */ |
- | |
| 91 | union tick_compare_reg { |
- | |
| 92 | uint64_t value; |
- | |
| 93 | struct { |
- | |
| 94 | unsigned int_dis : 1; /**< TICK_INT interrupt disabled flag. */ |
- | |
| 95 | uint64_t tick_cmpr : 63; /**< Compare value for TICK interrupts. */ |
- | |
| 96 | } __attribute__ ((packed)); |
- | |
| 97 | }; |
- | |
| 98 | typedef union tick_compare_reg tick_compare_reg_t; |
- | |
| 99 | - | ||
| 100 | /** SOFTINT Register. */ |
- | |
| 101 | union softint_reg { |
- | |
| 102 | uint64_t value; |
- | |
| 103 | struct { |
- | |
| 104 | uint64_t : 47; |
- | |
| 105 | unsigned stick_int : 1; |
- | |
| 106 | unsigned int_level : 15; |
- | |
| 107 | unsigned tick_int : 1; |
- | |
| 108 | } __attribute__ ((packed)); |
- | |
| 109 | }; |
- | |
| 110 | typedef union softint_reg softint_reg_t; |
- | |
| 111 | - | ||
| 112 | #endif |
- | |
| 113 | 40 | ||
| 114 | #endif |
41 | #endif |
| 115 | 42 | ||
| 116 | /** @} |
43 | /** @} |
| 117 | */ |
44 | */ |