0001
0002
0003
0004
0005
0006 #ifndef __LIMA_REGS_H__
0007 #define __LIMA_REGS_H__
0008
0009
0010
0011
0012
0013
0014 #define LIMA_PMU_POWER_UP 0x00
0015 #define LIMA_PMU_POWER_DOWN 0x04
0016 #define LIMA_PMU_POWER_GP0_MASK BIT(0)
0017 #define LIMA_PMU_POWER_L2_MASK BIT(1)
0018 #define LIMA_PMU_POWER_PP_MASK(i) BIT(2 + i)
0019
0020
0021
0022
0023
0024
0025 #define LIMA450_PMU_POWER_PP0_MASK BIT(1)
0026 #define LIMA450_PMU_POWER_PP13_MASK BIT(2)
0027 #define LIMA450_PMU_POWER_PP47_MASK BIT(3)
0028
0029 #define LIMA_PMU_STATUS 0x08
0030 #define LIMA_PMU_INT_MASK 0x0C
0031 #define LIMA_PMU_INT_RAWSTAT 0x10
0032 #define LIMA_PMU_INT_CLEAR 0x18
0033 #define LIMA_PMU_INT_CMD_MASK BIT(0)
0034 #define LIMA_PMU_SW_DELAY 0x1C
0035
0036
0037 #define LIMA_L2_CACHE_SIZE 0x0004
0038 #define LIMA_L2_CACHE_STATUS 0x0008
0039 #define LIMA_L2_CACHE_STATUS_COMMAND_BUSY BIT(0)
0040 #define LIMA_L2_CACHE_STATUS_DATA_BUSY BIT(1)
0041 #define LIMA_L2_CACHE_COMMAND 0x0010
0042 #define LIMA_L2_CACHE_COMMAND_CLEAR_ALL BIT(0)
0043 #define LIMA_L2_CACHE_CLEAR_PAGE 0x0014
0044 #define LIMA_L2_CACHE_MAX_READS 0x0018
0045 #define LIMA_L2_CACHE_ENABLE 0x001C
0046 #define LIMA_L2_CACHE_ENABLE_ACCESS BIT(0)
0047 #define LIMA_L2_CACHE_ENABLE_READ_ALLOCATE BIT(1)
0048 #define LIMA_L2_CACHE_PERFCNT_SRC0 0x0020
0049 #define LIMA_L2_CACHE_PERFCNT_VAL0 0x0024
0050 #define LIMA_L2_CACHE_PERFCNT_SRC1 0x0028
0051 #define LIMA_L2_CACHE_ERFCNT_VAL1 0x002C
0052
0053
0054 #define LIMA_GP_VSCL_START_ADDR 0x00
0055 #define LIMA_GP_VSCL_END_ADDR 0x04
0056 #define LIMA_GP_PLBUCL_START_ADDR 0x08
0057 #define LIMA_GP_PLBUCL_END_ADDR 0x0c
0058 #define LIMA_GP_PLBU_ALLOC_START_ADDR 0x10
0059 #define LIMA_GP_PLBU_ALLOC_END_ADDR 0x14
0060 #define LIMA_GP_CMD 0x20
0061 #define LIMA_GP_CMD_START_VS BIT(0)
0062 #define LIMA_GP_CMD_START_PLBU BIT(1)
0063 #define LIMA_GP_CMD_UPDATE_PLBU_ALLOC BIT(4)
0064 #define LIMA_GP_CMD_RESET BIT(5)
0065 #define LIMA_GP_CMD_FORCE_HANG BIT(6)
0066 #define LIMA_GP_CMD_STOP_BUS BIT(9)
0067 #define LIMA_GP_CMD_SOFT_RESET BIT(10)
0068 #define LIMA_GP_INT_RAWSTAT 0x24
0069 #define LIMA_GP_INT_CLEAR 0x28
0070 #define LIMA_GP_INT_MASK 0x2C
0071 #define LIMA_GP_INT_STAT 0x30
0072 #define LIMA_GP_IRQ_VS_END_CMD_LST BIT(0)
0073 #define LIMA_GP_IRQ_PLBU_END_CMD_LST BIT(1)
0074 #define LIMA_GP_IRQ_PLBU_OUT_OF_MEM BIT(2)
0075 #define LIMA_GP_IRQ_VS_SEM_IRQ BIT(3)
0076 #define LIMA_GP_IRQ_PLBU_SEM_IRQ BIT(4)
0077 #define LIMA_GP_IRQ_HANG BIT(5)
0078 #define LIMA_GP_IRQ_FORCE_HANG BIT(6)
0079 #define LIMA_GP_IRQ_PERF_CNT_0_LIMIT BIT(7)
0080 #define LIMA_GP_IRQ_PERF_CNT_1_LIMIT BIT(8)
0081 #define LIMA_GP_IRQ_WRITE_BOUND_ERR BIT(9)
0082 #define LIMA_GP_IRQ_SYNC_ERROR BIT(10)
0083 #define LIMA_GP_IRQ_AXI_BUS_ERROR BIT(11)
0084 #define LIMA_GP_IRQ_AXI_BUS_STOPPED BIT(12)
0085 #define LIMA_GP_IRQ_VS_INVALID_CMD BIT(13)
0086 #define LIMA_GP_IRQ_PLB_INVALID_CMD BIT(14)
0087 #define LIMA_GP_IRQ_RESET_COMPLETED BIT(19)
0088 #define LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW BIT(20)
0089 #define LIMA_GP_IRQ_SEMAPHORE_OVERFLOW BIT(21)
0090 #define LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS BIT(22)
0091 #define LIMA_GP_WRITE_BOUND_LOW 0x34
0092 #define LIMA_GP_PERF_CNT_0_ENABLE 0x3C
0093 #define LIMA_GP_PERF_CNT_1_ENABLE 0x40
0094 #define LIMA_GP_PERF_CNT_0_SRC 0x44
0095 #define LIMA_GP_PERF_CNT_1_SRC 0x48
0096 #define LIMA_GP_PERF_CNT_0_VALUE 0x4C
0097 #define LIMA_GP_PERF_CNT_1_VALUE 0x50
0098 #define LIMA_GP_PERF_CNT_0_LIMIT 0x54
0099 #define LIMA_GP_STATUS 0x68
0100 #define LIMA_GP_STATUS_VS_ACTIVE BIT(1)
0101 #define LIMA_GP_STATUS_BUS_STOPPED BIT(2)
0102 #define LIMA_GP_STATUS_PLBU_ACTIVE BIT(3)
0103 #define LIMA_GP_STATUS_BUS_ERROR BIT(6)
0104 #define LIMA_GP_STATUS_WRITE_BOUND_ERR BIT(8)
0105 #define LIMA_GP_VERSION 0x6C
0106 #define LIMA_GP_VSCL_START_ADDR_READ 0x80
0107 #define LIMA_GP_PLBCL_START_ADDR_READ 0x84
0108 #define LIMA_GP_CONTR_AXI_BUS_ERROR_STAT 0x94
0109
0110 #define LIMA_GP_IRQ_MASK_ALL \
0111 ( \
0112 LIMA_GP_IRQ_VS_END_CMD_LST | \
0113 LIMA_GP_IRQ_PLBU_END_CMD_LST | \
0114 LIMA_GP_IRQ_PLBU_OUT_OF_MEM | \
0115 LIMA_GP_IRQ_VS_SEM_IRQ | \
0116 LIMA_GP_IRQ_PLBU_SEM_IRQ | \
0117 LIMA_GP_IRQ_HANG | \
0118 LIMA_GP_IRQ_FORCE_HANG | \
0119 LIMA_GP_IRQ_PERF_CNT_0_LIMIT | \
0120 LIMA_GP_IRQ_PERF_CNT_1_LIMIT | \
0121 LIMA_GP_IRQ_WRITE_BOUND_ERR | \
0122 LIMA_GP_IRQ_SYNC_ERROR | \
0123 LIMA_GP_IRQ_AXI_BUS_ERROR | \
0124 LIMA_GP_IRQ_AXI_BUS_STOPPED | \
0125 LIMA_GP_IRQ_VS_INVALID_CMD | \
0126 LIMA_GP_IRQ_PLB_INVALID_CMD | \
0127 LIMA_GP_IRQ_RESET_COMPLETED | \
0128 LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW | \
0129 LIMA_GP_IRQ_SEMAPHORE_OVERFLOW | \
0130 LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS)
0131
0132 #define LIMA_GP_IRQ_MASK_ERROR \
0133 ( \
0134 LIMA_GP_IRQ_PLBU_OUT_OF_MEM | \
0135 LIMA_GP_IRQ_FORCE_HANG | \
0136 LIMA_GP_IRQ_WRITE_BOUND_ERR | \
0137 LIMA_GP_IRQ_SYNC_ERROR | \
0138 LIMA_GP_IRQ_AXI_BUS_ERROR | \
0139 LIMA_GP_IRQ_VS_INVALID_CMD | \
0140 LIMA_GP_IRQ_PLB_INVALID_CMD | \
0141 LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW | \
0142 LIMA_GP_IRQ_SEMAPHORE_OVERFLOW | \
0143 LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS)
0144
0145 #define LIMA_GP_IRQ_MASK_USED \
0146 ( \
0147 LIMA_GP_IRQ_VS_END_CMD_LST | \
0148 LIMA_GP_IRQ_PLBU_END_CMD_LST | \
0149 LIMA_GP_IRQ_MASK_ERROR)
0150
0151
0152 #define LIMA_PP_FRAME 0x0000
0153 #define LIMA_PP_RSW 0x0004
0154 #define LIMA_PP_STACK 0x0030
0155 #define LIMA_PP_STACK_SIZE 0x0034
0156 #define LIMA_PP_ORIGIN_OFFSET_X 0x0040
0157 #define LIMA_PP_WB(i) (0x0100 * (i + 1))
0158 #define LIMA_PP_WB_SOURCE_SELECT 0x0000
0159 #define LIMA_PP_WB_SOURCE_ADDR 0x0004
0160
0161 #define LIMA_PP_VERSION 0x1000
0162 #define LIMA_PP_CURRENT_REND_LIST_ADDR 0x1004
0163 #define LIMA_PP_STATUS 0x1008
0164 #define LIMA_PP_STATUS_RENDERING_ACTIVE BIT(0)
0165 #define LIMA_PP_STATUS_BUS_STOPPED BIT(4)
0166 #define LIMA_PP_CTRL 0x100c
0167 #define LIMA_PP_CTRL_STOP_BUS BIT(0)
0168 #define LIMA_PP_CTRL_FLUSH_CACHES BIT(3)
0169 #define LIMA_PP_CTRL_FORCE_RESET BIT(5)
0170 #define LIMA_PP_CTRL_START_RENDERING BIT(6)
0171 #define LIMA_PP_CTRL_SOFT_RESET BIT(7)
0172 #define LIMA_PP_INT_RAWSTAT 0x1020
0173 #define LIMA_PP_INT_CLEAR 0x1024
0174 #define LIMA_PP_INT_MASK 0x1028
0175 #define LIMA_PP_INT_STATUS 0x102c
0176 #define LIMA_PP_IRQ_END_OF_FRAME BIT(0)
0177 #define LIMA_PP_IRQ_END_OF_TILE BIT(1)
0178 #define LIMA_PP_IRQ_HANG BIT(2)
0179 #define LIMA_PP_IRQ_FORCE_HANG BIT(3)
0180 #define LIMA_PP_IRQ_BUS_ERROR BIT(4)
0181 #define LIMA_PP_IRQ_BUS_STOP BIT(5)
0182 #define LIMA_PP_IRQ_CNT_0_LIMIT BIT(6)
0183 #define LIMA_PP_IRQ_CNT_1_LIMIT BIT(7)
0184 #define LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR BIT(8)
0185 #define LIMA_PP_IRQ_INVALID_PLIST_COMMAND BIT(9)
0186 #define LIMA_PP_IRQ_CALL_STACK_UNDERFLOW BIT(10)
0187 #define LIMA_PP_IRQ_CALL_STACK_OVERFLOW BIT(11)
0188 #define LIMA_PP_IRQ_RESET_COMPLETED BIT(12)
0189 #define LIMA_PP_WRITE_BOUNDARY_LOW 0x1044
0190 #define LIMA_PP_BUS_ERROR_STATUS 0x1050
0191 #define LIMA_PP_PERF_CNT_0_ENABLE 0x1080
0192 #define LIMA_PP_PERF_CNT_0_SRC 0x1084
0193 #define LIMA_PP_PERF_CNT_0_LIMIT 0x1088
0194 #define LIMA_PP_PERF_CNT_0_VALUE 0x108c
0195 #define LIMA_PP_PERF_CNT_1_ENABLE 0x10a0
0196 #define LIMA_PP_PERF_CNT_1_SRC 0x10a4
0197 #define LIMA_PP_PERF_CNT_1_LIMIT 0x10a8
0198 #define LIMA_PP_PERF_CNT_1_VALUE 0x10ac
0199 #define LIMA_PP_PERFMON_CONTR 0x10b0
0200 #define LIMA_PP_PERFMON_BASE 0x10b4
0201
0202 #define LIMA_PP_IRQ_MASK_ALL \
0203 ( \
0204 LIMA_PP_IRQ_END_OF_FRAME | \
0205 LIMA_PP_IRQ_END_OF_TILE | \
0206 LIMA_PP_IRQ_HANG | \
0207 LIMA_PP_IRQ_FORCE_HANG | \
0208 LIMA_PP_IRQ_BUS_ERROR | \
0209 LIMA_PP_IRQ_BUS_STOP | \
0210 LIMA_PP_IRQ_CNT_0_LIMIT | \
0211 LIMA_PP_IRQ_CNT_1_LIMIT | \
0212 LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR | \
0213 LIMA_PP_IRQ_INVALID_PLIST_COMMAND | \
0214 LIMA_PP_IRQ_CALL_STACK_UNDERFLOW | \
0215 LIMA_PP_IRQ_CALL_STACK_OVERFLOW | \
0216 LIMA_PP_IRQ_RESET_COMPLETED)
0217
0218 #define LIMA_PP_IRQ_MASK_ERROR \
0219 ( \
0220 LIMA_PP_IRQ_FORCE_HANG | \
0221 LIMA_PP_IRQ_BUS_ERROR | \
0222 LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR | \
0223 LIMA_PP_IRQ_INVALID_PLIST_COMMAND | \
0224 LIMA_PP_IRQ_CALL_STACK_UNDERFLOW | \
0225 LIMA_PP_IRQ_CALL_STACK_OVERFLOW)
0226
0227 #define LIMA_PP_IRQ_MASK_USED \
0228 ( \
0229 LIMA_PP_IRQ_END_OF_FRAME | \
0230 LIMA_PP_IRQ_MASK_ERROR)
0231
0232
0233 #define LIMA_MMU_DTE_ADDR 0x0000
0234 #define LIMA_MMU_STATUS 0x0004
0235 #define LIMA_MMU_STATUS_PAGING_ENABLED BIT(0)
0236 #define LIMA_MMU_STATUS_PAGE_FAULT_ACTIVE BIT(1)
0237 #define LIMA_MMU_STATUS_STALL_ACTIVE BIT(2)
0238 #define LIMA_MMU_STATUS_IDLE BIT(3)
0239 #define LIMA_MMU_STATUS_REPLAY_BUFFER_EMPTY BIT(4)
0240 #define LIMA_MMU_STATUS_PAGE_FAULT_IS_WRITE BIT(5)
0241 #define LIMA_MMU_STATUS_BUS_ID(x) ((x >> 6) & 0x1F)
0242 #define LIMA_MMU_STATUS_STALL_NOT_ACTIVE BIT(31)
0243 #define LIMA_MMU_COMMAND 0x0008
0244 #define LIMA_MMU_COMMAND_ENABLE_PAGING 0x00
0245 #define LIMA_MMU_COMMAND_DISABLE_PAGING 0x01
0246 #define LIMA_MMU_COMMAND_ENABLE_STALL 0x02
0247 #define LIMA_MMU_COMMAND_DISABLE_STALL 0x03
0248 #define LIMA_MMU_COMMAND_ZAP_CACHE 0x04
0249 #define LIMA_MMU_COMMAND_PAGE_FAULT_DONE 0x05
0250 #define LIMA_MMU_COMMAND_HARD_RESET 0x06
0251 #define LIMA_MMU_PAGE_FAULT_ADDR 0x000C
0252 #define LIMA_MMU_ZAP_ONE_LINE 0x0010
0253 #define LIMA_MMU_INT_RAWSTAT 0x0014
0254 #define LIMA_MMU_INT_CLEAR 0x0018
0255 #define LIMA_MMU_INT_MASK 0x001C
0256 #define LIMA_MMU_INT_PAGE_FAULT BIT(0)
0257 #define LIMA_MMU_INT_READ_BUS_ERROR BIT(1)
0258 #define LIMA_MMU_INT_STATUS 0x0020
0259
0260 #define LIMA_VM_FLAG_PRESENT BIT(0)
0261 #define LIMA_VM_FLAG_READ_PERMISSION BIT(1)
0262 #define LIMA_VM_FLAG_WRITE_PERMISSION BIT(2)
0263 #define LIMA_VM_FLAG_OVERRIDE_CACHE BIT(3)
0264 #define LIMA_VM_FLAG_WRITE_CACHEABLE BIT(4)
0265 #define LIMA_VM_FLAG_WRITE_ALLOCATE BIT(5)
0266 #define LIMA_VM_FLAG_WRITE_BUFFERABLE BIT(6)
0267 #define LIMA_VM_FLAG_READ_CACHEABLE BIT(7)
0268 #define LIMA_VM_FLAG_READ_ALLOCATE BIT(8)
0269 #define LIMA_VM_FLAG_MASK 0x1FF
0270
0271 #define LIMA_VM_FLAGS_CACHE ( \
0272 LIMA_VM_FLAG_PRESENT | \
0273 LIMA_VM_FLAG_READ_PERMISSION | \
0274 LIMA_VM_FLAG_WRITE_PERMISSION | \
0275 LIMA_VM_FLAG_OVERRIDE_CACHE | \
0276 LIMA_VM_FLAG_WRITE_CACHEABLE | \
0277 LIMA_VM_FLAG_WRITE_BUFFERABLE | \
0278 LIMA_VM_FLAG_READ_CACHEABLE | \
0279 LIMA_VM_FLAG_READ_ALLOCATE)
0280
0281 #define LIMA_VM_FLAGS_UNCACHE ( \
0282 LIMA_VM_FLAG_PRESENT | \
0283 LIMA_VM_FLAG_READ_PERMISSION | \
0284 LIMA_VM_FLAG_WRITE_PERMISSION)
0285
0286
0287 #define LIMA_DLBU_MASTER_TLLIST_PHYS_ADDR 0x0000
0288 #define LIMA_DLBU_MASTER_TLLIST_VADDR 0x0004
0289 #define LIMA_DLBU_TLLIST_VBASEADDR 0x0008
0290 #define LIMA_DLBU_FB_DIM 0x000C
0291 #define LIMA_DLBU_TLLIST_CONF 0x0010
0292 #define LIMA_DLBU_START_TILE_POS 0x0014
0293 #define LIMA_DLBU_PP_ENABLE_MASK 0x0018
0294
0295
0296 #define LIMA_BCAST_BROADCAST_MASK 0x0
0297 #define LIMA_BCAST_INTERRUPT_MASK 0x4
0298
0299 #endif