Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0 */
0002 /* Copyright 2010-2017 ARM Limited. All rights reserved.
0003  * Copyright 2017-2019 Qiang Yu <yuq825@gmail.com>
0004  */
0005 
0006 #ifndef __LIMA_REGS_H__
0007 #define __LIMA_REGS_H__
0008 
0009 /* This file's register definition is collected from the
0010  * official ARM Mali Utgard GPU kernel driver source code
0011  */
0012 
0013 /* PMU regs */
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  * On Mali450 each block automatically starts up its corresponding L2
0022  * and the PPs are not fully independent controllable.
0023  * Instead PP0, PP1-3 and PP4-7 can be turned on or off.
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 /* L2 cache regs */
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 /* GP regs */
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 /* PP regs */
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 /* MMU regs */
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 /* DLBU regs */
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 /* BCAST regs */
0296 #define LIMA_BCAST_BROADCAST_MASK    0x0
0297 #define LIMA_BCAST_INTERRUPT_MASK    0x4
0298 
0299 #endif