1a1d2a633SQiang Yu /* SPDX-License-Identifier: GPL-2.0 */ 2a1d2a633SQiang Yu /* Copyright 2010-2017 ARM Limited. All rights reserved. 3a1d2a633SQiang Yu * Copyright 2017-2019 Qiang Yu <yuq825@gmail.com> 4a1d2a633SQiang Yu */ 5a1d2a633SQiang Yu 6a1d2a633SQiang Yu #ifndef __LIMA_REGS_H__ 7a1d2a633SQiang Yu #define __LIMA_REGS_H__ 8a1d2a633SQiang Yu 9a1d2a633SQiang Yu /* This file's register definition is collected from the 10a1d2a633SQiang Yu * official ARM Mali Utgard GPU kernel driver source code 11a1d2a633SQiang Yu */ 12a1d2a633SQiang Yu 13a1d2a633SQiang Yu /* PMU regs */ 14a1d2a633SQiang Yu #define LIMA_PMU_POWER_UP 0x00 15a1d2a633SQiang Yu #define LIMA_PMU_POWER_DOWN 0x04 16a1d2a633SQiang Yu #define LIMA_PMU_POWER_GP0_MASK BIT(0) 17a1d2a633SQiang Yu #define LIMA_PMU_POWER_L2_MASK BIT(1) 18a1d2a633SQiang Yu #define LIMA_PMU_POWER_PP_MASK(i) BIT(2 + i) 19a1d2a633SQiang Yu 20a1d2a633SQiang Yu /* 21a1d2a633SQiang Yu * On Mali450 each block automatically starts up its corresponding L2 22a1d2a633SQiang Yu * and the PPs are not fully independent controllable. 23a1d2a633SQiang Yu * Instead PP0, PP1-3 and PP4-7 can be turned on or off. 24a1d2a633SQiang Yu */ 25a1d2a633SQiang Yu #define LIMA450_PMU_POWER_PP0_MASK BIT(1) 26a1d2a633SQiang Yu #define LIMA450_PMU_POWER_PP13_MASK BIT(2) 27a1d2a633SQiang Yu #define LIMA450_PMU_POWER_PP47_MASK BIT(3) 28a1d2a633SQiang Yu 29a1d2a633SQiang Yu #define LIMA_PMU_STATUS 0x08 30a1d2a633SQiang Yu #define LIMA_PMU_INT_MASK 0x0C 31a1d2a633SQiang Yu #define LIMA_PMU_INT_RAWSTAT 0x10 32a1d2a633SQiang Yu #define LIMA_PMU_INT_CLEAR 0x18 33a1d2a633SQiang Yu #define LIMA_PMU_INT_CMD_MASK BIT(0) 34a1d2a633SQiang Yu #define LIMA_PMU_SW_DELAY 0x1C 35a1d2a633SQiang Yu 36a1d2a633SQiang Yu /* L2 cache regs */ 37a1d2a633SQiang Yu #define LIMA_L2_CACHE_SIZE 0x0004 38a1d2a633SQiang Yu #define LIMA_L2_CACHE_STATUS 0x0008 39a1d2a633SQiang Yu #define LIMA_L2_CACHE_STATUS_COMMAND_BUSY BIT(0) 40a1d2a633SQiang Yu #define LIMA_L2_CACHE_STATUS_DATA_BUSY BIT(1) 41a1d2a633SQiang Yu #define LIMA_L2_CACHE_COMMAND 0x0010 42a1d2a633SQiang Yu #define LIMA_L2_CACHE_COMMAND_CLEAR_ALL BIT(0) 43a1d2a633SQiang Yu #define LIMA_L2_CACHE_CLEAR_PAGE 0x0014 44a1d2a633SQiang Yu #define LIMA_L2_CACHE_MAX_READS 0x0018 45a1d2a633SQiang Yu #define LIMA_L2_CACHE_ENABLE 0x001C 46a1d2a633SQiang Yu #define LIMA_L2_CACHE_ENABLE_ACCESS BIT(0) 47a1d2a633SQiang Yu #define LIMA_L2_CACHE_ENABLE_READ_ALLOCATE BIT(1) 48a1d2a633SQiang Yu #define LIMA_L2_CACHE_PERFCNT_SRC0 0x0020 49a1d2a633SQiang Yu #define LIMA_L2_CACHE_PERFCNT_VAL0 0x0024 50a1d2a633SQiang Yu #define LIMA_L2_CACHE_PERFCNT_SRC1 0x0028 51a1d2a633SQiang Yu #define LIMA_L2_CACHE_ERFCNT_VAL1 0x002C 52a1d2a633SQiang Yu 53a1d2a633SQiang Yu /* GP regs */ 54a1d2a633SQiang Yu #define LIMA_GP_VSCL_START_ADDR 0x00 55a1d2a633SQiang Yu #define LIMA_GP_VSCL_END_ADDR 0x04 56a1d2a633SQiang Yu #define LIMA_GP_PLBUCL_START_ADDR 0x08 57a1d2a633SQiang Yu #define LIMA_GP_PLBUCL_END_ADDR 0x0c 58a1d2a633SQiang Yu #define LIMA_GP_PLBU_ALLOC_START_ADDR 0x10 59a1d2a633SQiang Yu #define LIMA_GP_PLBU_ALLOC_END_ADDR 0x14 60a1d2a633SQiang Yu #define LIMA_GP_CMD 0x20 61a1d2a633SQiang Yu #define LIMA_GP_CMD_START_VS BIT(0) 62a1d2a633SQiang Yu #define LIMA_GP_CMD_START_PLBU BIT(1) 63a1d2a633SQiang Yu #define LIMA_GP_CMD_UPDATE_PLBU_ALLOC BIT(4) 64a1d2a633SQiang Yu #define LIMA_GP_CMD_RESET BIT(5) 65a1d2a633SQiang Yu #define LIMA_GP_CMD_FORCE_HANG BIT(6) 66a1d2a633SQiang Yu #define LIMA_GP_CMD_STOP_BUS BIT(9) 67a1d2a633SQiang Yu #define LIMA_GP_CMD_SOFT_RESET BIT(10) 68a1d2a633SQiang Yu #define LIMA_GP_INT_RAWSTAT 0x24 69a1d2a633SQiang Yu #define LIMA_GP_INT_CLEAR 0x28 70a1d2a633SQiang Yu #define LIMA_GP_INT_MASK 0x2C 71a1d2a633SQiang Yu #define LIMA_GP_INT_STAT 0x30 72a1d2a633SQiang Yu #define LIMA_GP_IRQ_VS_END_CMD_LST BIT(0) 73a1d2a633SQiang Yu #define LIMA_GP_IRQ_PLBU_END_CMD_LST BIT(1) 74a1d2a633SQiang Yu #define LIMA_GP_IRQ_PLBU_OUT_OF_MEM BIT(2) 75a1d2a633SQiang Yu #define LIMA_GP_IRQ_VS_SEM_IRQ BIT(3) 76a1d2a633SQiang Yu #define LIMA_GP_IRQ_PLBU_SEM_IRQ BIT(4) 77a1d2a633SQiang Yu #define LIMA_GP_IRQ_HANG BIT(5) 78a1d2a633SQiang Yu #define LIMA_GP_IRQ_FORCE_HANG BIT(6) 79a1d2a633SQiang Yu #define LIMA_GP_IRQ_PERF_CNT_0_LIMIT BIT(7) 80a1d2a633SQiang Yu #define LIMA_GP_IRQ_PERF_CNT_1_LIMIT BIT(8) 81a1d2a633SQiang Yu #define LIMA_GP_IRQ_WRITE_BOUND_ERR BIT(9) 82a1d2a633SQiang Yu #define LIMA_GP_IRQ_SYNC_ERROR BIT(10) 83a1d2a633SQiang Yu #define LIMA_GP_IRQ_AXI_BUS_ERROR BIT(11) 84a1d2a633SQiang Yu #define LIMA_GP_IRQ_AXI_BUS_STOPPED BIT(12) 85a1d2a633SQiang Yu #define LIMA_GP_IRQ_VS_INVALID_CMD BIT(13) 86a1d2a633SQiang Yu #define LIMA_GP_IRQ_PLB_INVALID_CMD BIT(14) 87a1d2a633SQiang Yu #define LIMA_GP_IRQ_RESET_COMPLETED BIT(19) 88a1d2a633SQiang Yu #define LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW BIT(20) 89a1d2a633SQiang Yu #define LIMA_GP_IRQ_SEMAPHORE_OVERFLOW BIT(21) 90a1d2a633SQiang Yu #define LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS BIT(22) 91a1d2a633SQiang Yu #define LIMA_GP_WRITE_BOUND_LOW 0x34 92a1d2a633SQiang Yu #define LIMA_GP_PERF_CNT_0_ENABLE 0x3C 93a1d2a633SQiang Yu #define LIMA_GP_PERF_CNT_1_ENABLE 0x40 94a1d2a633SQiang Yu #define LIMA_GP_PERF_CNT_0_SRC 0x44 95a1d2a633SQiang Yu #define LIMA_GP_PERF_CNT_1_SRC 0x48 96a1d2a633SQiang Yu #define LIMA_GP_PERF_CNT_0_VALUE 0x4C 97a1d2a633SQiang Yu #define LIMA_GP_PERF_CNT_1_VALUE 0x50 98a1d2a633SQiang Yu #define LIMA_GP_PERF_CNT_0_LIMIT 0x54 99a1d2a633SQiang Yu #define LIMA_GP_STATUS 0x68 100a1d2a633SQiang Yu #define LIMA_GP_STATUS_VS_ACTIVE BIT(1) 101a1d2a633SQiang Yu #define LIMA_GP_STATUS_BUS_STOPPED BIT(2) 102a1d2a633SQiang Yu #define LIMA_GP_STATUS_PLBU_ACTIVE BIT(3) 103a1d2a633SQiang Yu #define LIMA_GP_STATUS_BUS_ERROR BIT(6) 104a1d2a633SQiang Yu #define LIMA_GP_STATUS_WRITE_BOUND_ERR BIT(8) 105a1d2a633SQiang Yu #define LIMA_GP_VERSION 0x6C 106a1d2a633SQiang Yu #define LIMA_GP_VSCL_START_ADDR_READ 0x80 107a1d2a633SQiang Yu #define LIMA_GP_PLBCL_START_ADDR_READ 0x84 108a1d2a633SQiang Yu #define LIMA_GP_CONTR_AXI_BUS_ERROR_STAT 0x94 109a1d2a633SQiang Yu 110a1d2a633SQiang Yu #define LIMA_GP_IRQ_MASK_ALL \ 111a1d2a633SQiang Yu ( \ 112a1d2a633SQiang Yu LIMA_GP_IRQ_VS_END_CMD_LST | \ 113a1d2a633SQiang Yu LIMA_GP_IRQ_PLBU_END_CMD_LST | \ 114a1d2a633SQiang Yu LIMA_GP_IRQ_PLBU_OUT_OF_MEM | \ 115a1d2a633SQiang Yu LIMA_GP_IRQ_VS_SEM_IRQ | \ 116a1d2a633SQiang Yu LIMA_GP_IRQ_PLBU_SEM_IRQ | \ 117a1d2a633SQiang Yu LIMA_GP_IRQ_HANG | \ 118a1d2a633SQiang Yu LIMA_GP_IRQ_FORCE_HANG | \ 119a1d2a633SQiang Yu LIMA_GP_IRQ_PERF_CNT_0_LIMIT | \ 120a1d2a633SQiang Yu LIMA_GP_IRQ_PERF_CNT_1_LIMIT | \ 121a1d2a633SQiang Yu LIMA_GP_IRQ_WRITE_BOUND_ERR | \ 122a1d2a633SQiang Yu LIMA_GP_IRQ_SYNC_ERROR | \ 123a1d2a633SQiang Yu LIMA_GP_IRQ_AXI_BUS_ERROR | \ 124a1d2a633SQiang Yu LIMA_GP_IRQ_AXI_BUS_STOPPED | \ 125a1d2a633SQiang Yu LIMA_GP_IRQ_VS_INVALID_CMD | \ 126a1d2a633SQiang Yu LIMA_GP_IRQ_PLB_INVALID_CMD | \ 127a1d2a633SQiang Yu LIMA_GP_IRQ_RESET_COMPLETED | \ 128a1d2a633SQiang Yu LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW | \ 129a1d2a633SQiang Yu LIMA_GP_IRQ_SEMAPHORE_OVERFLOW | \ 130a1d2a633SQiang Yu LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS) 131a1d2a633SQiang Yu 132a1d2a633SQiang Yu #define LIMA_GP_IRQ_MASK_ERROR \ 133a1d2a633SQiang Yu ( \ 134a1d2a633SQiang Yu LIMA_GP_IRQ_PLBU_OUT_OF_MEM | \ 135a1d2a633SQiang Yu LIMA_GP_IRQ_FORCE_HANG | \ 136a1d2a633SQiang Yu LIMA_GP_IRQ_WRITE_BOUND_ERR | \ 137a1d2a633SQiang Yu LIMA_GP_IRQ_SYNC_ERROR | \ 138a1d2a633SQiang Yu LIMA_GP_IRQ_AXI_BUS_ERROR | \ 139a1d2a633SQiang Yu LIMA_GP_IRQ_VS_INVALID_CMD | \ 140a1d2a633SQiang Yu LIMA_GP_IRQ_PLB_INVALID_CMD | \ 141a1d2a633SQiang Yu LIMA_GP_IRQ_SEMAPHORE_UNDERFLOW | \ 142a1d2a633SQiang Yu LIMA_GP_IRQ_SEMAPHORE_OVERFLOW | \ 143a1d2a633SQiang Yu LIMA_GP_IRQ_PTR_ARRAY_OUT_OF_BOUNDS) 144a1d2a633SQiang Yu 145a1d2a633SQiang Yu #define LIMA_GP_IRQ_MASK_USED \ 146a1d2a633SQiang Yu ( \ 147a1d2a633SQiang Yu LIMA_GP_IRQ_VS_END_CMD_LST | \ 148a1d2a633SQiang Yu LIMA_GP_IRQ_PLBU_END_CMD_LST | \ 149a1d2a633SQiang Yu LIMA_GP_IRQ_MASK_ERROR) 150a1d2a633SQiang Yu 151a1d2a633SQiang Yu /* PP regs */ 152a1d2a633SQiang Yu #define LIMA_PP_FRAME 0x0000 153a1d2a633SQiang Yu #define LIMA_PP_RSW 0x0004 154a1d2a633SQiang Yu #define LIMA_PP_STACK 0x0030 155a1d2a633SQiang Yu #define LIMA_PP_STACK_SIZE 0x0034 156a1d2a633SQiang Yu #define LIMA_PP_ORIGIN_OFFSET_X 0x0040 157a1d2a633SQiang Yu #define LIMA_PP_WB(i) (0x0100 * (i + 1)) 158a1d2a633SQiang Yu #define LIMA_PP_WB_SOURCE_SELECT 0x0000 159a1d2a633SQiang Yu #define LIMA_PP_WB_SOURCE_ADDR 0x0004 160a1d2a633SQiang Yu 161a1d2a633SQiang Yu #define LIMA_PP_VERSION 0x1000 162a1d2a633SQiang Yu #define LIMA_PP_CURRENT_REND_LIST_ADDR 0x1004 163a1d2a633SQiang Yu #define LIMA_PP_STATUS 0x1008 164a1d2a633SQiang Yu #define LIMA_PP_STATUS_RENDERING_ACTIVE BIT(0) 165a1d2a633SQiang Yu #define LIMA_PP_STATUS_BUS_STOPPED BIT(4) 166a1d2a633SQiang Yu #define LIMA_PP_CTRL 0x100c 167a1d2a633SQiang Yu #define LIMA_PP_CTRL_STOP_BUS BIT(0) 168a1d2a633SQiang Yu #define LIMA_PP_CTRL_FLUSH_CACHES BIT(3) 169a1d2a633SQiang Yu #define LIMA_PP_CTRL_FORCE_RESET BIT(5) 170a1d2a633SQiang Yu #define LIMA_PP_CTRL_START_RENDERING BIT(6) 171a1d2a633SQiang Yu #define LIMA_PP_CTRL_SOFT_RESET BIT(7) 172a1d2a633SQiang Yu #define LIMA_PP_INT_RAWSTAT 0x1020 173a1d2a633SQiang Yu #define LIMA_PP_INT_CLEAR 0x1024 174a1d2a633SQiang Yu #define LIMA_PP_INT_MASK 0x1028 175a1d2a633SQiang Yu #define LIMA_PP_INT_STATUS 0x102c 176a1d2a633SQiang Yu #define LIMA_PP_IRQ_END_OF_FRAME BIT(0) 177a1d2a633SQiang Yu #define LIMA_PP_IRQ_END_OF_TILE BIT(1) 178a1d2a633SQiang Yu #define LIMA_PP_IRQ_HANG BIT(2) 179a1d2a633SQiang Yu #define LIMA_PP_IRQ_FORCE_HANG BIT(3) 180a1d2a633SQiang Yu #define LIMA_PP_IRQ_BUS_ERROR BIT(4) 181a1d2a633SQiang Yu #define LIMA_PP_IRQ_BUS_STOP BIT(5) 182a1d2a633SQiang Yu #define LIMA_PP_IRQ_CNT_0_LIMIT BIT(6) 183a1d2a633SQiang Yu #define LIMA_PP_IRQ_CNT_1_LIMIT BIT(7) 184a1d2a633SQiang Yu #define LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR BIT(8) 185a1d2a633SQiang Yu #define LIMA_PP_IRQ_INVALID_PLIST_COMMAND BIT(9) 186a1d2a633SQiang Yu #define LIMA_PP_IRQ_CALL_STACK_UNDERFLOW BIT(10) 187a1d2a633SQiang Yu #define LIMA_PP_IRQ_CALL_STACK_OVERFLOW BIT(11) 188a1d2a633SQiang Yu #define LIMA_PP_IRQ_RESET_COMPLETED BIT(12) 189a1d2a633SQiang Yu #define LIMA_PP_WRITE_BOUNDARY_LOW 0x1044 190a1d2a633SQiang Yu #define LIMA_PP_BUS_ERROR_STATUS 0x1050 191a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_0_ENABLE 0x1080 192a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_0_SRC 0x1084 193a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_0_LIMIT 0x1088 194a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_0_VALUE 0x108c 195a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_1_ENABLE 0x10a0 196a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_1_SRC 0x10a4 197a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_1_LIMIT 0x10a8 198a1d2a633SQiang Yu #define LIMA_PP_PERF_CNT_1_VALUE 0x10ac 199a1d2a633SQiang Yu #define LIMA_PP_PERFMON_CONTR 0x10b0 200a1d2a633SQiang Yu #define LIMA_PP_PERFMON_BASE 0x10b4 201a1d2a633SQiang Yu 202a1d2a633SQiang Yu #define LIMA_PP_IRQ_MASK_ALL \ 203a1d2a633SQiang Yu ( \ 204a1d2a633SQiang Yu LIMA_PP_IRQ_END_OF_FRAME | \ 205a1d2a633SQiang Yu LIMA_PP_IRQ_END_OF_TILE | \ 206a1d2a633SQiang Yu LIMA_PP_IRQ_HANG | \ 207a1d2a633SQiang Yu LIMA_PP_IRQ_FORCE_HANG | \ 208a1d2a633SQiang Yu LIMA_PP_IRQ_BUS_ERROR | \ 209a1d2a633SQiang Yu LIMA_PP_IRQ_BUS_STOP | \ 210a1d2a633SQiang Yu LIMA_PP_IRQ_CNT_0_LIMIT | \ 211a1d2a633SQiang Yu LIMA_PP_IRQ_CNT_1_LIMIT | \ 212a1d2a633SQiang Yu LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR | \ 213a1d2a633SQiang Yu LIMA_PP_IRQ_INVALID_PLIST_COMMAND | \ 214a1d2a633SQiang Yu LIMA_PP_IRQ_CALL_STACK_UNDERFLOW | \ 215a1d2a633SQiang Yu LIMA_PP_IRQ_CALL_STACK_OVERFLOW | \ 216a1d2a633SQiang Yu LIMA_PP_IRQ_RESET_COMPLETED) 217a1d2a633SQiang Yu 218a1d2a633SQiang Yu #define LIMA_PP_IRQ_MASK_ERROR \ 219a1d2a633SQiang Yu ( \ 220a1d2a633SQiang Yu LIMA_PP_IRQ_FORCE_HANG | \ 221a1d2a633SQiang Yu LIMA_PP_IRQ_BUS_ERROR | \ 222a1d2a633SQiang Yu LIMA_PP_IRQ_WRITE_BOUNDARY_ERROR | \ 223a1d2a633SQiang Yu LIMA_PP_IRQ_INVALID_PLIST_COMMAND | \ 224a1d2a633SQiang Yu LIMA_PP_IRQ_CALL_STACK_UNDERFLOW | \ 225a1d2a633SQiang Yu LIMA_PP_IRQ_CALL_STACK_OVERFLOW) 226a1d2a633SQiang Yu 227a1d2a633SQiang Yu #define LIMA_PP_IRQ_MASK_USED \ 228a1d2a633SQiang Yu ( \ 229a1d2a633SQiang Yu LIMA_PP_IRQ_END_OF_FRAME | \ 230a1d2a633SQiang Yu LIMA_PP_IRQ_MASK_ERROR) 231a1d2a633SQiang Yu 232a1d2a633SQiang Yu /* MMU regs */ 233a1d2a633SQiang Yu #define LIMA_MMU_DTE_ADDR 0x0000 234a1d2a633SQiang Yu #define LIMA_MMU_STATUS 0x0004 235a1d2a633SQiang Yu #define LIMA_MMU_STATUS_PAGING_ENABLED BIT(0) 236a1d2a633SQiang Yu #define LIMA_MMU_STATUS_PAGE_FAULT_ACTIVE BIT(1) 237a1d2a633SQiang Yu #define LIMA_MMU_STATUS_STALL_ACTIVE BIT(2) 238a1d2a633SQiang Yu #define LIMA_MMU_STATUS_IDLE BIT(3) 239a1d2a633SQiang Yu #define LIMA_MMU_STATUS_REPLAY_BUFFER_EMPTY BIT(4) 240a1d2a633SQiang Yu #define LIMA_MMU_STATUS_PAGE_FAULT_IS_WRITE BIT(5) 241a1d2a633SQiang Yu #define LIMA_MMU_STATUS_BUS_ID(x) ((x >> 6) & 0x1F) 242*500edbbdSQiang Yu #define LIMA_MMU_STATUS_STALL_NOT_ACTIVE BIT(31) 243a1d2a633SQiang Yu #define LIMA_MMU_COMMAND 0x0008 244a1d2a633SQiang Yu #define LIMA_MMU_COMMAND_ENABLE_PAGING 0x00 245a1d2a633SQiang Yu #define LIMA_MMU_COMMAND_DISABLE_PAGING 0x01 246a1d2a633SQiang Yu #define LIMA_MMU_COMMAND_ENABLE_STALL 0x02 247a1d2a633SQiang Yu #define LIMA_MMU_COMMAND_DISABLE_STALL 0x03 248a1d2a633SQiang Yu #define LIMA_MMU_COMMAND_ZAP_CACHE 0x04 249a1d2a633SQiang Yu #define LIMA_MMU_COMMAND_PAGE_FAULT_DONE 0x05 250a1d2a633SQiang Yu #define LIMA_MMU_COMMAND_HARD_RESET 0x06 251a1d2a633SQiang Yu #define LIMA_MMU_PAGE_FAULT_ADDR 0x000C 252a1d2a633SQiang Yu #define LIMA_MMU_ZAP_ONE_LINE 0x0010 253a1d2a633SQiang Yu #define LIMA_MMU_INT_RAWSTAT 0x0014 254a1d2a633SQiang Yu #define LIMA_MMU_INT_CLEAR 0x0018 255a1d2a633SQiang Yu #define LIMA_MMU_INT_MASK 0x001C 256a1d2a633SQiang Yu #define LIMA_MMU_INT_PAGE_FAULT BIT(0) 257a1d2a633SQiang Yu #define LIMA_MMU_INT_READ_BUS_ERROR BIT(1) 258a1d2a633SQiang Yu #define LIMA_MMU_INT_STATUS 0x0020 259a1d2a633SQiang Yu 260a1d2a633SQiang Yu #define LIMA_VM_FLAG_PRESENT BIT(0) 261a1d2a633SQiang Yu #define LIMA_VM_FLAG_READ_PERMISSION BIT(1) 262a1d2a633SQiang Yu #define LIMA_VM_FLAG_WRITE_PERMISSION BIT(2) 263a1d2a633SQiang Yu #define LIMA_VM_FLAG_OVERRIDE_CACHE BIT(3) 264a1d2a633SQiang Yu #define LIMA_VM_FLAG_WRITE_CACHEABLE BIT(4) 265a1d2a633SQiang Yu #define LIMA_VM_FLAG_WRITE_ALLOCATE BIT(5) 266a1d2a633SQiang Yu #define LIMA_VM_FLAG_WRITE_BUFFERABLE BIT(6) 267a1d2a633SQiang Yu #define LIMA_VM_FLAG_READ_CACHEABLE BIT(7) 268a1d2a633SQiang Yu #define LIMA_VM_FLAG_READ_ALLOCATE BIT(8) 269a1d2a633SQiang Yu #define LIMA_VM_FLAG_MASK 0x1FF 270a1d2a633SQiang Yu 271a1d2a633SQiang Yu #define LIMA_VM_FLAGS_CACHE ( \ 272a1d2a633SQiang Yu LIMA_VM_FLAG_PRESENT | \ 273a1d2a633SQiang Yu LIMA_VM_FLAG_READ_PERMISSION | \ 274a1d2a633SQiang Yu LIMA_VM_FLAG_WRITE_PERMISSION | \ 275a1d2a633SQiang Yu LIMA_VM_FLAG_OVERRIDE_CACHE | \ 276a1d2a633SQiang Yu LIMA_VM_FLAG_WRITE_CACHEABLE | \ 277a1d2a633SQiang Yu LIMA_VM_FLAG_WRITE_BUFFERABLE | \ 278a1d2a633SQiang Yu LIMA_VM_FLAG_READ_CACHEABLE | \ 279a1d2a633SQiang Yu LIMA_VM_FLAG_READ_ALLOCATE) 280a1d2a633SQiang Yu 281a1d2a633SQiang Yu #define LIMA_VM_FLAGS_UNCACHE ( \ 282a1d2a633SQiang Yu LIMA_VM_FLAG_PRESENT | \ 283a1d2a633SQiang Yu LIMA_VM_FLAG_READ_PERMISSION | \ 284a1d2a633SQiang Yu LIMA_VM_FLAG_WRITE_PERMISSION) 285a1d2a633SQiang Yu 286a1d2a633SQiang Yu /* DLBU regs */ 287a1d2a633SQiang Yu #define LIMA_DLBU_MASTER_TLLIST_PHYS_ADDR 0x0000 288a1d2a633SQiang Yu #define LIMA_DLBU_MASTER_TLLIST_VADDR 0x0004 289a1d2a633SQiang Yu #define LIMA_DLBU_TLLIST_VBASEADDR 0x0008 290a1d2a633SQiang Yu #define LIMA_DLBU_FB_DIM 0x000C 291a1d2a633SQiang Yu #define LIMA_DLBU_TLLIST_CONF 0x0010 292a1d2a633SQiang Yu #define LIMA_DLBU_START_TILE_POS 0x0014 293a1d2a633SQiang Yu #define LIMA_DLBU_PP_ENABLE_MASK 0x0018 294a1d2a633SQiang Yu 295a1d2a633SQiang Yu /* BCAST regs */ 296a1d2a633SQiang Yu #define LIMA_BCAST_BROADCAST_MASK 0x0 297a1d2a633SQiang Yu #define LIMA_BCAST_INTERRUPT_MASK 0x4 298a1d2a633SQiang Yu 299a1d2a633SQiang Yu #endif 300