1 // SPDX-License-Identifier: GPL-2.0
4 * Copyright 2016-2019 HabanaLabs, Ltd.
9 #include "../include/goya/asic_reg/goya_regs.h"
12 * goya_set_block_as_protected - set the given block as protected
14 * @hdev: pointer to hl_device structure
15 * @block: block base address
18 static void goya_pb_set_block(struct hl_device
*hdev
, u64 base
)
20 u32 pb_addr
= base
- CFG_BASE
+ PROT_BITS_OFFS
;
22 while (pb_addr
& 0xFFF) {
28 static void goya_init_mme_protection_bits(struct hl_device
*hdev
)
33 /* TODO: change to real reg name when Soc Online is updated */
34 u64 mmMME_SBB_POWER_ECO1
= 0xDFF60,
35 mmMME_SBB_POWER_ECO2
= 0xDFF64;
37 goya_pb_set_block(hdev
, mmACC_MS_ECC_MEM_0_BASE
);
38 goya_pb_set_block(hdev
, mmACC_MS_ECC_MEM_1_BASE
);
39 goya_pb_set_block(hdev
, mmACC_MS_ECC_MEM_2_BASE
);
40 goya_pb_set_block(hdev
, mmACC_MS_ECC_MEM_3_BASE
);
42 goya_pb_set_block(hdev
, mmSBA_ECC_MEM_BASE
);
43 goya_pb_set_block(hdev
, mmSBB_ECC_MEM_BASE
);
45 goya_pb_set_block(hdev
, mmMME1_RTR_BASE
);
46 goya_pb_set_block(hdev
, mmMME1_RD_REGULATOR_BASE
);
47 goya_pb_set_block(hdev
, mmMME1_WR_REGULATOR_BASE
);
48 goya_pb_set_block(hdev
, mmMME2_RTR_BASE
);
49 goya_pb_set_block(hdev
, mmMME2_RD_REGULATOR_BASE
);
50 goya_pb_set_block(hdev
, mmMME2_WR_REGULATOR_BASE
);
51 goya_pb_set_block(hdev
, mmMME3_RTR_BASE
);
52 goya_pb_set_block(hdev
, mmMME3_RD_REGULATOR_BASE
);
53 goya_pb_set_block(hdev
, mmMME3_WR_REGULATOR_BASE
);
55 goya_pb_set_block(hdev
, mmMME4_RTR_BASE
);
56 goya_pb_set_block(hdev
, mmMME4_RD_REGULATOR_BASE
);
57 goya_pb_set_block(hdev
, mmMME4_WR_REGULATOR_BASE
);
59 goya_pb_set_block(hdev
, mmMME5_RTR_BASE
);
60 goya_pb_set_block(hdev
, mmMME5_RD_REGULATOR_BASE
);
61 goya_pb_set_block(hdev
, mmMME5_WR_REGULATOR_BASE
);
63 goya_pb_set_block(hdev
, mmMME6_RTR_BASE
);
64 goya_pb_set_block(hdev
, mmMME6_RD_REGULATOR_BASE
);
65 goya_pb_set_block(hdev
, mmMME6_WR_REGULATOR_BASE
);
67 pb_addr
= (mmMME_DUMMY
& ~0xFFF) + PROT_BITS_OFFS
;
68 word_offset
= ((mmMME_DUMMY
& PROT_BITS_OFFS
) >> 7) << 2;
69 mask
= 1 << ((mmMME_DUMMY
& 0x7F) >> 2);
70 mask
|= 1 << ((mmMME_RESET
& 0x7F) >> 2);
71 mask
|= 1 << ((mmMME_STALL
& 0x7F) >> 2);
72 mask
|= 1 << ((mmMME_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
73 mask
|= 1 << ((mmMME_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
74 mask
|= 1 << ((mmMME_DBGMEM_ADD
& 0x7F) >> 2);
75 mask
|= 1 << ((mmMME_DBGMEM_DATA_WR
& 0x7F) >> 2);
76 mask
|= 1 << ((mmMME_DBGMEM_DATA_RD
& 0x7F) >> 2);
77 mask
|= 1 << ((mmMME_DBGMEM_CTRL
& 0x7F) >> 2);
78 mask
|= 1 << ((mmMME_DBGMEM_RC
& 0x7F) >> 2);
79 mask
|= 1 << ((mmMME_LOG_SHADOW
& 0x7F) >> 2);
81 WREG32(pb_addr
+ word_offset
, ~mask
);
83 pb_addr
= (mmMME_STORE_MAX_CREDIT
& ~0xFFF) + PROT_BITS_OFFS
;
84 word_offset
= ((mmMME_STORE_MAX_CREDIT
& PROT_BITS_OFFS
) >> 7) << 2;
85 mask
= 1 << ((mmMME_STORE_MAX_CREDIT
& 0x7F) >> 2);
86 mask
|= 1 << ((mmMME_AGU
& 0x7F) >> 2);
87 mask
|= 1 << ((mmMME_SBA
& 0x7F) >> 2);
88 mask
|= 1 << ((mmMME_SBB
& 0x7F) >> 2);
89 mask
|= 1 << ((mmMME_SBC
& 0x7F) >> 2);
90 mask
|= 1 << ((mmMME_WBC
& 0x7F) >> 2);
91 mask
|= 1 << ((mmMME_SBA_CONTROL_DATA
& 0x7F) >> 2);
92 mask
|= 1 << ((mmMME_SBB_CONTROL_DATA
& 0x7F) >> 2);
93 mask
|= 1 << ((mmMME_SBC_CONTROL_DATA
& 0x7F) >> 2);
94 mask
|= 1 << ((mmMME_WBC_CONTROL_DATA
& 0x7F) >> 2);
95 mask
|= 1 << ((mmMME_TE
& 0x7F) >> 2);
96 mask
|= 1 << ((mmMME_TE2DEC
& 0x7F) >> 2);
97 mask
|= 1 << ((mmMME_REI_STATUS
& 0x7F) >> 2);
98 mask
|= 1 << ((mmMME_REI_MASK
& 0x7F) >> 2);
99 mask
|= 1 << ((mmMME_SEI_STATUS
& 0x7F) >> 2);
100 mask
|= 1 << ((mmMME_SEI_MASK
& 0x7F) >> 2);
101 mask
|= 1 << ((mmMME_SPI_STATUS
& 0x7F) >> 2);
102 mask
|= 1 << ((mmMME_SPI_MASK
& 0x7F) >> 2);
104 WREG32(pb_addr
+ word_offset
, ~mask
);
106 pb_addr
= (mmMME_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
107 word_offset
= ((mmMME_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
108 mask
= 1 << ((mmMME_QM_GLBL_CFG0
& 0x7F) >> 2);
109 mask
|= 1 << ((mmMME_QM_GLBL_CFG1
& 0x7F) >> 2);
110 mask
|= 1 << ((mmMME_QM_GLBL_PROT
& 0x7F) >> 2);
111 mask
|= 1 << ((mmMME_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
112 mask
|= 1 << ((mmMME_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
113 mask
|= 1 << ((mmMME_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
114 mask
|= 1 << ((mmMME_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
115 mask
|= 1 << ((mmMME_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
116 mask
|= 1 << ((mmMME_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
117 mask
|= 1 << ((mmMME_QM_GLBL_STS0
& 0x7F) >> 2);
118 mask
|= 1 << ((mmMME_QM_GLBL_STS1
& 0x7F) >> 2);
119 mask
|= 1 << ((mmMME_QM_PQ_BASE_LO
& 0x7F) >> 2);
120 mask
|= 1 << ((mmMME_QM_PQ_BASE_HI
& 0x7F) >> 2);
121 mask
|= 1 << ((mmMME_QM_PQ_SIZE
& 0x7F) >> 2);
122 mask
|= 1 << ((mmMME_QM_PQ_PI
& 0x7F) >> 2);
123 mask
|= 1 << ((mmMME_QM_PQ_CI
& 0x7F) >> 2);
124 mask
|= 1 << ((mmMME_QM_PQ_CFG0
& 0x7F) >> 2);
125 mask
|= 1 << ((mmMME_QM_PQ_CFG1
& 0x7F) >> 2);
126 mask
|= 1 << ((mmMME_QM_PQ_ARUSER
& 0x7F) >> 2);
128 WREG32(pb_addr
+ word_offset
, ~mask
);
130 pb_addr
= (mmMME_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
131 word_offset
= ((mmMME_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
132 mask
= 1 << ((mmMME_QM_PQ_PUSH0
& 0x7F) >> 2);
133 mask
|= 1 << ((mmMME_QM_PQ_PUSH1
& 0x7F) >> 2);
134 mask
|= 1 << ((mmMME_QM_PQ_PUSH2
& 0x7F) >> 2);
135 mask
|= 1 << ((mmMME_QM_PQ_PUSH3
& 0x7F) >> 2);
136 mask
|= 1 << ((mmMME_QM_PQ_STS0
& 0x7F) >> 2);
137 mask
|= 1 << ((mmMME_QM_PQ_STS1
& 0x7F) >> 2);
138 mask
|= 1 << ((mmMME_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
139 mask
|= 1 << ((mmMME_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
140 mask
|= 1 << ((mmMME_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
141 mask
|= 1 << ((mmMME_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
142 mask
|= 1 << ((mmMME_QM_CQ_CFG0
& 0x7F) >> 2);
143 mask
|= 1 << ((mmMME_QM_CQ_CFG1
& 0x7F) >> 2);
144 mask
|= 1 << ((mmMME_QM_CQ_ARUSER
& 0x7F) >> 2);
145 mask
|= 1 << ((mmMME_QM_CQ_PTR_LO
& 0x7F) >> 2);
146 mask
|= 1 << ((mmMME_QM_CQ_PTR_HI
& 0x7F) >> 2);
147 mask
|= 1 << ((mmMME_QM_CQ_TSIZE
& 0x7F) >> 2);
148 mask
|= 1 << ((mmMME_QM_CQ_CTL
& 0x7F) >> 2);
149 mask
|= 1 << ((mmMME_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
150 mask
|= 1 << ((mmMME_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
151 mask
|= 1 << ((mmMME_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
152 mask
|= 1 << ((mmMME_QM_CQ_CTL_STS
& 0x7F) >> 2);
153 mask
|= 1 << ((mmMME_QM_CQ_STS0
& 0x7F) >> 2);
154 mask
|= 1 << ((mmMME_QM_CQ_STS1
& 0x7F) >> 2);
155 mask
|= 1 << ((mmMME_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
156 mask
|= 1 << ((mmMME_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
157 mask
|= 1 << ((mmMME_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
158 mask
|= 1 << ((mmMME_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
160 WREG32(pb_addr
+ word_offset
, ~mask
);
162 pb_addr
= (mmMME_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
163 word_offset
= ((mmMME_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
164 mask
= 1 << ((mmMME_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
165 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
166 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
167 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
168 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
169 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
170 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
171 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
172 mask
|= 1 << ((mmMME_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
173 mask
|= 1 << ((mmMME_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
174 mask
|= 1 << ((mmMME_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
175 mask
|= 1 << ((mmMME_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
176 mask
|= 1 << ((mmMME_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
177 mask
|= 1 << ((mmMME_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
178 mask
|= 1 << ((mmMME_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
180 WREG32(pb_addr
+ word_offset
, ~mask
);
182 pb_addr
= (mmMME_QM_CP_STS
& ~0xFFF) + PROT_BITS_OFFS
;
183 word_offset
= ((mmMME_QM_CP_STS
& PROT_BITS_OFFS
) >> 7) << 2;
184 mask
= 1 << ((mmMME_QM_CP_STS
& 0x7F) >> 2);
185 mask
|= 1 << ((mmMME_QM_CP_CURRENT_INST_LO
& 0x7F) >> 2);
186 mask
|= 1 << ((mmMME_QM_CP_CURRENT_INST_HI
& 0x7F) >> 2);
187 mask
|= 1 << ((mmMME_QM_CP_BARRIER_CFG
& 0x7F) >> 2);
188 mask
|= 1 << ((mmMME_QM_CP_DBG_0
& 0x7F) >> 2);
189 mask
|= 1 << ((mmMME_QM_PQ_BUF_ADDR
& 0x7F) >> 2);
190 mask
|= 1 << ((mmMME_QM_PQ_BUF_RDATA
& 0x7F) >> 2);
191 mask
|= 1 << ((mmMME_QM_CQ_BUF_ADDR
& 0x7F) >> 2);
192 mask
|= 1 << ((mmMME_QM_CQ_BUF_RDATA
& 0x7F) >> 2);
194 WREG32(pb_addr
+ word_offset
, ~mask
);
196 pb_addr
= (mmMME_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
197 word_offset
= ((mmMME_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
198 mask
= 1 << ((mmMME_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
199 mask
|= 1 << ((mmMME_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
200 mask
|= 1 << ((mmMME_CMDQ_GLBL_PROT
& 0x7F) >> 2);
201 mask
|= 1 << ((mmMME_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
202 mask
|= 1 << ((mmMME_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
203 mask
|= 1 << ((mmMME_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
204 mask
|= 1 << ((mmMME_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
205 mask
|= 1 << ((mmMME_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
206 mask
|= 1 << ((mmMME_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
207 mask
|= 1 << ((mmMME_CMDQ_GLBL_STS0
& 0x7F) >> 2);
208 mask
|= 1 << ((mmMME_CMDQ_GLBL_STS1
& 0x7F) >> 2);
210 WREG32(pb_addr
+ word_offset
, ~mask
);
212 pb_addr
= (mmMME_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
213 word_offset
= ((mmMME_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
214 mask
= 1 << ((mmMME_CMDQ_CQ_CFG0
& 0x7F) >> 2);
215 mask
|= 1 << ((mmMME_CMDQ_CQ_CFG1
& 0x7F) >> 2);
216 mask
|= 1 << ((mmMME_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
217 mask
|= 1 << ((mmMME_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
218 mask
|= 1 << ((mmMME_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
219 mask
|= 1 << ((mmMME_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
220 mask
|= 1 << ((mmMME_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
221 mask
|= 1 << ((mmMME_CMDQ_CQ_STS0
& 0x7F) >> 2);
222 mask
|= 1 << ((mmMME_CMDQ_CQ_STS1
& 0x7F) >> 2);
223 mask
|= 1 << ((mmMME_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
224 mask
|= 1 << ((mmMME_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
225 mask
|= 1 << ((mmMME_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
226 mask
|= 1 << ((mmMME_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
228 WREG32(pb_addr
+ word_offset
, ~mask
);
230 pb_addr
= (mmMME_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
231 word_offset
= ((mmMME_CMDQ_CQ_IFIFO_CNT
&
232 PROT_BITS_OFFS
) >> 7) << 2;
233 mask
= 1 << ((mmMME_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
234 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
235 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
236 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
237 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
238 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
239 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
240 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
241 mask
|= 1 << ((mmMME_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
242 mask
|= 1 << ((mmMME_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
243 mask
|= 1 << ((mmMME_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
244 mask
|= 1 << ((mmMME_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
245 mask
|= 1 << ((mmMME_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
246 mask
|= 1 << ((mmMME_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
247 mask
|= 1 << ((mmMME_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
248 mask
|= 1 << ((mmMME_CMDQ_CP_STS
& 0x7F) >> 2);
249 mask
|= 1 << ((mmMME_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
251 WREG32(pb_addr
+ word_offset
, ~mask
);
253 pb_addr
= (mmMME_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
254 word_offset
= ((mmMME_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
256 mask
= 1 << ((mmMME_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
257 mask
|= 1 << ((mmMME_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
258 mask
|= 1 << ((mmMME_CMDQ_CP_DBG_0
& 0x7F) >> 2);
259 mask
|= 1 << ((mmMME_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
260 mask
|= 1 << ((mmMME_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
262 WREG32(pb_addr
+ word_offset
, ~mask
);
264 pb_addr
= (mmMME_SBB_POWER_ECO1
& ~0xFFF) + PROT_BITS_OFFS
;
265 word_offset
= ((mmMME_SBB_POWER_ECO1
& PROT_BITS_OFFS
) >> 7) << 2;
266 mask
= 1 << ((mmMME_SBB_POWER_ECO1
& 0x7F) >> 2);
267 mask
|= 1 << ((mmMME_SBB_POWER_ECO2
& 0x7F) >> 2);
269 WREG32(pb_addr
+ word_offset
, ~mask
);
272 static void goya_init_dma_protection_bits(struct hl_device
*hdev
)
277 goya_pb_set_block(hdev
, mmDMA_NRTR_BASE
);
278 goya_pb_set_block(hdev
, mmDMA_RD_REGULATOR_BASE
);
279 goya_pb_set_block(hdev
, mmDMA_WR_REGULATOR_BASE
);
281 pb_addr
= (mmDMA_QM_0_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
282 word_offset
= ((mmDMA_QM_0_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
283 mask
= 1 << ((mmDMA_QM_0_GLBL_CFG0
& 0x7F) >> 2);
284 mask
|= 1 << ((mmDMA_QM_0_GLBL_CFG1
& 0x7F) >> 2);
285 mask
|= 1 << ((mmDMA_QM_0_GLBL_PROT
& 0x7F) >> 2);
286 mask
|= 1 << ((mmDMA_QM_0_GLBL_ERR_CFG
& 0x7F) >> 2);
287 mask
|= 1 << ((mmDMA_QM_0_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
288 mask
|= 1 << ((mmDMA_QM_0_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
289 mask
|= 1 << ((mmDMA_QM_0_GLBL_ERR_WDATA
& 0x7F) >> 2);
290 mask
|= 1 << ((mmDMA_QM_0_GLBL_SECURE_PROPS
& 0x7F) >> 2);
291 mask
|= 1 << ((mmDMA_QM_0_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
292 mask
|= 1 << ((mmDMA_QM_0_GLBL_STS0
& 0x7F) >> 2);
293 mask
|= 1 << ((mmDMA_QM_0_GLBL_STS1
& 0x7F) >> 2);
294 mask
|= 1 << ((mmDMA_QM_0_PQ_BASE_LO
& 0x7F) >> 2);
295 mask
|= 1 << ((mmDMA_QM_0_PQ_BASE_HI
& 0x7F) >> 2);
296 mask
|= 1 << ((mmDMA_QM_0_PQ_SIZE
& 0x7F) >> 2);
297 mask
|= 1 << ((mmDMA_QM_0_PQ_PI
& 0x7F) >> 2);
298 mask
|= 1 << ((mmDMA_QM_0_PQ_CI
& 0x7F) >> 2);
299 mask
|= 1 << ((mmDMA_QM_0_PQ_CFG0
& 0x7F) >> 2);
300 mask
|= 1 << ((mmDMA_QM_0_PQ_CFG1
& 0x7F) >> 2);
301 mask
|= 1 << ((mmDMA_QM_0_PQ_ARUSER
& 0x7F) >> 2);
303 WREG32(pb_addr
+ word_offset
, ~mask
);
305 pb_addr
= (mmDMA_QM_0_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
306 word_offset
= ((mmDMA_QM_0_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
307 mask
= 1 << ((mmDMA_QM_0_PQ_PUSH0
& 0x7F) >> 2);
308 mask
|= 1 << ((mmDMA_QM_0_PQ_PUSH1
& 0x7F) >> 2);
309 mask
|= 1 << ((mmDMA_QM_0_PQ_PUSH2
& 0x7F) >> 2);
310 mask
|= 1 << ((mmDMA_QM_0_PQ_PUSH3
& 0x7F) >> 2);
311 mask
|= 1 << ((mmDMA_QM_0_PQ_STS0
& 0x7F) >> 2);
312 mask
|= 1 << ((mmDMA_QM_0_PQ_STS1
& 0x7F) >> 2);
313 mask
|= 1 << ((mmDMA_QM_0_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
314 mask
|= 1 << ((mmDMA_QM_0_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
315 mask
|= 1 << ((mmDMA_QM_0_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
316 mask
|= 1 << ((mmDMA_QM_0_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
317 mask
|= 1 << ((mmDMA_QM_0_CQ_CFG0
& 0x7F) >> 2);
318 mask
|= 1 << ((mmDMA_QM_0_CQ_CFG1
& 0x7F) >> 2);
319 mask
|= 1 << ((mmDMA_QM_0_CQ_ARUSER
& 0x7F) >> 2);
320 mask
|= 1 << ((mmDMA_QM_0_CQ_PTR_LO
& 0x7F) >> 2);
321 mask
|= 1 << ((mmDMA_QM_0_CQ_PTR_HI
& 0x7F) >> 2);
322 mask
|= 1 << ((mmDMA_QM_0_CQ_TSIZE
& 0x7F) >> 2);
323 mask
|= 1 << ((mmDMA_QM_0_CQ_CTL
& 0x7F) >> 2);
324 mask
|= 1 << ((mmDMA_QM_0_CQ_PTR_LO_STS
& 0x7F) >> 2);
325 mask
|= 1 << ((mmDMA_QM_0_CQ_PTR_HI_STS
& 0x7F) >> 2);
326 mask
|= 1 << ((mmDMA_QM_0_CQ_TSIZE_STS
& 0x7F) >> 2);
327 mask
|= 1 << ((mmDMA_QM_0_CQ_CTL_STS
& 0x7F) >> 2);
328 mask
|= 1 << ((mmDMA_QM_0_CQ_STS0
& 0x7F) >> 2);
329 mask
|= 1 << ((mmDMA_QM_0_CQ_STS1
& 0x7F) >> 2);
330 mask
|= 1 << ((mmDMA_QM_0_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
331 mask
|= 1 << ((mmDMA_QM_0_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
332 mask
|= 1 << ((mmDMA_QM_0_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
333 mask
|= 1 << ((mmDMA_QM_0_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
335 WREG32(pb_addr
+ word_offset
, ~mask
);
337 pb_addr
= (mmDMA_QM_0_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
338 word_offset
= ((mmDMA_QM_0_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
339 mask
= 1 << ((mmDMA_QM_0_CQ_IFIFO_CNT
& 0x7F) >> 2);
340 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
341 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
342 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
343 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
344 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
345 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
346 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
347 mask
|= 1 << ((mmDMA_QM_0_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
348 mask
|= 1 << ((mmDMA_QM_0_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
349 mask
|= 1 << ((mmDMA_QM_0_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
350 mask
|= 1 << ((mmDMA_QM_0_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
351 mask
|= 1 << ((mmDMA_QM_0_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
352 mask
|= 1 << ((mmDMA_QM_0_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
353 mask
|= 1 << ((mmDMA_QM_0_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
355 WREG32(pb_addr
+ word_offset
, ~mask
);
357 goya_pb_set_block(hdev
, mmDMA_CH_0_BASE
);
359 pb_addr
= (mmDMA_QM_1_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
360 word_offset
= ((mmDMA_QM_1_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
361 mask
= 1 << ((mmDMA_QM_1_GLBL_CFG0
& 0x7F) >> 2);
362 mask
|= 1 << ((mmDMA_QM_1_GLBL_CFG1
& 0x7F) >> 2);
363 mask
|= 1 << ((mmDMA_QM_1_GLBL_PROT
& 0x7F) >> 2);
364 mask
|= 1 << ((mmDMA_QM_1_GLBL_ERR_CFG
& 0x7F) >> 2);
365 mask
|= 1 << ((mmDMA_QM_1_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
366 mask
|= 1 << ((mmDMA_QM_1_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
367 mask
|= 1 << ((mmDMA_QM_1_GLBL_ERR_WDATA
& 0x7F) >> 2);
368 mask
|= 1 << ((mmDMA_QM_1_GLBL_SECURE_PROPS
& 0x7F) >> 2);
369 mask
|= 1 << ((mmDMA_QM_1_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
370 mask
|= 1 << ((mmDMA_QM_1_GLBL_STS0
& 0x7F) >> 2);
371 mask
|= 1 << ((mmDMA_QM_1_GLBL_STS1
& 0x7F) >> 2);
372 mask
|= 1 << ((mmDMA_QM_1_PQ_BASE_LO
& 0x7F) >> 2);
373 mask
|= 1 << ((mmDMA_QM_1_PQ_BASE_HI
& 0x7F) >> 2);
374 mask
|= 1 << ((mmDMA_QM_1_PQ_SIZE
& 0x7F) >> 2);
375 mask
|= 1 << ((mmDMA_QM_1_PQ_PI
& 0x7F) >> 2);
376 mask
|= 1 << ((mmDMA_QM_1_PQ_CI
& 0x7F) >> 2);
377 mask
|= 1 << ((mmDMA_QM_1_PQ_CFG0
& 0x7F) >> 2);
378 mask
|= 1 << ((mmDMA_QM_1_PQ_CFG1
& 0x7F) >> 2);
379 mask
|= 1 << ((mmDMA_QM_1_PQ_ARUSER
& 0x7F) >> 2);
381 WREG32(pb_addr
+ word_offset
, ~mask
);
383 pb_addr
= (mmDMA_QM_1_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
384 word_offset
= ((mmDMA_QM_1_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
385 mask
= 1 << ((mmDMA_QM_1_PQ_PUSH0
& 0x7F) >> 2);
386 mask
|= 1 << ((mmDMA_QM_1_PQ_PUSH1
& 0x7F) >> 2);
387 mask
|= 1 << ((mmDMA_QM_1_PQ_PUSH2
& 0x7F) >> 2);
388 mask
|= 1 << ((mmDMA_QM_1_PQ_PUSH3
& 0x7F) >> 2);
389 mask
|= 1 << ((mmDMA_QM_1_PQ_STS0
& 0x7F) >> 2);
390 mask
|= 1 << ((mmDMA_QM_1_PQ_STS1
& 0x7F) >> 2);
391 mask
|= 1 << ((mmDMA_QM_1_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
392 mask
|= 1 << ((mmDMA_QM_1_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
393 mask
|= 1 << ((mmDMA_QM_1_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
394 mask
|= 1 << ((mmDMA_QM_1_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
395 mask
|= 1 << ((mmDMA_QM_1_CQ_CFG0
& 0x7F) >> 2);
396 mask
|= 1 << ((mmDMA_QM_1_CQ_CFG1
& 0x7F) >> 2);
397 mask
|= 1 << ((mmDMA_QM_1_CQ_ARUSER
& 0x7F) >> 2);
398 mask
|= 1 << ((mmDMA_QM_1_CQ_PTR_LO
& 0x7F) >> 2);
399 mask
|= 1 << ((mmDMA_QM_1_CQ_PTR_HI
& 0x7F) >> 2);
400 mask
|= 1 << ((mmDMA_QM_1_CQ_TSIZE
& 0x7F) >> 2);
401 mask
|= 1 << ((mmDMA_QM_1_CQ_CTL
& 0x7F) >> 2);
402 mask
|= 1 << ((mmDMA_QM_1_CQ_PTR_LO_STS
& 0x7F) >> 2);
403 mask
|= 1 << ((mmDMA_QM_1_CQ_PTR_HI_STS
& 0x7F) >> 2);
404 mask
|= 1 << ((mmDMA_QM_1_CQ_TSIZE_STS
& 0x7F) >> 2);
405 mask
|= 1 << ((mmDMA_QM_1_CQ_CTL_STS
& 0x7F) >> 2);
406 mask
|= 1 << ((mmDMA_QM_1_CQ_STS0
& 0x7F) >> 2);
407 mask
|= 1 << ((mmDMA_QM_1_CQ_STS1
& 0x7F) >> 2);
408 mask
|= 1 << ((mmDMA_QM_1_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
409 mask
|= 1 << ((mmDMA_QM_1_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
410 mask
|= 1 << ((mmDMA_QM_1_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
411 mask
|= 1 << ((mmDMA_QM_1_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
413 WREG32(pb_addr
+ word_offset
, ~mask
);
415 pb_addr
= (mmDMA_QM_1_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
416 word_offset
= ((mmDMA_QM_1_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
417 mask
= 1 << ((mmDMA_QM_1_CQ_IFIFO_CNT
& 0x7F) >> 2);
418 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
419 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
420 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
421 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
422 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
423 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
424 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
425 mask
|= 1 << ((mmDMA_QM_1_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
426 mask
|= 1 << ((mmDMA_QM_1_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
427 mask
|= 1 << ((mmDMA_QM_1_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
428 mask
|= 1 << ((mmDMA_QM_1_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
429 mask
|= 1 << ((mmDMA_QM_1_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
430 mask
|= 1 << ((mmDMA_QM_1_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
431 mask
|= 1 << ((mmDMA_QM_1_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
433 WREG32(pb_addr
+ word_offset
, ~mask
);
435 goya_pb_set_block(hdev
, mmDMA_CH_1_BASE
);
437 pb_addr
= (mmDMA_QM_2_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
438 word_offset
= ((mmDMA_QM_2_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
439 mask
= 1 << ((mmDMA_QM_2_GLBL_CFG0
& 0x7F) >> 2);
440 mask
|= 1 << ((mmDMA_QM_2_GLBL_CFG1
& 0x7F) >> 2);
441 mask
|= 1 << ((mmDMA_QM_2_GLBL_PROT
& 0x7F) >> 2);
442 mask
|= 1 << ((mmDMA_QM_2_GLBL_ERR_CFG
& 0x7F) >> 2);
443 mask
|= 1 << ((mmDMA_QM_2_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
444 mask
|= 1 << ((mmDMA_QM_2_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
445 mask
|= 1 << ((mmDMA_QM_2_GLBL_ERR_WDATA
& 0x7F) >> 2);
446 mask
|= 1 << ((mmDMA_QM_2_GLBL_SECURE_PROPS
& 0x7F) >> 2);
447 mask
|= 1 << ((mmDMA_QM_2_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
448 mask
|= 1 << ((mmDMA_QM_2_GLBL_STS0
& 0x7F) >> 2);
449 mask
|= 1 << ((mmDMA_QM_2_GLBL_STS1
& 0x7F) >> 2);
450 mask
|= 1 << ((mmDMA_QM_2_PQ_BASE_LO
& 0x7F) >> 2);
451 mask
|= 1 << ((mmDMA_QM_2_PQ_BASE_HI
& 0x7F) >> 2);
452 mask
|= 1 << ((mmDMA_QM_2_PQ_SIZE
& 0x7F) >> 2);
453 mask
|= 1 << ((mmDMA_QM_2_PQ_PI
& 0x7F) >> 2);
454 mask
|= 1 << ((mmDMA_QM_2_PQ_CI
& 0x7F) >> 2);
455 mask
|= 1 << ((mmDMA_QM_2_PQ_CFG0
& 0x7F) >> 2);
456 mask
|= 1 << ((mmDMA_QM_2_PQ_CFG1
& 0x7F) >> 2);
457 mask
|= 1 << ((mmDMA_QM_2_PQ_ARUSER
& 0x7F) >> 2);
459 WREG32(pb_addr
+ word_offset
, ~mask
);
461 pb_addr
= (mmDMA_QM_2_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
462 word_offset
= ((mmDMA_QM_2_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
463 mask
= 1 << ((mmDMA_QM_2_PQ_PUSH0
& 0x7F) >> 2);
464 mask
|= 1 << ((mmDMA_QM_2_PQ_PUSH1
& 0x7F) >> 2);
465 mask
|= 1 << ((mmDMA_QM_2_PQ_PUSH2
& 0x7F) >> 2);
466 mask
|= 1 << ((mmDMA_QM_2_PQ_PUSH3
& 0x7F) >> 2);
467 mask
|= 1 << ((mmDMA_QM_2_PQ_STS0
& 0x7F) >> 2);
468 mask
|= 1 << ((mmDMA_QM_2_PQ_STS1
& 0x7F) >> 2);
469 mask
|= 1 << ((mmDMA_QM_2_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
470 mask
|= 1 << ((mmDMA_QM_2_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
471 mask
|= 1 << ((mmDMA_QM_2_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
472 mask
|= 1 << ((mmDMA_QM_2_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
473 mask
|= 1 << ((mmDMA_QM_2_CQ_CFG0
& 0x7F) >> 2);
474 mask
|= 1 << ((mmDMA_QM_2_CQ_CFG1
& 0x7F) >> 2);
475 mask
|= 1 << ((mmDMA_QM_2_CQ_ARUSER
& 0x7F) >> 2);
476 mask
|= 1 << ((mmDMA_QM_2_CQ_PTR_LO
& 0x7F) >> 2);
477 mask
|= 1 << ((mmDMA_QM_2_CQ_PTR_HI
& 0x7F) >> 2);
478 mask
|= 1 << ((mmDMA_QM_2_CQ_TSIZE
& 0x7F) >> 2);
479 mask
|= 1 << ((mmDMA_QM_2_CQ_CTL
& 0x7F) >> 2);
480 mask
|= 1 << ((mmDMA_QM_2_CQ_PTR_LO_STS
& 0x7F) >> 2);
481 mask
|= 1 << ((mmDMA_QM_2_CQ_PTR_HI_STS
& 0x7F) >> 2);
482 mask
|= 1 << ((mmDMA_QM_2_CQ_TSIZE_STS
& 0x7F) >> 2);
483 mask
|= 1 << ((mmDMA_QM_2_CQ_CTL_STS
& 0x7F) >> 2);
484 mask
|= 1 << ((mmDMA_QM_2_CQ_STS0
& 0x7F) >> 2);
485 mask
|= 1 << ((mmDMA_QM_2_CQ_STS1
& 0x7F) >> 2);
486 mask
|= 1 << ((mmDMA_QM_2_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
487 mask
|= 1 << ((mmDMA_QM_2_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
488 mask
|= 1 << ((mmDMA_QM_2_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
489 mask
|= 1 << ((mmDMA_QM_2_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
491 WREG32(pb_addr
+ word_offset
, ~mask
);
493 pb_addr
= (mmDMA_QM_2_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
494 word_offset
= ((mmDMA_QM_2_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
495 mask
= 1 << ((mmDMA_QM_2_CQ_IFIFO_CNT
& 0x7F) >> 2);
496 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
497 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
498 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
499 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
500 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
501 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
502 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
503 mask
|= 1 << ((mmDMA_QM_2_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
504 mask
|= 1 << ((mmDMA_QM_2_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
505 mask
|= 1 << ((mmDMA_QM_2_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
506 mask
|= 1 << ((mmDMA_QM_2_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
507 mask
|= 1 << ((mmDMA_QM_2_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
508 mask
|= 1 << ((mmDMA_QM_2_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
509 mask
|= 1 << ((mmDMA_QM_2_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
511 WREG32(pb_addr
+ word_offset
, ~mask
);
513 goya_pb_set_block(hdev
, mmDMA_CH_2_BASE
);
515 pb_addr
= (mmDMA_QM_3_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
516 word_offset
= ((mmDMA_QM_3_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
517 mask
= 1 << ((mmDMA_QM_3_GLBL_CFG0
& 0x7F) >> 2);
518 mask
|= 1 << ((mmDMA_QM_3_GLBL_CFG1
& 0x7F) >> 2);
519 mask
|= 1 << ((mmDMA_QM_3_GLBL_PROT
& 0x7F) >> 2);
520 mask
|= 1 << ((mmDMA_QM_3_GLBL_ERR_CFG
& 0x7F) >> 2);
521 mask
|= 1 << ((mmDMA_QM_3_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
522 mask
|= 1 << ((mmDMA_QM_3_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
523 mask
|= 1 << ((mmDMA_QM_3_GLBL_ERR_WDATA
& 0x7F) >> 2);
524 mask
|= 1 << ((mmDMA_QM_3_GLBL_SECURE_PROPS
& 0x7F) >> 2);
525 mask
|= 1 << ((mmDMA_QM_3_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
526 mask
|= 1 << ((mmDMA_QM_3_GLBL_STS0
& 0x7F) >> 2);
527 mask
|= 1 << ((mmDMA_QM_3_GLBL_STS1
& 0x7F) >> 2);
528 mask
|= 1 << ((mmDMA_QM_3_PQ_BASE_LO
& 0x7F) >> 2);
529 mask
|= 1 << ((mmDMA_QM_3_PQ_BASE_HI
& 0x7F) >> 2);
530 mask
|= 1 << ((mmDMA_QM_3_PQ_SIZE
& 0x7F) >> 2);
531 mask
|= 1 << ((mmDMA_QM_3_PQ_PI
& 0x7F) >> 2);
532 mask
|= 1 << ((mmDMA_QM_3_PQ_CI
& 0x7F) >> 2);
533 mask
|= 1 << ((mmDMA_QM_3_PQ_CFG0
& 0x7F) >> 2);
534 mask
|= 1 << ((mmDMA_QM_3_PQ_CFG1
& 0x7F) >> 2);
535 mask
|= 1 << ((mmDMA_QM_3_PQ_ARUSER
& 0x7F) >> 2);
537 WREG32(pb_addr
+ word_offset
, ~mask
);
539 pb_addr
= (mmDMA_QM_3_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
540 word_offset
= ((mmDMA_QM_3_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
541 mask
= 1 << ((mmDMA_QM_3_PQ_PUSH0
& 0x7F) >> 2);
542 mask
|= 1 << ((mmDMA_QM_3_PQ_PUSH1
& 0x7F) >> 2);
543 mask
|= 1 << ((mmDMA_QM_3_PQ_PUSH2
& 0x7F) >> 2);
544 mask
|= 1 << ((mmDMA_QM_3_PQ_PUSH3
& 0x7F) >> 2);
545 mask
|= 1 << ((mmDMA_QM_3_PQ_STS0
& 0x7F) >> 2);
546 mask
|= 1 << ((mmDMA_QM_3_PQ_STS1
& 0x7F) >> 2);
547 mask
|= 1 << ((mmDMA_QM_3_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
548 mask
|= 1 << ((mmDMA_QM_3_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
549 mask
|= 1 << ((mmDMA_QM_3_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
550 mask
|= 1 << ((mmDMA_QM_3_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
551 mask
|= 1 << ((mmDMA_QM_3_CQ_CFG0
& 0x7F) >> 2);
552 mask
|= 1 << ((mmDMA_QM_3_CQ_CFG1
& 0x7F) >> 2);
553 mask
|= 1 << ((mmDMA_QM_3_CQ_ARUSER
& 0x7F) >> 2);
554 mask
|= 1 << ((mmDMA_QM_3_CQ_PTR_LO
& 0x7F) >> 2);
555 mask
|= 1 << ((mmDMA_QM_3_CQ_PTR_HI
& 0x7F) >> 2);
556 mask
|= 1 << ((mmDMA_QM_3_CQ_TSIZE
& 0x7F) >> 2);
557 mask
|= 1 << ((mmDMA_QM_3_CQ_CTL
& 0x7F) >> 2);
558 mask
|= 1 << ((mmDMA_QM_3_CQ_PTR_LO_STS
& 0x7F) >> 2);
559 mask
|= 1 << ((mmDMA_QM_3_CQ_PTR_HI_STS
& 0x7F) >> 2);
560 mask
|= 1 << ((mmDMA_QM_3_CQ_TSIZE_STS
& 0x7F) >> 2);
561 mask
|= 1 << ((mmDMA_QM_3_CQ_CTL_STS
& 0x7F) >> 2);
562 mask
|= 1 << ((mmDMA_QM_3_CQ_STS0
& 0x7F) >> 2);
563 mask
|= 1 << ((mmDMA_QM_3_CQ_STS1
& 0x7F) >> 2);
564 mask
|= 1 << ((mmDMA_QM_3_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
565 mask
|= 1 << ((mmDMA_QM_3_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
566 mask
|= 1 << ((mmDMA_QM_3_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
567 mask
|= 1 << ((mmDMA_QM_3_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
569 WREG32(pb_addr
+ word_offset
, ~mask
);
571 pb_addr
= (mmDMA_QM_3_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
572 word_offset
= ((mmDMA_QM_3_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
573 mask
= 1 << ((mmDMA_QM_3_CQ_IFIFO_CNT
& 0x7F) >> 2);
574 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
575 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
576 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
577 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
578 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
579 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
580 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
581 mask
|= 1 << ((mmDMA_QM_3_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
582 mask
|= 1 << ((mmDMA_QM_3_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
583 mask
|= 1 << ((mmDMA_QM_3_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
584 mask
|= 1 << ((mmDMA_QM_3_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
585 mask
|= 1 << ((mmDMA_QM_3_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
586 mask
|= 1 << ((mmDMA_QM_3_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
587 mask
|= 1 << ((mmDMA_QM_3_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
589 WREG32(pb_addr
+ word_offset
, ~mask
);
591 goya_pb_set_block(hdev
, mmDMA_CH_3_BASE
);
593 pb_addr
= (mmDMA_QM_4_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
594 word_offset
= ((mmDMA_QM_4_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
595 mask
= 1 << ((mmDMA_QM_4_GLBL_CFG0
& 0x7F) >> 2);
596 mask
|= 1 << ((mmDMA_QM_4_GLBL_CFG1
& 0x7F) >> 2);
597 mask
|= 1 << ((mmDMA_QM_4_GLBL_PROT
& 0x7F) >> 2);
598 mask
|= 1 << ((mmDMA_QM_4_GLBL_ERR_CFG
& 0x7F) >> 2);
599 mask
|= 1 << ((mmDMA_QM_4_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
600 mask
|= 1 << ((mmDMA_QM_4_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
601 mask
|= 1 << ((mmDMA_QM_4_GLBL_ERR_WDATA
& 0x7F) >> 2);
602 mask
|= 1 << ((mmDMA_QM_4_GLBL_SECURE_PROPS
& 0x7F) >> 2);
603 mask
|= 1 << ((mmDMA_QM_4_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
604 mask
|= 1 << ((mmDMA_QM_4_GLBL_STS0
& 0x7F) >> 2);
605 mask
|= 1 << ((mmDMA_QM_4_GLBL_STS1
& 0x7F) >> 2);
606 mask
|= 1 << ((mmDMA_QM_4_PQ_BASE_LO
& 0x7F) >> 2);
607 mask
|= 1 << ((mmDMA_QM_4_PQ_BASE_HI
& 0x7F) >> 2);
608 mask
|= 1 << ((mmDMA_QM_4_PQ_SIZE
& 0x7F) >> 2);
609 mask
|= 1 << ((mmDMA_QM_4_PQ_PI
& 0x7F) >> 2);
610 mask
|= 1 << ((mmDMA_QM_4_PQ_CI
& 0x7F) >> 2);
611 mask
|= 1 << ((mmDMA_QM_4_PQ_CFG0
& 0x7F) >> 2);
612 mask
|= 1 << ((mmDMA_QM_4_PQ_CFG1
& 0x7F) >> 2);
613 mask
|= 1 << ((mmDMA_QM_4_PQ_ARUSER
& 0x7F) >> 2);
615 WREG32(pb_addr
+ word_offset
, ~mask
);
617 pb_addr
= (mmDMA_QM_4_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
618 word_offset
= ((mmDMA_QM_4_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
619 mask
= 1 << ((mmDMA_QM_4_PQ_PUSH0
& 0x7F) >> 2);
620 mask
|= 1 << ((mmDMA_QM_4_PQ_PUSH1
& 0x7F) >> 2);
621 mask
|= 1 << ((mmDMA_QM_4_PQ_PUSH2
& 0x7F) >> 2);
622 mask
|= 1 << ((mmDMA_QM_4_PQ_PUSH3
& 0x7F) >> 2);
623 mask
|= 1 << ((mmDMA_QM_4_PQ_STS0
& 0x7F) >> 2);
624 mask
|= 1 << ((mmDMA_QM_4_PQ_STS1
& 0x7F) >> 2);
625 mask
|= 1 << ((mmDMA_QM_4_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
626 mask
|= 1 << ((mmDMA_QM_4_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
627 mask
|= 1 << ((mmDMA_QM_4_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
628 mask
|= 1 << ((mmDMA_QM_4_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
629 mask
|= 1 << ((mmDMA_QM_4_CQ_CFG0
& 0x7F) >> 2);
630 mask
|= 1 << ((mmDMA_QM_4_CQ_CFG1
& 0x7F) >> 2);
631 mask
|= 1 << ((mmDMA_QM_4_CQ_ARUSER
& 0x7F) >> 2);
632 mask
|= 1 << ((mmDMA_QM_4_CQ_PTR_LO
& 0x7F) >> 2);
633 mask
|= 1 << ((mmDMA_QM_4_CQ_PTR_HI
& 0x7F) >> 2);
634 mask
|= 1 << ((mmDMA_QM_4_CQ_TSIZE
& 0x7F) >> 2);
635 mask
|= 1 << ((mmDMA_QM_4_CQ_CTL
& 0x7F) >> 2);
636 mask
|= 1 << ((mmDMA_QM_4_CQ_PTR_LO_STS
& 0x7F) >> 2);
637 mask
|= 1 << ((mmDMA_QM_4_CQ_PTR_HI_STS
& 0x7F) >> 2);
638 mask
|= 1 << ((mmDMA_QM_4_CQ_TSIZE_STS
& 0x7F) >> 2);
639 mask
|= 1 << ((mmDMA_QM_4_CQ_CTL_STS
& 0x7F) >> 2);
640 mask
|= 1 << ((mmDMA_QM_4_CQ_STS0
& 0x7F) >> 2);
641 mask
|= 1 << ((mmDMA_QM_4_CQ_STS1
& 0x7F) >> 2);
642 mask
|= 1 << ((mmDMA_QM_4_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
643 mask
|= 1 << ((mmDMA_QM_4_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
644 mask
|= 1 << ((mmDMA_QM_4_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
645 mask
|= 1 << ((mmDMA_QM_4_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
647 WREG32(pb_addr
+ word_offset
, ~mask
);
649 pb_addr
= (mmDMA_QM_4_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
650 word_offset
= ((mmDMA_QM_4_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
651 mask
= 1 << ((mmDMA_QM_4_CQ_IFIFO_CNT
& 0x7F) >> 2);
652 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
653 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
654 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
655 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
656 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
657 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
658 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
659 mask
|= 1 << ((mmDMA_QM_4_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
660 mask
|= 1 << ((mmDMA_QM_4_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
661 mask
|= 1 << ((mmDMA_QM_4_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
662 mask
|= 1 << ((mmDMA_QM_4_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
663 mask
|= 1 << ((mmDMA_QM_4_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
664 mask
|= 1 << ((mmDMA_QM_4_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
665 mask
|= 1 << ((mmDMA_QM_4_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
667 WREG32(pb_addr
+ word_offset
, ~mask
);
669 goya_pb_set_block(hdev
, mmDMA_CH_4_BASE
);
672 static void goya_init_tpc_protection_bits(struct hl_device
*hdev
)
677 goya_pb_set_block(hdev
, mmTPC0_RD_REGULATOR_BASE
);
678 goya_pb_set_block(hdev
, mmTPC0_WR_REGULATOR_BASE
);
680 pb_addr
= (mmTPC0_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
681 word_offset
= ((mmTPC0_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
683 mask
= 1 << ((mmTPC0_CFG_SEMAPHORE
& 0x7F) >> 2);
684 mask
|= 1 << ((mmTPC0_CFG_VFLAGS
& 0x7F) >> 2);
685 mask
|= 1 << ((mmTPC0_CFG_SFLAGS
& 0x7F) >> 2);
686 mask
|= 1 << ((mmTPC0_CFG_STATUS
& 0x7F) >> 2);
688 WREG32(pb_addr
+ word_offset
, ~mask
);
690 pb_addr
= (mmTPC0_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
691 word_offset
= ((mmTPC0_CFG_CFG_BASE_ADDRESS_HIGH
&
692 PROT_BITS_OFFS
) >> 7) << 2;
693 mask
= 1 << ((mmTPC0_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
694 mask
|= 1 << ((mmTPC0_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
695 mask
|= 1 << ((mmTPC0_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
696 mask
|= 1 << ((mmTPC0_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
697 mask
|= 1 << ((mmTPC0_CFG_TPC_STALL
& 0x7F) >> 2);
698 mask
|= 1 << ((mmTPC0_CFG_MSS_CONFIG
& 0x7F) >> 2);
699 mask
|= 1 << ((mmTPC0_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
700 mask
|= 1 << ((mmTPC0_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
702 WREG32(pb_addr
+ word_offset
, ~mask
);
704 pb_addr
= (mmTPC0_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
705 word_offset
= ((mmTPC0_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
706 mask
= 1 << ((mmTPC0_CFG_ARUSER
& 0x7F) >> 2);
707 mask
|= 1 << ((mmTPC0_CFG_AWUSER
& 0x7F) >> 2);
709 WREG32(pb_addr
+ word_offset
, ~mask
);
711 pb_addr
= (mmTPC0_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
712 word_offset
= ((mmTPC0_CFG_FUNC_MBIST_CNTRL
&
713 PROT_BITS_OFFS
) >> 7) << 2;
714 mask
= 1 << ((mmTPC0_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
715 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
716 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
717 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
718 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
719 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
720 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
721 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
722 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
723 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
724 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
725 mask
|= 1 << ((mmTPC0_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
727 WREG32(pb_addr
+ word_offset
, ~mask
);
729 pb_addr
= (mmTPC0_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
730 word_offset
= ((mmTPC0_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
731 mask
= 1 << ((mmTPC0_QM_GLBL_CFG0
& 0x7F) >> 2);
732 mask
|= 1 << ((mmTPC0_QM_GLBL_CFG1
& 0x7F) >> 2);
733 mask
|= 1 << ((mmTPC0_QM_GLBL_PROT
& 0x7F) >> 2);
734 mask
|= 1 << ((mmTPC0_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
735 mask
|= 1 << ((mmTPC0_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
736 mask
|= 1 << ((mmTPC0_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
737 mask
|= 1 << ((mmTPC0_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
738 mask
|= 1 << ((mmTPC0_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
739 mask
|= 1 << ((mmTPC0_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
740 mask
|= 1 << ((mmTPC0_QM_GLBL_STS0
& 0x7F) >> 2);
741 mask
|= 1 << ((mmTPC0_QM_GLBL_STS1
& 0x7F) >> 2);
742 mask
|= 1 << ((mmTPC0_QM_PQ_BASE_LO
& 0x7F) >> 2);
743 mask
|= 1 << ((mmTPC0_QM_PQ_BASE_HI
& 0x7F) >> 2);
744 mask
|= 1 << ((mmTPC0_QM_PQ_SIZE
& 0x7F) >> 2);
745 mask
|= 1 << ((mmTPC0_QM_PQ_PI
& 0x7F) >> 2);
746 mask
|= 1 << ((mmTPC0_QM_PQ_CI
& 0x7F) >> 2);
747 mask
|= 1 << ((mmTPC0_QM_PQ_CFG0
& 0x7F) >> 2);
748 mask
|= 1 << ((mmTPC0_QM_PQ_CFG1
& 0x7F) >> 2);
749 mask
|= 1 << ((mmTPC0_QM_PQ_ARUSER
& 0x7F) >> 2);
751 WREG32(pb_addr
+ word_offset
, ~mask
);
753 pb_addr
= (mmTPC0_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
754 word_offset
= ((mmTPC0_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
755 mask
= 1 << ((mmTPC0_QM_PQ_PUSH0
& 0x7F) >> 2);
756 mask
|= 1 << ((mmTPC0_QM_PQ_PUSH1
& 0x7F) >> 2);
757 mask
|= 1 << ((mmTPC0_QM_PQ_PUSH2
& 0x7F) >> 2);
758 mask
|= 1 << ((mmTPC0_QM_PQ_PUSH3
& 0x7F) >> 2);
759 mask
|= 1 << ((mmTPC0_QM_PQ_STS0
& 0x7F) >> 2);
760 mask
|= 1 << ((mmTPC0_QM_PQ_STS1
& 0x7F) >> 2);
761 mask
|= 1 << ((mmTPC0_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
762 mask
|= 1 << ((mmTPC0_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
763 mask
|= 1 << ((mmTPC0_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
764 mask
|= 1 << ((mmTPC0_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
765 mask
|= 1 << ((mmTPC0_QM_CQ_CFG0
& 0x7F) >> 2);
766 mask
|= 1 << ((mmTPC0_QM_CQ_CFG1
& 0x7F) >> 2);
767 mask
|= 1 << ((mmTPC0_QM_CQ_ARUSER
& 0x7F) >> 2);
768 mask
|= 1 << ((mmTPC0_QM_CQ_PTR_LO
& 0x7F) >> 2);
769 mask
|= 1 << ((mmTPC0_QM_CQ_PTR_HI
& 0x7F) >> 2);
770 mask
|= 1 << ((mmTPC0_QM_CQ_TSIZE
& 0x7F) >> 2);
771 mask
|= 1 << ((mmTPC0_QM_CQ_CTL
& 0x7F) >> 2);
772 mask
|= 1 << ((mmTPC0_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
773 mask
|= 1 << ((mmTPC0_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
774 mask
|= 1 << ((mmTPC0_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
775 mask
|= 1 << ((mmTPC0_QM_CQ_CTL_STS
& 0x7F) >> 2);
776 mask
|= 1 << ((mmTPC0_QM_CQ_STS0
& 0x7F) >> 2);
777 mask
|= 1 << ((mmTPC0_QM_CQ_STS1
& 0x7F) >> 2);
778 mask
|= 1 << ((mmTPC0_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
779 mask
|= 1 << ((mmTPC0_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
780 mask
|= 1 << ((mmTPC0_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
781 mask
|= 1 << ((mmTPC0_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
783 WREG32(pb_addr
+ word_offset
, ~mask
);
785 pb_addr
= (mmTPC0_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
786 word_offset
= ((mmTPC0_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
787 mask
= 1 << ((mmTPC0_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
788 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
789 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
790 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
791 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
792 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
793 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
794 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
795 mask
|= 1 << ((mmTPC0_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
796 mask
|= 1 << ((mmTPC0_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
797 mask
|= 1 << ((mmTPC0_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
798 mask
|= 1 << ((mmTPC0_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
799 mask
|= 1 << ((mmTPC0_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
800 mask
|= 1 << ((mmTPC0_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
801 mask
|= 1 << ((mmTPC0_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
803 WREG32(pb_addr
+ word_offset
, ~mask
);
805 pb_addr
= (mmTPC0_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
806 word_offset
= ((mmTPC0_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
807 mask
= 1 << ((mmTPC0_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
808 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
809 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_PROT
& 0x7F) >> 2);
810 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
811 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
812 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
813 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
814 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
815 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
816 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_STS0
& 0x7F) >> 2);
817 mask
|= 1 << ((mmTPC0_CMDQ_GLBL_STS1
& 0x7F) >> 2);
819 WREG32(pb_addr
+ word_offset
, ~mask
);
821 pb_addr
= (mmTPC0_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
822 word_offset
= ((mmTPC0_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
823 mask
= 1 << ((mmTPC0_CMDQ_CQ_CFG0
& 0x7F) >> 2);
824 mask
|= 1 << ((mmTPC0_CMDQ_CQ_CFG1
& 0x7F) >> 2);
825 mask
|= 1 << ((mmTPC0_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
826 mask
|= 1 << ((mmTPC0_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
827 mask
|= 1 << ((mmTPC0_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
828 mask
|= 1 << ((mmTPC0_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
829 mask
|= 1 << ((mmTPC0_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
830 mask
|= 1 << ((mmTPC0_CMDQ_CQ_STS0
& 0x7F) >> 2);
831 mask
|= 1 << ((mmTPC0_CMDQ_CQ_STS1
& 0x7F) >> 2);
832 mask
|= 1 << ((mmTPC0_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
833 mask
|= 1 << ((mmTPC0_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
834 mask
|= 1 << ((mmTPC0_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
835 mask
|= 1 << ((mmTPC0_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
837 WREG32(pb_addr
+ word_offset
, ~mask
);
839 pb_addr
= (mmTPC0_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
840 word_offset
= ((mmTPC0_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
841 mask
= 1 << ((mmTPC0_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
842 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
843 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
844 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
845 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
846 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
847 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
848 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
849 mask
|= 1 << ((mmTPC0_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
850 mask
|= 1 << ((mmTPC0_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
851 mask
|= 1 << ((mmTPC0_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
852 mask
|= 1 << ((mmTPC0_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
853 mask
|= 1 << ((mmTPC0_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
854 mask
|= 1 << ((mmTPC0_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
855 mask
|= 1 << ((mmTPC0_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
856 mask
|= 1 << ((mmTPC0_CMDQ_CP_STS
& 0x7F) >> 2);
857 mask
|= 1 << ((mmTPC0_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
859 WREG32(pb_addr
+ word_offset
, ~mask
);
861 pb_addr
= (mmTPC0_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
862 word_offset
= ((mmTPC0_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
864 mask
= 1 << ((mmTPC0_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
865 mask
|= 1 << ((mmTPC0_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
866 mask
|= 1 << ((mmTPC0_CMDQ_CP_DBG_0
& 0x7F) >> 2);
867 mask
|= 1 << ((mmTPC0_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
868 mask
|= 1 << ((mmTPC0_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
870 WREG32(pb_addr
+ word_offset
, ~mask
);
872 goya_pb_set_block(hdev
, mmTPC1_RTR_BASE
);
873 goya_pb_set_block(hdev
, mmTPC1_RD_REGULATOR_BASE
);
874 goya_pb_set_block(hdev
, mmTPC1_WR_REGULATOR_BASE
);
876 pb_addr
= (mmTPC1_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
877 word_offset
= ((mmTPC1_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
879 mask
= 1 << ((mmTPC1_CFG_SEMAPHORE
& 0x7F) >> 2);
880 mask
|= 1 << ((mmTPC1_CFG_VFLAGS
& 0x7F) >> 2);
881 mask
|= 1 << ((mmTPC1_CFG_SFLAGS
& 0x7F) >> 2);
882 mask
|= 1 << ((mmTPC1_CFG_STATUS
& 0x7F) >> 2);
884 WREG32(pb_addr
+ word_offset
, ~mask
);
886 pb_addr
= (mmTPC1_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
887 word_offset
= ((mmTPC1_CFG_CFG_BASE_ADDRESS_HIGH
&
888 PROT_BITS_OFFS
) >> 7) << 2;
889 mask
= 1 << ((mmTPC1_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
890 mask
|= 1 << ((mmTPC1_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
891 mask
|= 1 << ((mmTPC1_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
892 mask
|= 1 << ((mmTPC1_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
893 mask
|= 1 << ((mmTPC1_CFG_TPC_STALL
& 0x7F) >> 2);
894 mask
|= 1 << ((mmTPC1_CFG_MSS_CONFIG
& 0x7F) >> 2);
895 mask
|= 1 << ((mmTPC1_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
896 mask
|= 1 << ((mmTPC1_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
898 WREG32(pb_addr
+ word_offset
, ~mask
);
900 pb_addr
= (mmTPC1_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
901 word_offset
= ((mmTPC1_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
902 mask
= 1 << ((mmTPC1_CFG_ARUSER
& 0x7F) >> 2);
903 mask
|= 1 << ((mmTPC1_CFG_AWUSER
& 0x7F) >> 2);
905 WREG32(pb_addr
+ word_offset
, ~mask
);
907 pb_addr
= (mmTPC1_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
908 word_offset
= ((mmTPC1_CFG_FUNC_MBIST_CNTRL
& PROT_BITS_OFFS
) >> 7)
910 mask
= 1 << ((mmTPC1_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
911 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
912 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
913 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
914 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
915 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
916 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
917 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
918 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
919 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
920 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
921 mask
|= 1 << ((mmTPC1_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
923 WREG32(pb_addr
+ word_offset
, ~mask
);
925 pb_addr
= (mmTPC1_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
926 word_offset
= ((mmTPC1_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
927 mask
= 1 << ((mmTPC1_QM_GLBL_CFG0
& 0x7F) >> 2);
928 mask
|= 1 << ((mmTPC1_QM_GLBL_CFG1
& 0x7F) >> 2);
929 mask
|= 1 << ((mmTPC1_QM_GLBL_PROT
& 0x7F) >> 2);
930 mask
|= 1 << ((mmTPC1_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
931 mask
|= 1 << ((mmTPC1_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
932 mask
|= 1 << ((mmTPC1_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
933 mask
|= 1 << ((mmTPC1_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
934 mask
|= 1 << ((mmTPC1_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
935 mask
|= 1 << ((mmTPC1_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
936 mask
|= 1 << ((mmTPC1_QM_GLBL_STS0
& 0x7F) >> 2);
937 mask
|= 1 << ((mmTPC1_QM_GLBL_STS1
& 0x7F) >> 2);
938 mask
|= 1 << ((mmTPC1_QM_PQ_BASE_LO
& 0x7F) >> 2);
939 mask
|= 1 << ((mmTPC1_QM_PQ_BASE_HI
& 0x7F) >> 2);
940 mask
|= 1 << ((mmTPC1_QM_PQ_SIZE
& 0x7F) >> 2);
941 mask
|= 1 << ((mmTPC1_QM_PQ_PI
& 0x7F) >> 2);
942 mask
|= 1 << ((mmTPC1_QM_PQ_CI
& 0x7F) >> 2);
943 mask
|= 1 << ((mmTPC1_QM_PQ_CFG0
& 0x7F) >> 2);
944 mask
|= 1 << ((mmTPC1_QM_PQ_CFG1
& 0x7F) >> 2);
945 mask
|= 1 << ((mmTPC1_QM_PQ_ARUSER
& 0x7F) >> 2);
947 WREG32(pb_addr
+ word_offset
, ~mask
);
949 pb_addr
= (mmTPC1_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
950 word_offset
= ((mmTPC1_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
951 mask
= 1 << ((mmTPC1_QM_PQ_PUSH0
& 0x7F) >> 2);
952 mask
|= 1 << ((mmTPC1_QM_PQ_PUSH1
& 0x7F) >> 2);
953 mask
|= 1 << ((mmTPC1_QM_PQ_PUSH2
& 0x7F) >> 2);
954 mask
|= 1 << ((mmTPC1_QM_PQ_PUSH3
& 0x7F) >> 2);
955 mask
|= 1 << ((mmTPC1_QM_PQ_STS0
& 0x7F) >> 2);
956 mask
|= 1 << ((mmTPC1_QM_PQ_STS1
& 0x7F) >> 2);
957 mask
|= 1 << ((mmTPC1_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
958 mask
|= 1 << ((mmTPC1_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
959 mask
|= 1 << ((mmTPC1_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
960 mask
|= 1 << ((mmTPC1_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
961 mask
|= 1 << ((mmTPC1_QM_CQ_CFG0
& 0x7F) >> 2);
962 mask
|= 1 << ((mmTPC1_QM_CQ_CFG1
& 0x7F) >> 2);
963 mask
|= 1 << ((mmTPC1_QM_CQ_ARUSER
& 0x7F) >> 2);
964 mask
|= 1 << ((mmTPC1_QM_CQ_PTR_LO
& 0x7F) >> 2);
965 mask
|= 1 << ((mmTPC1_QM_CQ_PTR_HI
& 0x7F) >> 2);
966 mask
|= 1 << ((mmTPC1_QM_CQ_TSIZE
& 0x7F) >> 2);
967 mask
|= 1 << ((mmTPC1_QM_CQ_CTL
& 0x7F) >> 2);
968 mask
|= 1 << ((mmTPC1_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
969 mask
|= 1 << ((mmTPC1_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
970 mask
|= 1 << ((mmTPC1_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
971 mask
|= 1 << ((mmTPC1_QM_CQ_CTL_STS
& 0x7F) >> 2);
972 mask
|= 1 << ((mmTPC1_QM_CQ_STS0
& 0x7F) >> 2);
973 mask
|= 1 << ((mmTPC1_QM_CQ_STS1
& 0x7F) >> 2);
974 mask
|= 1 << ((mmTPC1_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
975 mask
|= 1 << ((mmTPC1_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
976 mask
|= 1 << ((mmTPC1_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
977 mask
|= 1 << ((mmTPC1_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
979 WREG32(pb_addr
+ word_offset
, ~mask
);
981 pb_addr
= (mmTPC1_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
982 word_offset
= ((mmTPC1_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
983 mask
= 1 << ((mmTPC1_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
984 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
985 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
986 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
987 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
988 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
989 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
990 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
991 mask
|= 1 << ((mmTPC1_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
992 mask
|= 1 << ((mmTPC1_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
993 mask
|= 1 << ((mmTPC1_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
994 mask
|= 1 << ((mmTPC1_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
995 mask
|= 1 << ((mmTPC1_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
996 mask
|= 1 << ((mmTPC1_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
997 mask
|= 1 << ((mmTPC1_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
999 WREG32(pb_addr
+ word_offset
, ~mask
);
1001 pb_addr
= (mmTPC1_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1002 word_offset
= ((mmTPC1_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1003 mask
= 1 << ((mmTPC1_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
1004 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
1005 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_PROT
& 0x7F) >> 2);
1006 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
1007 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1008 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1009 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
1010 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1011 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1012 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_STS0
& 0x7F) >> 2);
1013 mask
|= 1 << ((mmTPC1_CMDQ_GLBL_STS1
& 0x7F) >> 2);
1015 WREG32(pb_addr
+ word_offset
, ~mask
);
1017 pb_addr
= (mmTPC1_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1018 word_offset
= ((mmTPC1_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1019 mask
= 1 << ((mmTPC1_CMDQ_CQ_CFG0
& 0x7F) >> 2);
1020 mask
|= 1 << ((mmTPC1_CMDQ_CQ_CFG1
& 0x7F) >> 2);
1021 mask
|= 1 << ((mmTPC1_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
1022 mask
|= 1 << ((mmTPC1_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
1023 mask
|= 1 << ((mmTPC1_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
1024 mask
|= 1 << ((mmTPC1_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
1025 mask
|= 1 << ((mmTPC1_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
1026 mask
|= 1 << ((mmTPC1_CMDQ_CQ_STS0
& 0x7F) >> 2);
1027 mask
|= 1 << ((mmTPC1_CMDQ_CQ_STS1
& 0x7F) >> 2);
1028 mask
|= 1 << ((mmTPC1_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1029 mask
|= 1 << ((mmTPC1_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1030 mask
|= 1 << ((mmTPC1_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1031 mask
|= 1 << ((mmTPC1_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1033 WREG32(pb_addr
+ word_offset
, ~mask
);
1035 pb_addr
= (mmTPC1_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1036 word_offset
= ((mmTPC1_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1037 mask
= 1 << ((mmTPC1_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
1038 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1039 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1040 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1041 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1042 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1043 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1044 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1045 mask
|= 1 << ((mmTPC1_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1046 mask
|= 1 << ((mmTPC1_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1047 mask
|= 1 << ((mmTPC1_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1048 mask
|= 1 << ((mmTPC1_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1049 mask
|= 1 << ((mmTPC1_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1050 mask
|= 1 << ((mmTPC1_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1051 mask
|= 1 << ((mmTPC1_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1052 mask
|= 1 << ((mmTPC1_CMDQ_CP_STS
& 0x7F) >> 2);
1053 mask
|= 1 << ((mmTPC1_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
1055 WREG32(pb_addr
+ word_offset
, ~mask
);
1057 pb_addr
= (mmTPC1_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
1058 word_offset
= ((mmTPC1_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
1060 mask
= 1 << ((mmTPC1_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
1061 mask
|= 1 << ((mmTPC1_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
1062 mask
|= 1 << ((mmTPC1_CMDQ_CP_DBG_0
& 0x7F) >> 2);
1063 mask
|= 1 << ((mmTPC1_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
1064 mask
|= 1 << ((mmTPC1_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
1066 WREG32(pb_addr
+ word_offset
, ~mask
);
1068 goya_pb_set_block(hdev
, mmTPC2_RTR_BASE
);
1069 goya_pb_set_block(hdev
, mmTPC2_RD_REGULATOR_BASE
);
1070 goya_pb_set_block(hdev
, mmTPC2_WR_REGULATOR_BASE
);
1072 pb_addr
= (mmTPC2_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
1073 word_offset
= ((mmTPC2_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
1075 mask
= 1 << ((mmTPC2_CFG_SEMAPHORE
& 0x7F) >> 2);
1076 mask
|= 1 << ((mmTPC2_CFG_VFLAGS
& 0x7F) >> 2);
1077 mask
|= 1 << ((mmTPC2_CFG_SFLAGS
& 0x7F) >> 2);
1078 mask
|= 1 << ((mmTPC2_CFG_STATUS
& 0x7F) >> 2);
1080 WREG32(pb_addr
+ word_offset
, ~mask
);
1082 pb_addr
= (mmTPC2_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
1083 word_offset
= ((mmTPC2_CFG_CFG_BASE_ADDRESS_HIGH
&
1084 PROT_BITS_OFFS
) >> 7) << 2;
1085 mask
= 1 << ((mmTPC2_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1086 mask
|= 1 << ((mmTPC2_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
1087 mask
|= 1 << ((mmTPC2_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
1088 mask
|= 1 << ((mmTPC2_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1089 mask
|= 1 << ((mmTPC2_CFG_TPC_STALL
& 0x7F) >> 2);
1090 mask
|= 1 << ((mmTPC2_CFG_MSS_CONFIG
& 0x7F) >> 2);
1091 mask
|= 1 << ((mmTPC2_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
1092 mask
|= 1 << ((mmTPC2_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
1094 WREG32(pb_addr
+ word_offset
, ~mask
);
1096 pb_addr
= (mmTPC2_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
1097 word_offset
= ((mmTPC2_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
1098 mask
= 1 << ((mmTPC2_CFG_ARUSER
& 0x7F) >> 2);
1099 mask
|= 1 << ((mmTPC2_CFG_AWUSER
& 0x7F) >> 2);
1101 WREG32(pb_addr
+ word_offset
, ~mask
);
1103 pb_addr
= (mmTPC2_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
1104 word_offset
= ((mmTPC2_CFG_FUNC_MBIST_CNTRL
& PROT_BITS_OFFS
) >> 7)
1106 mask
= 1 << ((mmTPC2_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
1107 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
1108 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
1109 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
1110 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
1111 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
1112 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
1113 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
1114 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
1115 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
1116 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
1117 mask
|= 1 << ((mmTPC2_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
1119 WREG32(pb_addr
+ word_offset
, ~mask
);
1121 pb_addr
= (mmTPC2_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1122 word_offset
= ((mmTPC2_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1123 mask
= 1 << ((mmTPC2_QM_GLBL_CFG0
& 0x7F) >> 2);
1124 mask
|= 1 << ((mmTPC2_QM_GLBL_CFG1
& 0x7F) >> 2);
1125 mask
|= 1 << ((mmTPC2_QM_GLBL_PROT
& 0x7F) >> 2);
1126 mask
|= 1 << ((mmTPC2_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
1127 mask
|= 1 << ((mmTPC2_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1128 mask
|= 1 << ((mmTPC2_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1129 mask
|= 1 << ((mmTPC2_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
1130 mask
|= 1 << ((mmTPC2_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1131 mask
|= 1 << ((mmTPC2_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1132 mask
|= 1 << ((mmTPC2_QM_GLBL_STS0
& 0x7F) >> 2);
1133 mask
|= 1 << ((mmTPC2_QM_GLBL_STS1
& 0x7F) >> 2);
1134 mask
|= 1 << ((mmTPC2_QM_PQ_BASE_LO
& 0x7F) >> 2);
1135 mask
|= 1 << ((mmTPC2_QM_PQ_BASE_HI
& 0x7F) >> 2);
1136 mask
|= 1 << ((mmTPC2_QM_PQ_SIZE
& 0x7F) >> 2);
1137 mask
|= 1 << ((mmTPC2_QM_PQ_PI
& 0x7F) >> 2);
1138 mask
|= 1 << ((mmTPC2_QM_PQ_CI
& 0x7F) >> 2);
1139 mask
|= 1 << ((mmTPC2_QM_PQ_CFG0
& 0x7F) >> 2);
1140 mask
|= 1 << ((mmTPC2_QM_PQ_CFG1
& 0x7F) >> 2);
1141 mask
|= 1 << ((mmTPC2_QM_PQ_ARUSER
& 0x7F) >> 2);
1143 WREG32(pb_addr
+ word_offset
, ~mask
);
1145 pb_addr
= (mmTPC2_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
1146 word_offset
= ((mmTPC2_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
1147 mask
= 1 << ((mmTPC2_QM_PQ_PUSH0
& 0x7F) >> 2);
1148 mask
|= 1 << ((mmTPC2_QM_PQ_PUSH1
& 0x7F) >> 2);
1149 mask
|= 1 << ((mmTPC2_QM_PQ_PUSH2
& 0x7F) >> 2);
1150 mask
|= 1 << ((mmTPC2_QM_PQ_PUSH3
& 0x7F) >> 2);
1151 mask
|= 1 << ((mmTPC2_QM_PQ_STS0
& 0x7F) >> 2);
1152 mask
|= 1 << ((mmTPC2_QM_PQ_STS1
& 0x7F) >> 2);
1153 mask
|= 1 << ((mmTPC2_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1154 mask
|= 1 << ((mmTPC2_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1155 mask
|= 1 << ((mmTPC2_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1156 mask
|= 1 << ((mmTPC2_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1157 mask
|= 1 << ((mmTPC2_QM_CQ_CFG0
& 0x7F) >> 2);
1158 mask
|= 1 << ((mmTPC2_QM_CQ_CFG1
& 0x7F) >> 2);
1159 mask
|= 1 << ((mmTPC2_QM_CQ_ARUSER
& 0x7F) >> 2);
1160 mask
|= 1 << ((mmTPC2_QM_CQ_PTR_LO
& 0x7F) >> 2);
1161 mask
|= 1 << ((mmTPC2_QM_CQ_PTR_HI
& 0x7F) >> 2);
1162 mask
|= 1 << ((mmTPC2_QM_CQ_TSIZE
& 0x7F) >> 2);
1163 mask
|= 1 << ((mmTPC2_QM_CQ_CTL
& 0x7F) >> 2);
1164 mask
|= 1 << ((mmTPC2_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
1165 mask
|= 1 << ((mmTPC2_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
1166 mask
|= 1 << ((mmTPC2_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
1167 mask
|= 1 << ((mmTPC2_QM_CQ_CTL_STS
& 0x7F) >> 2);
1168 mask
|= 1 << ((mmTPC2_QM_CQ_STS0
& 0x7F) >> 2);
1169 mask
|= 1 << ((mmTPC2_QM_CQ_STS1
& 0x7F) >> 2);
1170 mask
|= 1 << ((mmTPC2_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1171 mask
|= 1 << ((mmTPC2_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1172 mask
|= 1 << ((mmTPC2_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1173 mask
|= 1 << ((mmTPC2_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1175 WREG32(pb_addr
+ word_offset
, ~mask
);
1177 pb_addr
= (mmTPC2_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1178 word_offset
= ((mmTPC2_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1179 mask
= 1 << ((mmTPC2_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
1180 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1181 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1182 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1183 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1184 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1185 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1186 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1187 mask
|= 1 << ((mmTPC2_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1188 mask
|= 1 << ((mmTPC2_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1189 mask
|= 1 << ((mmTPC2_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1190 mask
|= 1 << ((mmTPC2_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1191 mask
|= 1 << ((mmTPC2_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1192 mask
|= 1 << ((mmTPC2_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1193 mask
|= 1 << ((mmTPC2_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1195 WREG32(pb_addr
+ word_offset
, ~mask
);
1197 pb_addr
= (mmTPC2_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1198 word_offset
= ((mmTPC2_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1199 mask
= 1 << ((mmTPC2_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
1200 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
1201 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_PROT
& 0x7F) >> 2);
1202 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
1203 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1204 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1205 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
1206 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1207 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1208 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_STS0
& 0x7F) >> 2);
1209 mask
|= 1 << ((mmTPC2_CMDQ_GLBL_STS1
& 0x7F) >> 2);
1211 WREG32(pb_addr
+ word_offset
, ~mask
);
1213 pb_addr
= (mmTPC2_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1214 word_offset
= ((mmTPC2_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1215 mask
= 1 << ((mmTPC2_CMDQ_CQ_CFG0
& 0x7F) >> 2);
1216 mask
|= 1 << ((mmTPC2_CMDQ_CQ_CFG1
& 0x7F) >> 2);
1217 mask
|= 1 << ((mmTPC2_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
1218 mask
|= 1 << ((mmTPC2_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
1219 mask
|= 1 << ((mmTPC2_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
1220 mask
|= 1 << ((mmTPC2_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
1221 mask
|= 1 << ((mmTPC2_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
1222 mask
|= 1 << ((mmTPC2_CMDQ_CQ_STS0
& 0x7F) >> 2);
1223 mask
|= 1 << ((mmTPC2_CMDQ_CQ_STS1
& 0x7F) >> 2);
1224 mask
|= 1 << ((mmTPC2_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1225 mask
|= 1 << ((mmTPC2_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1226 mask
|= 1 << ((mmTPC2_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1227 mask
|= 1 << ((mmTPC2_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1229 WREG32(pb_addr
+ word_offset
, ~mask
);
1231 pb_addr
= (mmTPC2_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1232 word_offset
= ((mmTPC2_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1233 mask
= 1 << ((mmTPC2_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
1234 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1235 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1236 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1237 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1238 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1239 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1240 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1241 mask
|= 1 << ((mmTPC2_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1242 mask
|= 1 << ((mmTPC2_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1243 mask
|= 1 << ((mmTPC2_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1244 mask
|= 1 << ((mmTPC2_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1245 mask
|= 1 << ((mmTPC2_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1246 mask
|= 1 << ((mmTPC2_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1247 mask
|= 1 << ((mmTPC2_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1248 mask
|= 1 << ((mmTPC2_CMDQ_CP_STS
& 0x7F) >> 2);
1249 mask
|= 1 << ((mmTPC2_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
1251 WREG32(pb_addr
+ word_offset
, ~mask
);
1253 pb_addr
= (mmTPC2_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
1254 word_offset
= ((mmTPC2_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
1256 mask
= 1 << ((mmTPC2_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
1257 mask
|= 1 << ((mmTPC2_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
1258 mask
|= 1 << ((mmTPC2_CMDQ_CP_DBG_0
& 0x7F) >> 2);
1259 mask
|= 1 << ((mmTPC2_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
1260 mask
|= 1 << ((mmTPC2_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
1262 WREG32(pb_addr
+ word_offset
, ~mask
);
1264 goya_pb_set_block(hdev
, mmTPC3_RTR_BASE
);
1265 goya_pb_set_block(hdev
, mmTPC3_RD_REGULATOR_BASE
);
1266 goya_pb_set_block(hdev
, mmTPC3_WR_REGULATOR_BASE
);
1268 pb_addr
= (mmTPC3_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
1269 word_offset
= ((mmTPC3_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
1271 mask
= 1 << ((mmTPC3_CFG_SEMAPHORE
& 0x7F) >> 2);
1272 mask
|= 1 << ((mmTPC3_CFG_VFLAGS
& 0x7F) >> 2);
1273 mask
|= 1 << ((mmTPC3_CFG_SFLAGS
& 0x7F) >> 2);
1274 mask
|= 1 << ((mmTPC3_CFG_STATUS
& 0x7F) >> 2);
1276 WREG32(pb_addr
+ word_offset
, ~mask
);
1278 pb_addr
= (mmTPC3_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
1279 word_offset
= ((mmTPC3_CFG_CFG_BASE_ADDRESS_HIGH
1280 & PROT_BITS_OFFS
) >> 7) << 2;
1281 mask
= 1 << ((mmTPC3_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1282 mask
|= 1 << ((mmTPC3_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
1283 mask
|= 1 << ((mmTPC3_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
1284 mask
|= 1 << ((mmTPC3_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1285 mask
|= 1 << ((mmTPC3_CFG_TPC_STALL
& 0x7F) >> 2);
1286 mask
|= 1 << ((mmTPC3_CFG_MSS_CONFIG
& 0x7F) >> 2);
1287 mask
|= 1 << ((mmTPC3_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
1288 mask
|= 1 << ((mmTPC3_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
1290 WREG32(pb_addr
+ word_offset
, ~mask
);
1292 pb_addr
= (mmTPC3_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
1293 word_offset
= ((mmTPC3_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
1294 mask
= 1 << ((mmTPC3_CFG_ARUSER
& 0x7F) >> 2);
1295 mask
|= 1 << ((mmTPC3_CFG_AWUSER
& 0x7F) >> 2);
1297 WREG32(pb_addr
+ word_offset
, ~mask
);
1299 pb_addr
= (mmTPC3_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
1300 word_offset
= ((mmTPC3_CFG_FUNC_MBIST_CNTRL
1301 & PROT_BITS_OFFS
) >> 7) << 2;
1302 mask
= 1 << ((mmTPC3_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
1303 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
1304 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
1305 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
1306 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
1307 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
1308 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
1309 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
1310 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
1311 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
1312 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
1313 mask
|= 1 << ((mmTPC3_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
1315 WREG32(pb_addr
+ word_offset
, ~mask
);
1317 pb_addr
= (mmTPC3_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1318 word_offset
= ((mmTPC3_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1319 mask
= 1 << ((mmTPC3_QM_GLBL_CFG0
& 0x7F) >> 2);
1320 mask
|= 1 << ((mmTPC3_QM_GLBL_CFG1
& 0x7F) >> 2);
1321 mask
|= 1 << ((mmTPC3_QM_GLBL_PROT
& 0x7F) >> 2);
1322 mask
|= 1 << ((mmTPC3_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
1323 mask
|= 1 << ((mmTPC3_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1324 mask
|= 1 << ((mmTPC3_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1325 mask
|= 1 << ((mmTPC3_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
1326 mask
|= 1 << ((mmTPC3_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1327 mask
|= 1 << ((mmTPC3_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1328 mask
|= 1 << ((mmTPC3_QM_GLBL_STS0
& 0x7F) >> 2);
1329 mask
|= 1 << ((mmTPC3_QM_GLBL_STS1
& 0x7F) >> 2);
1330 mask
|= 1 << ((mmTPC3_QM_PQ_BASE_LO
& 0x7F) >> 2);
1331 mask
|= 1 << ((mmTPC3_QM_PQ_BASE_HI
& 0x7F) >> 2);
1332 mask
|= 1 << ((mmTPC3_QM_PQ_SIZE
& 0x7F) >> 2);
1333 mask
|= 1 << ((mmTPC3_QM_PQ_PI
& 0x7F) >> 2);
1334 mask
|= 1 << ((mmTPC3_QM_PQ_CI
& 0x7F) >> 2);
1335 mask
|= 1 << ((mmTPC3_QM_PQ_CFG0
& 0x7F) >> 2);
1336 mask
|= 1 << ((mmTPC3_QM_PQ_CFG1
& 0x7F) >> 2);
1337 mask
|= 1 << ((mmTPC3_QM_PQ_ARUSER
& 0x7F) >> 2);
1339 WREG32(pb_addr
+ word_offset
, ~mask
);
1341 pb_addr
= (mmTPC3_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
1342 word_offset
= ((mmTPC3_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
1343 mask
= 1 << ((mmTPC3_QM_PQ_PUSH0
& 0x7F) >> 2);
1344 mask
|= 1 << ((mmTPC3_QM_PQ_PUSH1
& 0x7F) >> 2);
1345 mask
|= 1 << ((mmTPC3_QM_PQ_PUSH2
& 0x7F) >> 2);
1346 mask
|= 1 << ((mmTPC3_QM_PQ_PUSH3
& 0x7F) >> 2);
1347 mask
|= 1 << ((mmTPC3_QM_PQ_STS0
& 0x7F) >> 2);
1348 mask
|= 1 << ((mmTPC3_QM_PQ_STS1
& 0x7F) >> 2);
1349 mask
|= 1 << ((mmTPC3_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1350 mask
|= 1 << ((mmTPC3_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1351 mask
|= 1 << ((mmTPC3_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1352 mask
|= 1 << ((mmTPC3_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1353 mask
|= 1 << ((mmTPC3_QM_CQ_CFG0
& 0x7F) >> 2);
1354 mask
|= 1 << ((mmTPC3_QM_CQ_CFG1
& 0x7F) >> 2);
1355 mask
|= 1 << ((mmTPC3_QM_CQ_ARUSER
& 0x7F) >> 2);
1356 mask
|= 1 << ((mmTPC3_QM_CQ_PTR_LO
& 0x7F) >> 2);
1357 mask
|= 1 << ((mmTPC3_QM_CQ_PTR_HI
& 0x7F) >> 2);
1358 mask
|= 1 << ((mmTPC3_QM_CQ_TSIZE
& 0x7F) >> 2);
1359 mask
|= 1 << ((mmTPC3_QM_CQ_CTL
& 0x7F) >> 2);
1360 mask
|= 1 << ((mmTPC3_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
1361 mask
|= 1 << ((mmTPC3_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
1362 mask
|= 1 << ((mmTPC3_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
1363 mask
|= 1 << ((mmTPC3_QM_CQ_CTL_STS
& 0x7F) >> 2);
1364 mask
|= 1 << ((mmTPC3_QM_CQ_STS0
& 0x7F) >> 2);
1365 mask
|= 1 << ((mmTPC3_QM_CQ_STS1
& 0x7F) >> 2);
1366 mask
|= 1 << ((mmTPC3_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1367 mask
|= 1 << ((mmTPC3_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1368 mask
|= 1 << ((mmTPC3_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1369 mask
|= 1 << ((mmTPC3_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1371 WREG32(pb_addr
+ word_offset
, ~mask
);
1373 pb_addr
= (mmTPC3_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1374 word_offset
= ((mmTPC3_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1375 mask
= 1 << ((mmTPC3_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
1376 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1377 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1378 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1379 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1380 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1381 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1382 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1383 mask
|= 1 << ((mmTPC3_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1384 mask
|= 1 << ((mmTPC3_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1385 mask
|= 1 << ((mmTPC3_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1386 mask
|= 1 << ((mmTPC3_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1387 mask
|= 1 << ((mmTPC3_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1388 mask
|= 1 << ((mmTPC3_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1389 mask
|= 1 << ((mmTPC3_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1391 WREG32(pb_addr
+ word_offset
, ~mask
);
1393 pb_addr
= (mmTPC3_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1394 word_offset
= ((mmTPC3_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1395 mask
= 1 << ((mmTPC3_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
1396 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
1397 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_PROT
& 0x7F) >> 2);
1398 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
1399 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1400 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1401 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
1402 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1403 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1404 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_STS0
& 0x7F) >> 2);
1405 mask
|= 1 << ((mmTPC3_CMDQ_GLBL_STS1
& 0x7F) >> 2);
1407 WREG32(pb_addr
+ word_offset
, ~mask
);
1409 pb_addr
= (mmTPC3_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1410 word_offset
= ((mmTPC3_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1411 mask
= 1 << ((mmTPC3_CMDQ_CQ_CFG0
& 0x7F) >> 2);
1412 mask
|= 1 << ((mmTPC3_CMDQ_CQ_CFG1
& 0x7F) >> 2);
1413 mask
|= 1 << ((mmTPC3_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
1414 mask
|= 1 << ((mmTPC3_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
1415 mask
|= 1 << ((mmTPC3_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
1416 mask
|= 1 << ((mmTPC3_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
1417 mask
|= 1 << ((mmTPC3_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
1418 mask
|= 1 << ((mmTPC3_CMDQ_CQ_STS0
& 0x7F) >> 2);
1419 mask
|= 1 << ((mmTPC3_CMDQ_CQ_STS1
& 0x7F) >> 2);
1420 mask
|= 1 << ((mmTPC3_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1421 mask
|= 1 << ((mmTPC3_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1422 mask
|= 1 << ((mmTPC3_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1423 mask
|= 1 << ((mmTPC3_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1425 WREG32(pb_addr
+ word_offset
, ~mask
);
1427 pb_addr
= (mmTPC3_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1428 word_offset
= ((mmTPC3_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1429 mask
= 1 << ((mmTPC3_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
1430 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1431 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1432 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1433 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1434 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1435 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1436 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1437 mask
|= 1 << ((mmTPC3_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1438 mask
|= 1 << ((mmTPC3_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1439 mask
|= 1 << ((mmTPC3_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1440 mask
|= 1 << ((mmTPC3_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1441 mask
|= 1 << ((mmTPC3_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1442 mask
|= 1 << ((mmTPC3_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1443 mask
|= 1 << ((mmTPC3_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1444 mask
|= 1 << ((mmTPC3_CMDQ_CP_STS
& 0x7F) >> 2);
1445 mask
|= 1 << ((mmTPC3_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
1447 WREG32(pb_addr
+ word_offset
, ~mask
);
1449 pb_addr
= (mmTPC3_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
1450 word_offset
= ((mmTPC3_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
1452 mask
= 1 << ((mmTPC3_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
1453 mask
|= 1 << ((mmTPC3_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
1454 mask
|= 1 << ((mmTPC3_CMDQ_CP_DBG_0
& 0x7F) >> 2);
1455 mask
|= 1 << ((mmTPC3_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
1456 mask
|= 1 << ((mmTPC3_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
1458 WREG32(pb_addr
+ word_offset
, ~mask
);
1460 goya_pb_set_block(hdev
, mmTPC4_RTR_BASE
);
1461 goya_pb_set_block(hdev
, mmTPC4_RD_REGULATOR_BASE
);
1462 goya_pb_set_block(hdev
, mmTPC4_WR_REGULATOR_BASE
);
1464 pb_addr
= (mmTPC4_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
1465 word_offset
= ((mmTPC4_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
1467 mask
= 1 << ((mmTPC4_CFG_SEMAPHORE
& 0x7F) >> 2);
1468 mask
|= 1 << ((mmTPC4_CFG_VFLAGS
& 0x7F) >> 2);
1469 mask
|= 1 << ((mmTPC4_CFG_SFLAGS
& 0x7F) >> 2);
1470 mask
|= 1 << ((mmTPC4_CFG_STATUS
& 0x7F) >> 2);
1472 WREG32(pb_addr
+ word_offset
, ~mask
);
1474 pb_addr
= (mmTPC4_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
1475 word_offset
= ((mmTPC4_CFG_CFG_BASE_ADDRESS_HIGH
&
1476 PROT_BITS_OFFS
) >> 7) << 2;
1477 mask
= 1 << ((mmTPC4_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1478 mask
|= 1 << ((mmTPC4_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
1479 mask
|= 1 << ((mmTPC4_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
1480 mask
|= 1 << ((mmTPC4_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1481 mask
|= 1 << ((mmTPC4_CFG_TPC_STALL
& 0x7F) >> 2);
1482 mask
|= 1 << ((mmTPC4_CFG_MSS_CONFIG
& 0x7F) >> 2);
1483 mask
|= 1 << ((mmTPC4_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
1484 mask
|= 1 << ((mmTPC4_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
1486 WREG32(pb_addr
+ word_offset
, ~mask
);
1488 pb_addr
= (mmTPC4_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
1489 word_offset
= ((mmTPC4_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
1490 mask
= 1 << ((mmTPC4_CFG_ARUSER
& 0x7F) >> 2);
1491 mask
|= 1 << ((mmTPC4_CFG_AWUSER
& 0x7F) >> 2);
1493 WREG32(pb_addr
+ word_offset
, ~mask
);
1495 pb_addr
= (mmTPC4_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
1496 word_offset
= ((mmTPC4_CFG_FUNC_MBIST_CNTRL
&
1497 PROT_BITS_OFFS
) >> 7) << 2;
1498 mask
= 1 << ((mmTPC4_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
1499 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
1500 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
1501 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
1502 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
1503 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
1504 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
1505 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
1506 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
1507 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
1508 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
1509 mask
|= 1 << ((mmTPC4_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
1511 WREG32(pb_addr
+ word_offset
, ~mask
);
1513 pb_addr
= (mmTPC4_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1514 word_offset
= ((mmTPC4_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1515 mask
= 1 << ((mmTPC4_QM_GLBL_CFG0
& 0x7F) >> 2);
1516 mask
|= 1 << ((mmTPC4_QM_GLBL_CFG1
& 0x7F) >> 2);
1517 mask
|= 1 << ((mmTPC4_QM_GLBL_PROT
& 0x7F) >> 2);
1518 mask
|= 1 << ((mmTPC4_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
1519 mask
|= 1 << ((mmTPC4_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1520 mask
|= 1 << ((mmTPC4_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1521 mask
|= 1 << ((mmTPC4_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
1522 mask
|= 1 << ((mmTPC4_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1523 mask
|= 1 << ((mmTPC4_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1524 mask
|= 1 << ((mmTPC4_QM_GLBL_STS0
& 0x7F) >> 2);
1525 mask
|= 1 << ((mmTPC4_QM_GLBL_STS1
& 0x7F) >> 2);
1526 mask
|= 1 << ((mmTPC4_QM_PQ_BASE_LO
& 0x7F) >> 2);
1527 mask
|= 1 << ((mmTPC4_QM_PQ_BASE_HI
& 0x7F) >> 2);
1528 mask
|= 1 << ((mmTPC4_QM_PQ_SIZE
& 0x7F) >> 2);
1529 mask
|= 1 << ((mmTPC4_QM_PQ_PI
& 0x7F) >> 2);
1530 mask
|= 1 << ((mmTPC4_QM_PQ_CI
& 0x7F) >> 2);
1531 mask
|= 1 << ((mmTPC4_QM_PQ_CFG0
& 0x7F) >> 2);
1532 mask
|= 1 << ((mmTPC4_QM_PQ_CFG1
& 0x7F) >> 2);
1533 mask
|= 1 << ((mmTPC4_QM_PQ_ARUSER
& 0x7F) >> 2);
1535 WREG32(pb_addr
+ word_offset
, ~mask
);
1537 pb_addr
= (mmTPC4_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
1538 word_offset
= ((mmTPC4_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
1539 mask
= 1 << ((mmTPC4_QM_PQ_PUSH0
& 0x7F) >> 2);
1540 mask
|= 1 << ((mmTPC4_QM_PQ_PUSH1
& 0x7F) >> 2);
1541 mask
|= 1 << ((mmTPC4_QM_PQ_PUSH2
& 0x7F) >> 2);
1542 mask
|= 1 << ((mmTPC4_QM_PQ_PUSH3
& 0x7F) >> 2);
1543 mask
|= 1 << ((mmTPC4_QM_PQ_STS0
& 0x7F) >> 2);
1544 mask
|= 1 << ((mmTPC4_QM_PQ_STS1
& 0x7F) >> 2);
1545 mask
|= 1 << ((mmTPC4_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1546 mask
|= 1 << ((mmTPC4_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1547 mask
|= 1 << ((mmTPC4_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1548 mask
|= 1 << ((mmTPC4_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1549 mask
|= 1 << ((mmTPC4_QM_CQ_CFG0
& 0x7F) >> 2);
1550 mask
|= 1 << ((mmTPC4_QM_CQ_CFG1
& 0x7F) >> 2);
1551 mask
|= 1 << ((mmTPC4_QM_CQ_ARUSER
& 0x7F) >> 2);
1552 mask
|= 1 << ((mmTPC4_QM_CQ_PTR_LO
& 0x7F) >> 2);
1553 mask
|= 1 << ((mmTPC4_QM_CQ_PTR_HI
& 0x7F) >> 2);
1554 mask
|= 1 << ((mmTPC4_QM_CQ_TSIZE
& 0x7F) >> 2);
1555 mask
|= 1 << ((mmTPC4_QM_CQ_CTL
& 0x7F) >> 2);
1556 mask
|= 1 << ((mmTPC4_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
1557 mask
|= 1 << ((mmTPC4_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
1558 mask
|= 1 << ((mmTPC4_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
1559 mask
|= 1 << ((mmTPC4_QM_CQ_CTL_STS
& 0x7F) >> 2);
1560 mask
|= 1 << ((mmTPC4_QM_CQ_STS0
& 0x7F) >> 2);
1561 mask
|= 1 << ((mmTPC4_QM_CQ_STS1
& 0x7F) >> 2);
1562 mask
|= 1 << ((mmTPC4_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1563 mask
|= 1 << ((mmTPC4_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1564 mask
|= 1 << ((mmTPC4_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1565 mask
|= 1 << ((mmTPC4_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1567 WREG32(pb_addr
+ word_offset
, ~mask
);
1569 pb_addr
= (mmTPC4_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1570 word_offset
= ((mmTPC4_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1571 mask
= 1 << ((mmTPC4_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
1572 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1573 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1574 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1575 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1576 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1577 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1578 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1579 mask
|= 1 << ((mmTPC4_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1580 mask
|= 1 << ((mmTPC4_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1581 mask
|= 1 << ((mmTPC4_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1582 mask
|= 1 << ((mmTPC4_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1583 mask
|= 1 << ((mmTPC4_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1584 mask
|= 1 << ((mmTPC4_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1585 mask
|= 1 << ((mmTPC4_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1587 WREG32(pb_addr
+ word_offset
, ~mask
);
1589 pb_addr
= (mmTPC4_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1590 word_offset
= ((mmTPC4_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1591 mask
= 1 << ((mmTPC4_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
1592 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
1593 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_PROT
& 0x7F) >> 2);
1594 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
1595 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1596 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1597 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
1598 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1599 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1600 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_STS0
& 0x7F) >> 2);
1601 mask
|= 1 << ((mmTPC4_CMDQ_GLBL_STS1
& 0x7F) >> 2);
1603 WREG32(pb_addr
+ word_offset
, ~mask
);
1605 pb_addr
= (mmTPC4_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1606 word_offset
= ((mmTPC4_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1607 mask
= 1 << ((mmTPC4_CMDQ_CQ_CFG0
& 0x7F) >> 2);
1608 mask
|= 1 << ((mmTPC4_CMDQ_CQ_CFG1
& 0x7F) >> 2);
1609 mask
|= 1 << ((mmTPC4_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
1610 mask
|= 1 << ((mmTPC4_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
1611 mask
|= 1 << ((mmTPC4_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
1612 mask
|= 1 << ((mmTPC4_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
1613 mask
|= 1 << ((mmTPC4_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
1614 mask
|= 1 << ((mmTPC4_CMDQ_CQ_STS0
& 0x7F) >> 2);
1615 mask
|= 1 << ((mmTPC4_CMDQ_CQ_STS1
& 0x7F) >> 2);
1616 mask
|= 1 << ((mmTPC4_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1617 mask
|= 1 << ((mmTPC4_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1618 mask
|= 1 << ((mmTPC4_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1619 mask
|= 1 << ((mmTPC4_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1621 WREG32(pb_addr
+ word_offset
, ~mask
);
1623 pb_addr
= (mmTPC4_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1624 word_offset
= ((mmTPC4_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1625 mask
= 1 << ((mmTPC4_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
1626 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1627 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1628 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1629 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1630 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1631 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1632 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1633 mask
|= 1 << ((mmTPC4_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1634 mask
|= 1 << ((mmTPC4_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1635 mask
|= 1 << ((mmTPC4_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1636 mask
|= 1 << ((mmTPC4_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1637 mask
|= 1 << ((mmTPC4_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1638 mask
|= 1 << ((mmTPC4_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1639 mask
|= 1 << ((mmTPC4_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1640 mask
|= 1 << ((mmTPC4_CMDQ_CP_STS
& 0x7F) >> 2);
1641 mask
|= 1 << ((mmTPC4_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
1643 WREG32(pb_addr
+ word_offset
, ~mask
);
1645 pb_addr
= (mmTPC4_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
1646 word_offset
= ((mmTPC4_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
1648 mask
= 1 << ((mmTPC4_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
1649 mask
|= 1 << ((mmTPC4_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
1650 mask
|= 1 << ((mmTPC4_CMDQ_CP_DBG_0
& 0x7F) >> 2);
1651 mask
|= 1 << ((mmTPC4_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
1652 mask
|= 1 << ((mmTPC4_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
1654 WREG32(pb_addr
+ word_offset
, ~mask
);
1656 goya_pb_set_block(hdev
, mmTPC5_RTR_BASE
);
1657 goya_pb_set_block(hdev
, mmTPC5_RD_REGULATOR_BASE
);
1658 goya_pb_set_block(hdev
, mmTPC5_WR_REGULATOR_BASE
);
1660 pb_addr
= (mmTPC5_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
1661 word_offset
= ((mmTPC5_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
1663 mask
= 1 << ((mmTPC5_CFG_SEMAPHORE
& 0x7F) >> 2);
1664 mask
|= 1 << ((mmTPC5_CFG_VFLAGS
& 0x7F) >> 2);
1665 mask
|= 1 << ((mmTPC5_CFG_SFLAGS
& 0x7F) >> 2);
1666 mask
|= 1 << ((mmTPC5_CFG_STATUS
& 0x7F) >> 2);
1668 WREG32(pb_addr
+ word_offset
, ~mask
);
1670 pb_addr
= (mmTPC5_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
1671 word_offset
= ((mmTPC5_CFG_CFG_BASE_ADDRESS_HIGH
&
1672 PROT_BITS_OFFS
) >> 7) << 2;
1673 mask
= 1 << ((mmTPC5_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1674 mask
|= 1 << ((mmTPC5_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
1675 mask
|= 1 << ((mmTPC5_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
1676 mask
|= 1 << ((mmTPC5_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1677 mask
|= 1 << ((mmTPC5_CFG_TPC_STALL
& 0x7F) >> 2);
1678 mask
|= 1 << ((mmTPC5_CFG_MSS_CONFIG
& 0x7F) >> 2);
1679 mask
|= 1 << ((mmTPC5_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
1680 mask
|= 1 << ((mmTPC5_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
1682 WREG32(pb_addr
+ word_offset
, ~mask
);
1684 pb_addr
= (mmTPC5_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
1685 word_offset
= ((mmTPC5_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
1686 mask
= 1 << ((mmTPC5_CFG_ARUSER
& 0x7F) >> 2);
1687 mask
|= 1 << ((mmTPC5_CFG_AWUSER
& 0x7F) >> 2);
1689 WREG32(pb_addr
+ word_offset
, ~mask
);
1691 pb_addr
= (mmTPC5_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
1692 word_offset
= ((mmTPC5_CFG_FUNC_MBIST_CNTRL
&
1693 PROT_BITS_OFFS
) >> 7) << 2;
1694 mask
= 1 << ((mmTPC5_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
1695 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
1696 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
1697 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
1698 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
1699 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
1700 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
1701 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
1702 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
1703 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
1704 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
1705 mask
|= 1 << ((mmTPC5_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
1707 WREG32(pb_addr
+ word_offset
, ~mask
);
1709 pb_addr
= (mmTPC5_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1710 word_offset
= ((mmTPC5_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1711 mask
= 1 << ((mmTPC5_QM_GLBL_CFG0
& 0x7F) >> 2);
1712 mask
|= 1 << ((mmTPC5_QM_GLBL_CFG1
& 0x7F) >> 2);
1713 mask
|= 1 << ((mmTPC5_QM_GLBL_PROT
& 0x7F) >> 2);
1714 mask
|= 1 << ((mmTPC5_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
1715 mask
|= 1 << ((mmTPC5_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1716 mask
|= 1 << ((mmTPC5_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1717 mask
|= 1 << ((mmTPC5_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
1718 mask
|= 1 << ((mmTPC5_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1719 mask
|= 1 << ((mmTPC5_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1720 mask
|= 1 << ((mmTPC5_QM_GLBL_STS0
& 0x7F) >> 2);
1721 mask
|= 1 << ((mmTPC5_QM_GLBL_STS1
& 0x7F) >> 2);
1722 mask
|= 1 << ((mmTPC5_QM_PQ_BASE_LO
& 0x7F) >> 2);
1723 mask
|= 1 << ((mmTPC5_QM_PQ_BASE_HI
& 0x7F) >> 2);
1724 mask
|= 1 << ((mmTPC5_QM_PQ_SIZE
& 0x7F) >> 2);
1725 mask
|= 1 << ((mmTPC5_QM_PQ_PI
& 0x7F) >> 2);
1726 mask
|= 1 << ((mmTPC5_QM_PQ_CI
& 0x7F) >> 2);
1727 mask
|= 1 << ((mmTPC5_QM_PQ_CFG0
& 0x7F) >> 2);
1728 mask
|= 1 << ((mmTPC5_QM_PQ_CFG1
& 0x7F) >> 2);
1729 mask
|= 1 << ((mmTPC5_QM_PQ_ARUSER
& 0x7F) >> 2);
1731 WREG32(pb_addr
+ word_offset
, ~mask
);
1733 pb_addr
= (mmTPC5_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
1734 word_offset
= ((mmTPC5_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
1735 mask
= 1 << ((mmTPC5_QM_PQ_PUSH0
& 0x7F) >> 2);
1736 mask
|= 1 << ((mmTPC5_QM_PQ_PUSH1
& 0x7F) >> 2);
1737 mask
|= 1 << ((mmTPC5_QM_PQ_PUSH2
& 0x7F) >> 2);
1738 mask
|= 1 << ((mmTPC5_QM_PQ_PUSH3
& 0x7F) >> 2);
1739 mask
|= 1 << ((mmTPC5_QM_PQ_STS0
& 0x7F) >> 2);
1740 mask
|= 1 << ((mmTPC5_QM_PQ_STS1
& 0x7F) >> 2);
1741 mask
|= 1 << ((mmTPC5_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1742 mask
|= 1 << ((mmTPC5_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1743 mask
|= 1 << ((mmTPC5_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1744 mask
|= 1 << ((mmTPC5_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1745 mask
|= 1 << ((mmTPC5_QM_CQ_CFG0
& 0x7F) >> 2);
1746 mask
|= 1 << ((mmTPC5_QM_CQ_CFG1
& 0x7F) >> 2);
1747 mask
|= 1 << ((mmTPC5_QM_CQ_ARUSER
& 0x7F) >> 2);
1748 mask
|= 1 << ((mmTPC5_QM_CQ_PTR_LO
& 0x7F) >> 2);
1749 mask
|= 1 << ((mmTPC5_QM_CQ_PTR_HI
& 0x7F) >> 2);
1750 mask
|= 1 << ((mmTPC5_QM_CQ_TSIZE
& 0x7F) >> 2);
1751 mask
|= 1 << ((mmTPC5_QM_CQ_CTL
& 0x7F) >> 2);
1752 mask
|= 1 << ((mmTPC5_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
1753 mask
|= 1 << ((mmTPC5_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
1754 mask
|= 1 << ((mmTPC5_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
1755 mask
|= 1 << ((mmTPC5_QM_CQ_CTL_STS
& 0x7F) >> 2);
1756 mask
|= 1 << ((mmTPC5_QM_CQ_STS0
& 0x7F) >> 2);
1757 mask
|= 1 << ((mmTPC5_QM_CQ_STS1
& 0x7F) >> 2);
1758 mask
|= 1 << ((mmTPC5_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1759 mask
|= 1 << ((mmTPC5_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1760 mask
|= 1 << ((mmTPC5_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1761 mask
|= 1 << ((mmTPC5_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1763 WREG32(pb_addr
+ word_offset
, ~mask
);
1765 pb_addr
= (mmTPC5_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1766 word_offset
= ((mmTPC5_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1767 mask
= 1 << ((mmTPC5_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
1768 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1769 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1770 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1771 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1772 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1773 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1774 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1775 mask
|= 1 << ((mmTPC5_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1776 mask
|= 1 << ((mmTPC5_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1777 mask
|= 1 << ((mmTPC5_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1778 mask
|= 1 << ((mmTPC5_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1779 mask
|= 1 << ((mmTPC5_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1780 mask
|= 1 << ((mmTPC5_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1781 mask
|= 1 << ((mmTPC5_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1783 WREG32(pb_addr
+ word_offset
, ~mask
);
1785 pb_addr
= (mmTPC5_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1786 word_offset
= ((mmTPC5_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1787 mask
= 1 << ((mmTPC5_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
1788 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
1789 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_PROT
& 0x7F) >> 2);
1790 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
1791 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1792 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1793 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
1794 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1795 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1796 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_STS0
& 0x7F) >> 2);
1797 mask
|= 1 << ((mmTPC5_CMDQ_GLBL_STS1
& 0x7F) >> 2);
1799 WREG32(pb_addr
+ word_offset
, ~mask
);
1801 pb_addr
= (mmTPC5_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1802 word_offset
= ((mmTPC5_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1803 mask
= 1 << ((mmTPC5_CMDQ_CQ_CFG0
& 0x7F) >> 2);
1804 mask
|= 1 << ((mmTPC5_CMDQ_CQ_CFG1
& 0x7F) >> 2);
1805 mask
|= 1 << ((mmTPC5_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
1806 mask
|= 1 << ((mmTPC5_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
1807 mask
|= 1 << ((mmTPC5_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
1808 mask
|= 1 << ((mmTPC5_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
1809 mask
|= 1 << ((mmTPC5_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
1810 mask
|= 1 << ((mmTPC5_CMDQ_CQ_STS0
& 0x7F) >> 2);
1811 mask
|= 1 << ((mmTPC5_CMDQ_CQ_STS1
& 0x7F) >> 2);
1812 mask
|= 1 << ((mmTPC5_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1813 mask
|= 1 << ((mmTPC5_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1814 mask
|= 1 << ((mmTPC5_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1815 mask
|= 1 << ((mmTPC5_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1817 WREG32(pb_addr
+ word_offset
, ~mask
);
1819 pb_addr
= (mmTPC5_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1820 word_offset
= ((mmTPC5_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1821 mask
= 1 << ((mmTPC5_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
1822 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1823 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1824 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1825 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1826 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1827 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1828 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1829 mask
|= 1 << ((mmTPC5_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1830 mask
|= 1 << ((mmTPC5_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1831 mask
|= 1 << ((mmTPC5_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1832 mask
|= 1 << ((mmTPC5_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1833 mask
|= 1 << ((mmTPC5_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1834 mask
|= 1 << ((mmTPC5_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1835 mask
|= 1 << ((mmTPC5_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1836 mask
|= 1 << ((mmTPC5_CMDQ_CP_STS
& 0x7F) >> 2);
1837 mask
|= 1 << ((mmTPC5_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
1839 WREG32(pb_addr
+ word_offset
, ~mask
);
1841 pb_addr
= (mmTPC5_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
1842 word_offset
= ((mmTPC5_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
1844 mask
= 1 << ((mmTPC5_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
1845 mask
|= 1 << ((mmTPC5_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
1846 mask
|= 1 << ((mmTPC5_CMDQ_CP_DBG_0
& 0x7F) >> 2);
1847 mask
|= 1 << ((mmTPC5_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
1848 mask
|= 1 << ((mmTPC5_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
1850 WREG32(pb_addr
+ word_offset
, ~mask
);
1852 goya_pb_set_block(hdev
, mmTPC6_RTR_BASE
);
1853 goya_pb_set_block(hdev
, mmTPC6_RD_REGULATOR_BASE
);
1854 goya_pb_set_block(hdev
, mmTPC6_WR_REGULATOR_BASE
);
1856 pb_addr
= (mmTPC6_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
1857 word_offset
= ((mmTPC6_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
1859 mask
= 1 << ((mmTPC6_CFG_SEMAPHORE
& 0x7F) >> 2);
1860 mask
|= 1 << ((mmTPC6_CFG_VFLAGS
& 0x7F) >> 2);
1861 mask
|= 1 << ((mmTPC6_CFG_SFLAGS
& 0x7F) >> 2);
1862 mask
|= 1 << ((mmTPC6_CFG_STATUS
& 0x7F) >> 2);
1864 WREG32(pb_addr
+ word_offset
, ~mask
);
1866 pb_addr
= (mmTPC6_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
1867 word_offset
= ((mmTPC6_CFG_CFG_BASE_ADDRESS_HIGH
&
1868 PROT_BITS_OFFS
) >> 7) << 2;
1869 mask
= 1 << ((mmTPC6_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1870 mask
|= 1 << ((mmTPC6_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
1871 mask
|= 1 << ((mmTPC6_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
1872 mask
|= 1 << ((mmTPC6_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
1873 mask
|= 1 << ((mmTPC6_CFG_TPC_STALL
& 0x7F) >> 2);
1874 mask
|= 1 << ((mmTPC6_CFG_MSS_CONFIG
& 0x7F) >> 2);
1875 mask
|= 1 << ((mmTPC6_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
1876 mask
|= 1 << ((mmTPC6_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
1878 WREG32(pb_addr
+ word_offset
, ~mask
);
1880 pb_addr
= (mmTPC6_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
1881 word_offset
= ((mmTPC6_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
1882 mask
= 1 << ((mmTPC6_CFG_ARUSER
& 0x7F) >> 2);
1883 mask
|= 1 << ((mmTPC6_CFG_AWUSER
& 0x7F) >> 2);
1885 WREG32(pb_addr
+ word_offset
, ~mask
);
1887 pb_addr
= (mmTPC6_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
1888 word_offset
= ((mmTPC6_CFG_FUNC_MBIST_CNTRL
&
1889 PROT_BITS_OFFS
) >> 7) << 2;
1890 mask
= 1 << ((mmTPC6_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
1891 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
1892 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
1893 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
1894 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
1895 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
1896 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
1897 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
1898 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
1899 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
1900 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
1901 mask
|= 1 << ((mmTPC6_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
1903 WREG32(pb_addr
+ word_offset
, ~mask
);
1905 pb_addr
= (mmTPC6_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1906 word_offset
= ((mmTPC6_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1907 mask
= 1 << ((mmTPC6_QM_GLBL_CFG0
& 0x7F) >> 2);
1908 mask
|= 1 << ((mmTPC6_QM_GLBL_CFG1
& 0x7F) >> 2);
1909 mask
|= 1 << ((mmTPC6_QM_GLBL_PROT
& 0x7F) >> 2);
1910 mask
|= 1 << ((mmTPC6_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
1911 mask
|= 1 << ((mmTPC6_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1912 mask
|= 1 << ((mmTPC6_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1913 mask
|= 1 << ((mmTPC6_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
1914 mask
|= 1 << ((mmTPC6_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1915 mask
|= 1 << ((mmTPC6_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1916 mask
|= 1 << ((mmTPC6_QM_GLBL_STS0
& 0x7F) >> 2);
1917 mask
|= 1 << ((mmTPC6_QM_GLBL_STS1
& 0x7F) >> 2);
1918 mask
|= 1 << ((mmTPC6_QM_PQ_BASE_LO
& 0x7F) >> 2);
1919 mask
|= 1 << ((mmTPC6_QM_PQ_BASE_HI
& 0x7F) >> 2);
1920 mask
|= 1 << ((mmTPC6_QM_PQ_SIZE
& 0x7F) >> 2);
1921 mask
|= 1 << ((mmTPC6_QM_PQ_PI
& 0x7F) >> 2);
1922 mask
|= 1 << ((mmTPC6_QM_PQ_CI
& 0x7F) >> 2);
1923 mask
|= 1 << ((mmTPC6_QM_PQ_CFG0
& 0x7F) >> 2);
1924 mask
|= 1 << ((mmTPC6_QM_PQ_CFG1
& 0x7F) >> 2);
1925 mask
|= 1 << ((mmTPC6_QM_PQ_ARUSER
& 0x7F) >> 2);
1927 WREG32(pb_addr
+ word_offset
, ~mask
);
1929 pb_addr
= (mmTPC6_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
1930 word_offset
= ((mmTPC6_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
1931 mask
= 1 << ((mmTPC6_QM_PQ_PUSH0
& 0x7F) >> 2);
1932 mask
|= 1 << ((mmTPC6_QM_PQ_PUSH1
& 0x7F) >> 2);
1933 mask
|= 1 << ((mmTPC6_QM_PQ_PUSH2
& 0x7F) >> 2);
1934 mask
|= 1 << ((mmTPC6_QM_PQ_PUSH3
& 0x7F) >> 2);
1935 mask
|= 1 << ((mmTPC6_QM_PQ_STS0
& 0x7F) >> 2);
1936 mask
|= 1 << ((mmTPC6_QM_PQ_STS1
& 0x7F) >> 2);
1937 mask
|= 1 << ((mmTPC6_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1938 mask
|= 1 << ((mmTPC6_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1939 mask
|= 1 << ((mmTPC6_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1940 mask
|= 1 << ((mmTPC6_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1941 mask
|= 1 << ((mmTPC6_QM_CQ_CFG0
& 0x7F) >> 2);
1942 mask
|= 1 << ((mmTPC6_QM_CQ_CFG1
& 0x7F) >> 2);
1943 mask
|= 1 << ((mmTPC6_QM_CQ_ARUSER
& 0x7F) >> 2);
1944 mask
|= 1 << ((mmTPC6_QM_CQ_PTR_LO
& 0x7F) >> 2);
1945 mask
|= 1 << ((mmTPC6_QM_CQ_PTR_HI
& 0x7F) >> 2);
1946 mask
|= 1 << ((mmTPC6_QM_CQ_TSIZE
& 0x7F) >> 2);
1947 mask
|= 1 << ((mmTPC6_QM_CQ_CTL
& 0x7F) >> 2);
1948 mask
|= 1 << ((mmTPC6_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
1949 mask
|= 1 << ((mmTPC6_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
1950 mask
|= 1 << ((mmTPC6_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
1951 mask
|= 1 << ((mmTPC6_QM_CQ_CTL_STS
& 0x7F) >> 2);
1952 mask
|= 1 << ((mmTPC6_QM_CQ_STS0
& 0x7F) >> 2);
1953 mask
|= 1 << ((mmTPC6_QM_CQ_STS1
& 0x7F) >> 2);
1954 mask
|= 1 << ((mmTPC6_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
1955 mask
|= 1 << ((mmTPC6_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
1956 mask
|= 1 << ((mmTPC6_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
1957 mask
|= 1 << ((mmTPC6_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
1959 WREG32(pb_addr
+ word_offset
, ~mask
);
1961 pb_addr
= (mmTPC6_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
1962 word_offset
= ((mmTPC6_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
1963 mask
= 1 << ((mmTPC6_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
1964 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
1965 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
1966 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
1967 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
1968 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
1969 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
1970 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
1971 mask
|= 1 << ((mmTPC6_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
1972 mask
|= 1 << ((mmTPC6_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
1973 mask
|= 1 << ((mmTPC6_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
1974 mask
|= 1 << ((mmTPC6_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
1975 mask
|= 1 << ((mmTPC6_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
1976 mask
|= 1 << ((mmTPC6_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
1977 mask
|= 1 << ((mmTPC6_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
1979 WREG32(pb_addr
+ word_offset
, ~mask
);
1981 pb_addr
= (mmTPC6_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1982 word_offset
= ((mmTPC6_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1983 mask
= 1 << ((mmTPC6_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
1984 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
1985 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_PROT
& 0x7F) >> 2);
1986 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
1987 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
1988 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
1989 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
1990 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
1991 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
1992 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_STS0
& 0x7F) >> 2);
1993 mask
|= 1 << ((mmTPC6_CMDQ_GLBL_STS1
& 0x7F) >> 2);
1995 WREG32(pb_addr
+ word_offset
, ~mask
);
1997 pb_addr
= (mmTPC6_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
1998 word_offset
= ((mmTPC6_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
1999 mask
= 1 << ((mmTPC6_CMDQ_CQ_CFG0
& 0x7F) >> 2);
2000 mask
|= 1 << ((mmTPC6_CMDQ_CQ_CFG1
& 0x7F) >> 2);
2001 mask
|= 1 << ((mmTPC6_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
2002 mask
|= 1 << ((mmTPC6_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
2003 mask
|= 1 << ((mmTPC6_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
2004 mask
|= 1 << ((mmTPC6_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
2005 mask
|= 1 << ((mmTPC6_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
2006 mask
|= 1 << ((mmTPC6_CMDQ_CQ_STS0
& 0x7F) >> 2);
2007 mask
|= 1 << ((mmTPC6_CMDQ_CQ_STS1
& 0x7F) >> 2);
2008 mask
|= 1 << ((mmTPC6_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
2009 mask
|= 1 << ((mmTPC6_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
2010 mask
|= 1 << ((mmTPC6_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
2011 mask
|= 1 << ((mmTPC6_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
2013 WREG32(pb_addr
+ word_offset
, ~mask
);
2015 pb_addr
= (mmTPC6_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
2016 word_offset
= ((mmTPC6_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
2017 mask
= 1 << ((mmTPC6_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
2018 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
2019 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
2020 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
2021 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
2022 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
2023 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
2024 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
2025 mask
|= 1 << ((mmTPC6_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
2026 mask
|= 1 << ((mmTPC6_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
2027 mask
|= 1 << ((mmTPC6_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
2028 mask
|= 1 << ((mmTPC6_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
2029 mask
|= 1 << ((mmTPC6_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
2030 mask
|= 1 << ((mmTPC6_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
2031 mask
|= 1 << ((mmTPC6_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
2032 mask
|= 1 << ((mmTPC6_CMDQ_CP_STS
& 0x7F) >> 2);
2033 mask
|= 1 << ((mmTPC6_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
2035 WREG32(pb_addr
+ word_offset
, ~mask
);
2037 pb_addr
= (mmTPC6_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
2038 word_offset
= ((mmTPC6_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
2040 mask
= 1 << ((mmTPC6_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
2041 mask
|= 1 << ((mmTPC6_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
2042 mask
|= 1 << ((mmTPC6_CMDQ_CP_DBG_0
& 0x7F) >> 2);
2043 mask
|= 1 << ((mmTPC6_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
2044 mask
|= 1 << ((mmTPC6_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
2046 WREG32(pb_addr
+ word_offset
, ~mask
);
2048 goya_pb_set_block(hdev
, mmTPC7_NRTR_BASE
);
2049 goya_pb_set_block(hdev
, mmTPC7_RD_REGULATOR_BASE
);
2050 goya_pb_set_block(hdev
, mmTPC7_WR_REGULATOR_BASE
);
2052 pb_addr
= (mmTPC7_CFG_SEMAPHORE
& ~0xFFF) + PROT_BITS_OFFS
;
2053 word_offset
= ((mmTPC7_CFG_SEMAPHORE
& PROT_BITS_OFFS
) >> 7) << 2;
2055 mask
= 1 << ((mmTPC7_CFG_SEMAPHORE
& 0x7F) >> 2);
2056 mask
|= 1 << ((mmTPC7_CFG_VFLAGS
& 0x7F) >> 2);
2057 mask
|= 1 << ((mmTPC7_CFG_SFLAGS
& 0x7F) >> 2);
2058 mask
|= 1 << ((mmTPC7_CFG_STATUS
& 0x7F) >> 2);
2060 WREG32(pb_addr
+ word_offset
, ~mask
);
2062 pb_addr
= (mmTPC7_CFG_CFG_BASE_ADDRESS_HIGH
& ~0xFFF) + PROT_BITS_OFFS
;
2063 word_offset
= ((mmTPC7_CFG_CFG_BASE_ADDRESS_HIGH
&
2064 PROT_BITS_OFFS
) >> 7) << 2;
2065 mask
= 1 << ((mmTPC7_CFG_CFG_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
2066 mask
|= 1 << ((mmTPC7_CFG_CFG_SUBTRACT_VALUE
& 0x7F) >> 2);
2067 mask
|= 1 << ((mmTPC7_CFG_SM_BASE_ADDRESS_LOW
& 0x7F) >> 2);
2068 mask
|= 1 << ((mmTPC7_CFG_SM_BASE_ADDRESS_HIGH
& 0x7F) >> 2);
2069 mask
|= 1 << ((mmTPC7_CFG_TPC_STALL
& 0x7F) >> 2);
2070 mask
|= 1 << ((mmTPC7_CFG_MSS_CONFIG
& 0x7F) >> 2);
2071 mask
|= 1 << ((mmTPC7_CFG_TPC_INTR_CAUSE
& 0x7F) >> 2);
2072 mask
|= 1 << ((mmTPC7_CFG_TPC_INTR_MASK
& 0x7F) >> 2);
2074 WREG32(pb_addr
+ word_offset
, ~mask
);
2076 pb_addr
= (mmTPC7_CFG_ARUSER
& ~0xFFF) + PROT_BITS_OFFS
;
2077 word_offset
= ((mmTPC7_CFG_ARUSER
& PROT_BITS_OFFS
) >> 7) << 2;
2078 mask
= 1 << ((mmTPC7_CFG_ARUSER
& 0x7F) >> 2);
2079 mask
|= 1 << ((mmTPC7_CFG_AWUSER
& 0x7F) >> 2);
2081 WREG32(pb_addr
+ word_offset
, ~mask
);
2083 pb_addr
= (mmTPC7_CFG_FUNC_MBIST_CNTRL
& ~0xFFF) + PROT_BITS_OFFS
;
2084 word_offset
= ((mmTPC7_CFG_FUNC_MBIST_CNTRL
&
2085 PROT_BITS_OFFS
) >> 7) << 2;
2086 mask
= 1 << ((mmTPC7_CFG_FUNC_MBIST_CNTRL
& 0x7F) >> 2);
2087 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_PAT
& 0x7F) >> 2);
2088 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_0
& 0x7F) >> 2);
2089 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_1
& 0x7F) >> 2);
2090 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_2
& 0x7F) >> 2);
2091 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_3
& 0x7F) >> 2);
2092 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_4
& 0x7F) >> 2);
2093 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_5
& 0x7F) >> 2);
2094 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_6
& 0x7F) >> 2);
2095 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_7
& 0x7F) >> 2);
2096 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_8
& 0x7F) >> 2);
2097 mask
|= 1 << ((mmTPC7_CFG_FUNC_MBIST_MEM_9
& 0x7F) >> 2);
2099 WREG32(pb_addr
+ word_offset
, ~mask
);
2101 pb_addr
= (mmTPC7_QM_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
2102 word_offset
= ((mmTPC7_QM_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
2103 mask
= 1 << ((mmTPC7_QM_GLBL_CFG0
& 0x7F) >> 2);
2104 mask
|= 1 << ((mmTPC7_QM_GLBL_CFG1
& 0x7F) >> 2);
2105 mask
|= 1 << ((mmTPC7_QM_GLBL_PROT
& 0x7F) >> 2);
2106 mask
|= 1 << ((mmTPC7_QM_GLBL_ERR_CFG
& 0x7F) >> 2);
2107 mask
|= 1 << ((mmTPC7_QM_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
2108 mask
|= 1 << ((mmTPC7_QM_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
2109 mask
|= 1 << ((mmTPC7_QM_GLBL_ERR_WDATA
& 0x7F) >> 2);
2110 mask
|= 1 << ((mmTPC7_QM_GLBL_SECURE_PROPS
& 0x7F) >> 2);
2111 mask
|= 1 << ((mmTPC7_QM_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
2112 mask
|= 1 << ((mmTPC7_QM_GLBL_STS0
& 0x7F) >> 2);
2113 mask
|= 1 << ((mmTPC7_QM_GLBL_STS1
& 0x7F) >> 2);
2114 mask
|= 1 << ((mmTPC7_QM_PQ_BASE_LO
& 0x7F) >> 2);
2115 mask
|= 1 << ((mmTPC7_QM_PQ_BASE_HI
& 0x7F) >> 2);
2116 mask
|= 1 << ((mmTPC7_QM_PQ_SIZE
& 0x7F) >> 2);
2117 mask
|= 1 << ((mmTPC7_QM_PQ_PI
& 0x7F) >> 2);
2118 mask
|= 1 << ((mmTPC7_QM_PQ_CI
& 0x7F) >> 2);
2119 mask
|= 1 << ((mmTPC7_QM_PQ_CFG0
& 0x7F) >> 2);
2120 mask
|= 1 << ((mmTPC7_QM_PQ_CFG1
& 0x7F) >> 2);
2121 mask
|= 1 << ((mmTPC7_QM_PQ_ARUSER
& 0x7F) >> 2);
2123 WREG32(pb_addr
+ word_offset
, ~mask
);
2125 pb_addr
= (mmTPC7_QM_PQ_PUSH0
& ~0xFFF) + PROT_BITS_OFFS
;
2126 word_offset
= ((mmTPC7_QM_PQ_PUSH0
& PROT_BITS_OFFS
) >> 7) << 2;
2127 mask
= 1 << ((mmTPC7_QM_PQ_PUSH0
& 0x7F) >> 2);
2128 mask
|= 1 << ((mmTPC7_QM_PQ_PUSH1
& 0x7F) >> 2);
2129 mask
|= 1 << ((mmTPC7_QM_PQ_PUSH2
& 0x7F) >> 2);
2130 mask
|= 1 << ((mmTPC7_QM_PQ_PUSH3
& 0x7F) >> 2);
2131 mask
|= 1 << ((mmTPC7_QM_PQ_STS0
& 0x7F) >> 2);
2132 mask
|= 1 << ((mmTPC7_QM_PQ_STS1
& 0x7F) >> 2);
2133 mask
|= 1 << ((mmTPC7_QM_PQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
2134 mask
|= 1 << ((mmTPC7_QM_PQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
2135 mask
|= 1 << ((mmTPC7_QM_PQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
2136 mask
|= 1 << ((mmTPC7_QM_PQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
2137 mask
|= 1 << ((mmTPC7_QM_CQ_CFG0
& 0x7F) >> 2);
2138 mask
|= 1 << ((mmTPC7_QM_CQ_CFG1
& 0x7F) >> 2);
2139 mask
|= 1 << ((mmTPC7_QM_CQ_ARUSER
& 0x7F) >> 2);
2140 mask
|= 1 << ((mmTPC7_QM_CQ_PTR_LO
& 0x7F) >> 2);
2141 mask
|= 1 << ((mmTPC7_QM_CQ_PTR_HI
& 0x7F) >> 2);
2142 mask
|= 1 << ((mmTPC7_QM_CQ_TSIZE
& 0x7F) >> 2);
2143 mask
|= 1 << ((mmTPC7_QM_CQ_CTL
& 0x7F) >> 2);
2144 mask
|= 1 << ((mmTPC7_QM_CQ_PTR_LO_STS
& 0x7F) >> 2);
2145 mask
|= 1 << ((mmTPC7_QM_CQ_PTR_HI_STS
& 0x7F) >> 2);
2146 mask
|= 1 << ((mmTPC7_QM_CQ_TSIZE_STS
& 0x7F) >> 2);
2147 mask
|= 1 << ((mmTPC7_QM_CQ_CTL_STS
& 0x7F) >> 2);
2148 mask
|= 1 << ((mmTPC7_QM_CQ_STS0
& 0x7F) >> 2);
2149 mask
|= 1 << ((mmTPC7_QM_CQ_STS1
& 0x7F) >> 2);
2150 mask
|= 1 << ((mmTPC7_QM_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
2151 mask
|= 1 << ((mmTPC7_QM_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
2152 mask
|= 1 << ((mmTPC7_QM_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
2153 mask
|= 1 << ((mmTPC7_QM_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
2155 WREG32(pb_addr
+ word_offset
, ~mask
);
2157 pb_addr
= (mmTPC7_QM_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
2158 word_offset
= ((mmTPC7_QM_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
2159 mask
= 1 << ((mmTPC7_QM_CQ_IFIFO_CNT
& 0x7F) >> 2);
2160 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
2161 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
2162 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
2163 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
2164 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
2165 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
2166 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
2167 mask
|= 1 << ((mmTPC7_QM_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
2168 mask
|= 1 << ((mmTPC7_QM_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
2169 mask
|= 1 << ((mmTPC7_QM_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
2170 mask
|= 1 << ((mmTPC7_QM_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
2171 mask
|= 1 << ((mmTPC7_QM_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
2172 mask
|= 1 << ((mmTPC7_QM_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
2173 mask
|= 1 << ((mmTPC7_QM_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
2175 WREG32(pb_addr
+ word_offset
, ~mask
);
2177 pb_addr
= (mmTPC7_CMDQ_GLBL_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
2178 word_offset
= ((mmTPC7_CMDQ_GLBL_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
2179 mask
= 1 << ((mmTPC7_CMDQ_GLBL_CFG0
& 0x7F) >> 2);
2180 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_CFG1
& 0x7F) >> 2);
2181 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_PROT
& 0x7F) >> 2);
2182 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_ERR_CFG
& 0x7F) >> 2);
2183 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_ERR_ADDR_LO
& 0x7F) >> 2);
2184 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_ERR_ADDR_HI
& 0x7F) >> 2);
2185 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_ERR_WDATA
& 0x7F) >> 2);
2186 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_SECURE_PROPS
& 0x7F) >> 2);
2187 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_NON_SECURE_PROPS
& 0x7F) >> 2);
2188 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_STS0
& 0x7F) >> 2);
2189 mask
|= 1 << ((mmTPC7_CMDQ_GLBL_STS1
& 0x7F) >> 2);
2191 WREG32(pb_addr
+ word_offset
, ~mask
);
2193 pb_addr
= (mmTPC7_CMDQ_CQ_CFG0
& ~0xFFF) + PROT_BITS_OFFS
;
2194 word_offset
= ((mmTPC7_CMDQ_CQ_CFG0
& PROT_BITS_OFFS
) >> 7) << 2;
2195 mask
= 1 << ((mmTPC7_CMDQ_CQ_CFG0
& 0x7F) >> 2);
2196 mask
|= 1 << ((mmTPC7_CMDQ_CQ_CFG1
& 0x7F) >> 2);
2197 mask
|= 1 << ((mmTPC7_CMDQ_CQ_ARUSER
& 0x7F) >> 2);
2198 mask
|= 1 << ((mmTPC7_CMDQ_CQ_PTR_LO_STS
& 0x7F) >> 2);
2199 mask
|= 1 << ((mmTPC7_CMDQ_CQ_PTR_HI_STS
& 0x7F) >> 2);
2200 mask
|= 1 << ((mmTPC7_CMDQ_CQ_TSIZE_STS
& 0x7F) >> 2);
2201 mask
|= 1 << ((mmTPC7_CMDQ_CQ_CTL_STS
& 0x7F) >> 2);
2202 mask
|= 1 << ((mmTPC7_CMDQ_CQ_STS0
& 0x7F) >> 2);
2203 mask
|= 1 << ((mmTPC7_CMDQ_CQ_STS1
& 0x7F) >> 2);
2204 mask
|= 1 << ((mmTPC7_CMDQ_CQ_RD_RATE_LIM_EN
& 0x7F) >> 2);
2205 mask
|= 1 << ((mmTPC7_CMDQ_CQ_RD_RATE_LIM_RST_TOKEN
& 0x7F) >> 2);
2206 mask
|= 1 << ((mmTPC7_CMDQ_CQ_RD_RATE_LIM_SAT
& 0x7F) >> 2);
2207 mask
|= 1 << ((mmTPC7_CMDQ_CQ_RD_RATE_LIM_TOUT
& 0x7F) >> 2);
2209 WREG32(pb_addr
+ word_offset
, ~mask
);
2211 pb_addr
= (mmTPC7_CMDQ_CQ_IFIFO_CNT
& ~0xFFF) + PROT_BITS_OFFS
;
2212 word_offset
= ((mmTPC7_CMDQ_CQ_IFIFO_CNT
& PROT_BITS_OFFS
) >> 7) << 2;
2213 mask
= 1 << ((mmTPC7_CMDQ_CQ_IFIFO_CNT
& 0x7F) >> 2);
2214 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE0_ADDR_LO
& 0x7F) >> 2);
2215 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE0_ADDR_HI
& 0x7F) >> 2);
2216 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE1_ADDR_LO
& 0x7F) >> 2);
2217 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE1_ADDR_HI
& 0x7F) >> 2);
2218 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE2_ADDR_LO
& 0x7F) >> 2);
2219 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE2_ADDR_HI
& 0x7F) >> 2);
2220 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE3_ADDR_LO
& 0x7F) >> 2);
2221 mask
|= 1 << ((mmTPC7_CMDQ_CP_MSG_BASE3_ADDR_HI
& 0x7F) >> 2);
2222 mask
|= 1 << ((mmTPC7_CMDQ_CP_LDMA_TSIZE_OFFSET
& 0x7F) >> 2);
2223 mask
|= 1 << ((mmTPC7_CMDQ_CP_LDMA_SRC_BASE_LO_OFFSET
& 0x7F) >> 2);
2224 mask
|= 1 << ((mmTPC7_CMDQ_CP_LDMA_SRC_BASE_HI_OFFSET
& 0x7F) >> 2);
2225 mask
|= 1 << ((mmTPC7_CMDQ_CP_LDMA_DST_BASE_LO_OFFSET
& 0x7F) >> 2);
2226 mask
|= 1 << ((mmTPC7_CMDQ_CP_LDMA_DST_BASE_HI_OFFSET
& 0x7F) >> 2);
2227 mask
|= 1 << ((mmTPC7_CMDQ_CP_LDMA_COMMIT_OFFSET
& 0x7F) >> 2);
2228 mask
|= 1 << ((mmTPC7_CMDQ_CP_STS
& 0x7F) >> 2);
2229 mask
|= 1 << ((mmTPC7_CMDQ_CP_CURRENT_INST_LO
& 0x7F) >> 2);
2231 WREG32(pb_addr
+ word_offset
, ~mask
);
2233 pb_addr
= (mmTPC7_CMDQ_CP_CURRENT_INST_HI
& ~0xFFF) + PROT_BITS_OFFS
;
2234 word_offset
= ((mmTPC7_CMDQ_CP_CURRENT_INST_HI
& PROT_BITS_OFFS
) >> 7)
2236 mask
= 1 << ((mmTPC7_CMDQ_CP_CURRENT_INST_HI
& 0x7F) >> 2);
2237 mask
|= 1 << ((mmTPC7_CMDQ_CP_BARRIER_CFG
& 0x7F) >> 2);
2238 mask
|= 1 << ((mmTPC7_CMDQ_CP_DBG_0
& 0x7F) >> 2);
2239 mask
|= 1 << ((mmTPC7_CMDQ_CQ_BUF_ADDR
& 0x7F) >> 2);
2240 mask
|= 1 << ((mmTPC7_CMDQ_CQ_BUF_RDATA
& 0x7F) >> 2);
2242 WREG32(pb_addr
+ word_offset
, ~mask
);
2246 * goya_init_protection_bits - Initialize protection bits for specific registers
2248 * @hdev: pointer to hl_device structure
2250 * All protection bits are 1 by default, means not protected. Need to set to 0
2251 * each bit that belongs to a protected register.
2254 static void goya_init_protection_bits(struct hl_device
*hdev
)
2257 * In each 4K block of registers, the last 128 bytes are protection
2258 * bits - total of 1024 bits, one for each register. Each bit is related
2259 * to a specific register, by the order of the registers.
2260 * So in order to calculate the bit that is related to a given register,
2261 * we need to calculate its word offset and then the exact bit inside
2262 * the word (which is 4 bytes).
2266 * 31 12 11 7 6 2 1 0
2267 * -----------------------------------------------------------------
2268 * | Don't | word | bit location | 0 |
2269 * | care | offset | inside word | |
2270 * -----------------------------------------------------------------
2272 * Bits 7-11 represents the word offset inside the 128 bytes.
2273 * Bits 2-6 represents the bit location inside the word.
2278 goya_pb_set_block(hdev
, mmPCI_NRTR_BASE
);
2279 goya_pb_set_block(hdev
, mmPCI_RD_REGULATOR_BASE
);
2280 goya_pb_set_block(hdev
, mmPCI_WR_REGULATOR_BASE
);
2282 goya_pb_set_block(hdev
, mmSRAM_Y0_X0_BANK_BASE
);
2283 goya_pb_set_block(hdev
, mmSRAM_Y0_X0_RTR_BASE
);
2284 goya_pb_set_block(hdev
, mmSRAM_Y0_X1_BANK_BASE
);
2285 goya_pb_set_block(hdev
, mmSRAM_Y0_X1_RTR_BASE
);
2286 goya_pb_set_block(hdev
, mmSRAM_Y0_X2_BANK_BASE
);
2287 goya_pb_set_block(hdev
, mmSRAM_Y0_X2_RTR_BASE
);
2288 goya_pb_set_block(hdev
, mmSRAM_Y0_X3_BANK_BASE
);
2289 goya_pb_set_block(hdev
, mmSRAM_Y0_X3_RTR_BASE
);
2290 goya_pb_set_block(hdev
, mmSRAM_Y0_X4_BANK_BASE
);
2291 goya_pb_set_block(hdev
, mmSRAM_Y0_X4_RTR_BASE
);
2293 goya_pb_set_block(hdev
, mmSRAM_Y1_X0_BANK_BASE
);
2294 goya_pb_set_block(hdev
, mmSRAM_Y1_X0_RTR_BASE
);
2295 goya_pb_set_block(hdev
, mmSRAM_Y1_X1_BANK_BASE
);
2296 goya_pb_set_block(hdev
, mmSRAM_Y1_X1_RTR_BASE
);
2297 goya_pb_set_block(hdev
, mmSRAM_Y1_X2_BANK_BASE
);
2298 goya_pb_set_block(hdev
, mmSRAM_Y1_X2_RTR_BASE
);
2299 goya_pb_set_block(hdev
, mmSRAM_Y1_X3_BANK_BASE
);
2300 goya_pb_set_block(hdev
, mmSRAM_Y1_X3_RTR_BASE
);
2301 goya_pb_set_block(hdev
, mmSRAM_Y1_X4_BANK_BASE
);
2302 goya_pb_set_block(hdev
, mmSRAM_Y1_X4_RTR_BASE
);
2304 goya_pb_set_block(hdev
, mmSRAM_Y2_X0_BANK_BASE
);
2305 goya_pb_set_block(hdev
, mmSRAM_Y2_X0_RTR_BASE
);
2306 goya_pb_set_block(hdev
, mmSRAM_Y2_X1_BANK_BASE
);
2307 goya_pb_set_block(hdev
, mmSRAM_Y2_X1_RTR_BASE
);
2308 goya_pb_set_block(hdev
, mmSRAM_Y2_X2_BANK_BASE
);
2309 goya_pb_set_block(hdev
, mmSRAM_Y2_X2_RTR_BASE
);
2310 goya_pb_set_block(hdev
, mmSRAM_Y2_X3_BANK_BASE
);
2311 goya_pb_set_block(hdev
, mmSRAM_Y2_X3_RTR_BASE
);
2312 goya_pb_set_block(hdev
, mmSRAM_Y2_X4_BANK_BASE
);
2313 goya_pb_set_block(hdev
, mmSRAM_Y2_X4_RTR_BASE
);
2315 goya_pb_set_block(hdev
, mmSRAM_Y3_X0_BANK_BASE
);
2316 goya_pb_set_block(hdev
, mmSRAM_Y3_X0_RTR_BASE
);
2317 goya_pb_set_block(hdev
, mmSRAM_Y3_X1_BANK_BASE
);
2318 goya_pb_set_block(hdev
, mmSRAM_Y3_X1_RTR_BASE
);
2319 goya_pb_set_block(hdev
, mmSRAM_Y3_X2_BANK_BASE
);
2320 goya_pb_set_block(hdev
, mmSRAM_Y3_X2_RTR_BASE
);
2321 goya_pb_set_block(hdev
, mmSRAM_Y3_X3_BANK_BASE
);
2322 goya_pb_set_block(hdev
, mmSRAM_Y3_X3_RTR_BASE
);
2323 goya_pb_set_block(hdev
, mmSRAM_Y3_X4_BANK_BASE
);
2324 goya_pb_set_block(hdev
, mmSRAM_Y3_X4_RTR_BASE
);
2326 goya_pb_set_block(hdev
, mmSRAM_Y4_X0_BANK_BASE
);
2327 goya_pb_set_block(hdev
, mmSRAM_Y4_X0_RTR_BASE
);
2328 goya_pb_set_block(hdev
, mmSRAM_Y4_X1_BANK_BASE
);
2329 goya_pb_set_block(hdev
, mmSRAM_Y4_X1_RTR_BASE
);
2330 goya_pb_set_block(hdev
, mmSRAM_Y4_X2_BANK_BASE
);
2331 goya_pb_set_block(hdev
, mmSRAM_Y4_X2_RTR_BASE
);
2332 goya_pb_set_block(hdev
, mmSRAM_Y4_X3_BANK_BASE
);
2333 goya_pb_set_block(hdev
, mmSRAM_Y4_X3_RTR_BASE
);
2334 goya_pb_set_block(hdev
, mmSRAM_Y4_X4_BANK_BASE
);
2335 goya_pb_set_block(hdev
, mmSRAM_Y4_X4_RTR_BASE
);
2337 goya_pb_set_block(hdev
, mmSRAM_Y5_X0_BANK_BASE
);
2338 goya_pb_set_block(hdev
, mmSRAM_Y5_X0_RTR_BASE
);
2339 goya_pb_set_block(hdev
, mmSRAM_Y5_X1_BANK_BASE
);
2340 goya_pb_set_block(hdev
, mmSRAM_Y5_X1_RTR_BASE
);
2341 goya_pb_set_block(hdev
, mmSRAM_Y5_X2_BANK_BASE
);
2342 goya_pb_set_block(hdev
, mmSRAM_Y5_X2_RTR_BASE
);
2343 goya_pb_set_block(hdev
, mmSRAM_Y5_X3_BANK_BASE
);
2344 goya_pb_set_block(hdev
, mmSRAM_Y5_X3_RTR_BASE
);
2345 goya_pb_set_block(hdev
, mmSRAM_Y5_X4_BANK_BASE
);
2346 goya_pb_set_block(hdev
, mmSRAM_Y5_X4_RTR_BASE
);
2348 goya_pb_set_block(hdev
, mmPCIE_WRAP_BASE
);
2349 goya_pb_set_block(hdev
, mmPCIE_CORE_BASE
);
2350 goya_pb_set_block(hdev
, mmPCIE_DB_CFG_BASE
);
2351 goya_pb_set_block(hdev
, mmPCIE_DB_CMD_BASE
);
2352 goya_pb_set_block(hdev
, mmPCIE_AUX_BASE
);
2353 goya_pb_set_block(hdev
, mmPCIE_DB_RSV_BASE
);
2354 goya_pb_set_block(hdev
, mmPCIE_PHY_BASE
);
2355 goya_pb_set_block(hdev
, mmTPC0_NRTR_BASE
);
2356 goya_pb_set_block(hdev
, mmTPC_PLL_BASE
);
2358 pb_addr
= (mmTPC_PLL_CLK_RLX_0
& ~0xFFF) + PROT_BITS_OFFS
;
2359 word_offset
= ((mmTPC_PLL_CLK_RLX_0
& PROT_BITS_OFFS
) >> 7) << 2;
2360 mask
= 1 << ((mmTPC_PLL_CLK_RLX_0
& 0x7C) >> 2);
2362 WREG32(pb_addr
+ word_offset
, mask
);
2364 goya_init_mme_protection_bits(hdev
);
2366 goya_init_dma_protection_bits(hdev
);
2368 goya_init_tpc_protection_bits(hdev
);
2372 * goya_init_security - Initialize security model
2374 * @hdev: pointer to hl_device structure
2376 * Initialize the security model of the device
2377 * That includes range registers and protection bit per register
2380 void goya_init_security(struct hl_device
*hdev
)
2382 struct goya_device
*goya
= hdev
->asic_specific
;
2384 u32 dram_addr_lo
= lower_32_bits(DRAM_PHYS_BASE
);
2385 u32 dram_addr_hi
= upper_32_bits(DRAM_PHYS_BASE
);
2387 u32 lbw_rng0_base
= 0xFC440000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2388 u32 lbw_rng0_mask
= 0xFFFF0000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2390 u32 lbw_rng1_base
= 0xFC480000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2391 u32 lbw_rng1_mask
= 0xFFF80000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2393 u32 lbw_rng2_base
= 0xFC600000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2394 u32 lbw_rng2_mask
= 0xFFE00000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2396 u32 lbw_rng3_base
= 0xFC800000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2397 u32 lbw_rng3_mask
= 0xFFF00000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2399 u32 lbw_rng4_base
= 0xFCC02000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2400 u32 lbw_rng4_mask
= 0xFFFFF000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2402 u32 lbw_rng5_base
= 0xFCC40000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2403 u32 lbw_rng5_mask
= 0xFFFF8000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2405 u32 lbw_rng6_base
= 0xFCC48000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2406 u32 lbw_rng6_mask
= 0xFFFFF000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2408 u32 lbw_rng7_base
= 0xFCC4A000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2409 u32 lbw_rng7_mask
= 0xFFFFE000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2411 u32 lbw_rng8_base
= 0xFCC4C000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2412 u32 lbw_rng8_mask
= 0xFFFFC000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2414 u32 lbw_rng9_base
= 0xFCC50000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2415 u32 lbw_rng9_mask
= 0xFFFF0000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2417 u32 lbw_rng10_base
= 0xFCC60000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2418 u32 lbw_rng10_mask
= 0xFFFE0000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2420 u32 lbw_rng11_base
= 0xFCE02000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2421 u32 lbw_rng11_mask
= 0xFFFFE000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2423 u32 lbw_rng12_base
= 0xFE484000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2424 u32 lbw_rng12_mask
= 0xFFFFF000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2426 u32 lbw_rng13_base
= 0xFEC43000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2427 u32 lbw_rng13_mask
= 0xFFFFF000 & DMA_MACRO_LBW_RANGE_BASE_R_MASK
;
2429 WREG32(mmDMA_MACRO_LBW_RANGE_HIT_BLOCK
, 0xFFFF);
2430 WREG32(mmDMA_MACRO_HBW_RANGE_HIT_BLOCK
, 0xFF);
2432 if (!(goya
->hw_cap_initialized
& HW_CAP_MMU
)) {
2433 WREG32(mmDMA_MACRO_HBW_RANGE_HIT_BLOCK
, 0xFE);
2436 WREG32(mmDMA_MACRO_HBW_RANGE_BASE_31_0_0
, 0);
2437 WREG32(mmDMA_MACRO_HBW_RANGE_BASE_49_32_0
, 0);
2438 WREG32(mmDMA_MACRO_HBW_RANGE_MASK_31_0_0
, 0);
2439 WREG32(mmDMA_MACRO_HBW_RANGE_MASK_49_32_0
, 0xFFF80);
2444 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2445 * The mask protects the first 512MB
2447 WREG32(mmDMA_MACRO_HBW_RANGE_BASE_31_0_1
, dram_addr_lo
);
2448 WREG32(mmDMA_MACRO_HBW_RANGE_BASE_49_32_1
, dram_addr_hi
);
2449 WREG32(mmDMA_MACRO_HBW_RANGE_MASK_31_0_1
, 0xE0000000);
2450 WREG32(mmDMA_MACRO_HBW_RANGE_MASK_49_32_1
, 0x3FFFF);
2452 /* Protect registers */
2454 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2455 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2456 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2457 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2458 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2459 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2460 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2461 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2462 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2463 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2464 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2465 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2466 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2467 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2468 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2469 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2470 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2471 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2472 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2473 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2474 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2475 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2476 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2477 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2478 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2479 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2480 WREG32(mmDMA_MACRO_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2481 WREG32(mmDMA_MACRO_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2483 WREG32(mmMME1_RTR_LBW_RANGE_HIT
, 0xFFFF);
2484 WREG32(mmMME2_RTR_LBW_RANGE_HIT
, 0xFFFF);
2485 WREG32(mmMME3_RTR_LBW_RANGE_HIT
, 0xFFFF);
2486 WREG32(mmMME4_RTR_LBW_RANGE_HIT
, 0xFFFF);
2487 WREG32(mmMME5_RTR_LBW_RANGE_HIT
, 0xFFFF);
2488 WREG32(mmMME6_RTR_LBW_RANGE_HIT
, 0xFFFF);
2490 WREG32(mmMME1_RTR_HBW_RANGE_HIT
, 0xFE);
2491 WREG32(mmMME2_RTR_HBW_RANGE_HIT
, 0xFE);
2492 WREG32(mmMME3_RTR_HBW_RANGE_HIT
, 0xFE);
2493 WREG32(mmMME4_RTR_HBW_RANGE_HIT
, 0xFE);
2494 WREG32(mmMME5_RTR_HBW_RANGE_HIT
, 0xFE);
2495 WREG32(mmMME6_RTR_HBW_RANGE_HIT
, 0xFE);
2498 WREG32(mmMME1_RTR_HBW_RANGE_BASE_L_0
, 0);
2499 WREG32(mmMME1_RTR_HBW_RANGE_BASE_H_0
, 0);
2500 WREG32(mmMME1_RTR_HBW_RANGE_MASK_L_0
, 0);
2501 WREG32(mmMME1_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2503 WREG32(mmMME2_RTR_HBW_RANGE_BASE_L_0
, 0);
2504 WREG32(mmMME2_RTR_HBW_RANGE_BASE_H_0
, 0);
2505 WREG32(mmMME2_RTR_HBW_RANGE_MASK_L_0
, 0);
2506 WREG32(mmMME2_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2508 WREG32(mmMME3_RTR_HBW_RANGE_BASE_L_0
, 0);
2509 WREG32(mmMME3_RTR_HBW_RANGE_BASE_H_0
, 0);
2510 WREG32(mmMME3_RTR_HBW_RANGE_MASK_L_0
, 0);
2511 WREG32(mmMME3_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2513 WREG32(mmMME4_RTR_HBW_RANGE_BASE_L_0
, 0);
2514 WREG32(mmMME4_RTR_HBW_RANGE_BASE_H_0
, 0);
2515 WREG32(mmMME4_RTR_HBW_RANGE_MASK_L_0
, 0);
2516 WREG32(mmMME4_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2518 WREG32(mmMME5_RTR_HBW_RANGE_BASE_L_0
, 0);
2519 WREG32(mmMME5_RTR_HBW_RANGE_BASE_H_0
, 0);
2520 WREG32(mmMME5_RTR_HBW_RANGE_MASK_L_0
, 0);
2521 WREG32(mmMME5_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2523 WREG32(mmMME6_RTR_HBW_RANGE_BASE_L_0
, 0);
2524 WREG32(mmMME6_RTR_HBW_RANGE_BASE_H_0
, 0);
2525 WREG32(mmMME6_RTR_HBW_RANGE_MASK_L_0
, 0);
2526 WREG32(mmMME6_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2530 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2531 * The mask protects the first 512MB
2533 WREG32(mmMME1_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2534 WREG32(mmMME1_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2535 WREG32(mmMME1_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2536 WREG32(mmMME1_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2538 WREG32(mmMME2_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2539 WREG32(mmMME2_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2540 WREG32(mmMME2_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2541 WREG32(mmMME2_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2543 WREG32(mmMME3_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2544 WREG32(mmMME3_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2545 WREG32(mmMME3_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2546 WREG32(mmMME3_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2548 WREG32(mmMME4_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2549 WREG32(mmMME4_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2550 WREG32(mmMME4_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2551 WREG32(mmMME4_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2553 WREG32(mmMME5_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2554 WREG32(mmMME5_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2555 WREG32(mmMME5_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2556 WREG32(mmMME5_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2558 WREG32(mmMME6_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2559 WREG32(mmMME6_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2560 WREG32(mmMME6_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2561 WREG32(mmMME6_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2563 WREG32(mmMME1_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2564 WREG32(mmMME1_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2565 WREG32(mmMME1_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2566 WREG32(mmMME1_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2567 WREG32(mmMME1_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2568 WREG32(mmMME1_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2569 WREG32(mmMME1_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2570 WREG32(mmMME1_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2571 WREG32(mmMME1_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2572 WREG32(mmMME1_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2573 WREG32(mmMME1_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2574 WREG32(mmMME1_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2575 WREG32(mmMME1_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2576 WREG32(mmMME1_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2577 WREG32(mmMME1_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2578 WREG32(mmMME1_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2579 WREG32(mmMME1_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2580 WREG32(mmMME1_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2581 WREG32(mmMME1_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2582 WREG32(mmMME1_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2583 WREG32(mmMME1_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2584 WREG32(mmMME1_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2585 WREG32(mmMME1_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2586 WREG32(mmMME1_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2587 WREG32(mmMME1_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2588 WREG32(mmMME1_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2589 WREG32(mmMME1_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2590 WREG32(mmMME1_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2592 WREG32(mmMME2_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2593 WREG32(mmMME2_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2594 WREG32(mmMME2_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2595 WREG32(mmMME2_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2596 WREG32(mmMME2_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2597 WREG32(mmMME2_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2598 WREG32(mmMME2_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2599 WREG32(mmMME2_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2600 WREG32(mmMME2_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2601 WREG32(mmMME2_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2602 WREG32(mmMME2_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2603 WREG32(mmMME2_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2604 WREG32(mmMME2_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2605 WREG32(mmMME2_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2606 WREG32(mmMME2_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2607 WREG32(mmMME2_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2608 WREG32(mmMME2_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2609 WREG32(mmMME2_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2610 WREG32(mmMME2_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2611 WREG32(mmMME2_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2612 WREG32(mmMME2_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2613 WREG32(mmMME2_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2614 WREG32(mmMME2_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2615 WREG32(mmMME2_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2616 WREG32(mmMME2_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2617 WREG32(mmMME2_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2618 WREG32(mmMME2_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2619 WREG32(mmMME2_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2621 WREG32(mmMME3_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2622 WREG32(mmMME3_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2623 WREG32(mmMME3_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2624 WREG32(mmMME3_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2625 WREG32(mmMME3_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2626 WREG32(mmMME3_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2627 WREG32(mmMME3_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2628 WREG32(mmMME3_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2629 WREG32(mmMME3_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2630 WREG32(mmMME3_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2631 WREG32(mmMME3_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2632 WREG32(mmMME3_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2633 WREG32(mmMME3_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2634 WREG32(mmMME3_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2635 WREG32(mmMME3_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2636 WREG32(mmMME3_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2637 WREG32(mmMME3_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2638 WREG32(mmMME3_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2639 WREG32(mmMME3_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2640 WREG32(mmMME3_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2641 WREG32(mmMME3_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2642 WREG32(mmMME3_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2643 WREG32(mmMME3_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2644 WREG32(mmMME3_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2645 WREG32(mmMME3_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2646 WREG32(mmMME3_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2647 WREG32(mmMME3_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2648 WREG32(mmMME3_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2650 WREG32(mmMME4_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2651 WREG32(mmMME4_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2652 WREG32(mmMME4_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2653 WREG32(mmMME4_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2654 WREG32(mmMME4_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2655 WREG32(mmMME4_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2656 WREG32(mmMME4_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2657 WREG32(mmMME4_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2658 WREG32(mmMME4_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2659 WREG32(mmMME4_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2660 WREG32(mmMME4_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2661 WREG32(mmMME4_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2662 WREG32(mmMME4_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2663 WREG32(mmMME4_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2664 WREG32(mmMME4_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2665 WREG32(mmMME4_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2666 WREG32(mmMME4_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2667 WREG32(mmMME4_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2668 WREG32(mmMME4_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2669 WREG32(mmMME4_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2670 WREG32(mmMME4_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2671 WREG32(mmMME4_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2672 WREG32(mmMME4_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2673 WREG32(mmMME4_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2674 WREG32(mmMME4_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2675 WREG32(mmMME4_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2676 WREG32(mmMME4_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2677 WREG32(mmMME4_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2679 WREG32(mmMME5_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2680 WREG32(mmMME5_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2681 WREG32(mmMME5_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2682 WREG32(mmMME5_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2683 WREG32(mmMME5_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2684 WREG32(mmMME5_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2685 WREG32(mmMME5_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2686 WREG32(mmMME5_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2687 WREG32(mmMME5_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2688 WREG32(mmMME5_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2689 WREG32(mmMME5_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2690 WREG32(mmMME5_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2691 WREG32(mmMME5_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2692 WREG32(mmMME5_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2693 WREG32(mmMME5_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2694 WREG32(mmMME5_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2695 WREG32(mmMME5_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2696 WREG32(mmMME5_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2697 WREG32(mmMME5_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2698 WREG32(mmMME5_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2699 WREG32(mmMME5_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2700 WREG32(mmMME5_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2701 WREG32(mmMME5_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2702 WREG32(mmMME5_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2703 WREG32(mmMME5_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2704 WREG32(mmMME5_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2705 WREG32(mmMME5_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2706 WREG32(mmMME5_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2708 WREG32(mmMME6_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2709 WREG32(mmMME6_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2710 WREG32(mmMME6_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2711 WREG32(mmMME6_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2712 WREG32(mmMME6_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2713 WREG32(mmMME6_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2714 WREG32(mmMME6_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2715 WREG32(mmMME6_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2716 WREG32(mmMME6_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2717 WREG32(mmMME6_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2718 WREG32(mmMME6_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2719 WREG32(mmMME6_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2720 WREG32(mmMME6_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2721 WREG32(mmMME6_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2722 WREG32(mmMME6_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2723 WREG32(mmMME6_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2724 WREG32(mmMME6_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2725 WREG32(mmMME6_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2726 WREG32(mmMME6_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2727 WREG32(mmMME6_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2728 WREG32(mmMME6_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2729 WREG32(mmMME6_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2730 WREG32(mmMME6_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2731 WREG32(mmMME6_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2732 WREG32(mmMME6_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2733 WREG32(mmMME6_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2734 WREG32(mmMME6_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2735 WREG32(mmMME6_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2737 WREG32(mmTPC0_NRTR_LBW_RANGE_HIT
, 0xFFFF);
2738 WREG32(mmTPC0_NRTR_HBW_RANGE_HIT
, 0xFE);
2741 WREG32(mmTPC0_NRTR_HBW_RANGE_BASE_L_0
, 0);
2742 WREG32(mmTPC0_NRTR_HBW_RANGE_BASE_H_0
, 0);
2743 WREG32(mmTPC0_NRTR_HBW_RANGE_MASK_L_0
, 0);
2744 WREG32(mmTPC0_NRTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2748 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2749 * The mask protects the first 512MB
2751 WREG32(mmTPC0_NRTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2752 WREG32(mmTPC0_NRTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2753 WREG32(mmTPC0_NRTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2754 WREG32(mmTPC0_NRTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2756 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2757 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2758 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2759 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2760 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2761 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2762 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2763 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2764 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2765 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2766 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2767 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2768 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2769 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2770 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2771 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2772 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2773 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2774 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2775 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2776 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2777 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2778 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2779 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2780 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2781 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2782 WREG32(mmTPC0_NRTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2783 WREG32(mmTPC0_NRTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2785 WREG32(mmTPC1_RTR_LBW_RANGE_HIT
, 0xFFFF);
2786 WREG32(mmTPC1_RTR_HBW_RANGE_HIT
, 0xFE);
2789 WREG32(mmTPC1_RTR_HBW_RANGE_BASE_L_0
, 0);
2790 WREG32(mmTPC1_RTR_HBW_RANGE_BASE_H_0
, 0);
2791 WREG32(mmTPC1_RTR_HBW_RANGE_MASK_L_0
, 0);
2792 WREG32(mmTPC1_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2796 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2797 * The mask protects the first 512MB
2799 WREG32(mmTPC1_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2800 WREG32(mmTPC1_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2801 WREG32(mmTPC1_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2802 WREG32(mmTPC1_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2804 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2805 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2806 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2807 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2808 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2809 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2810 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2811 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2812 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2813 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2814 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2815 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2816 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2817 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2818 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2819 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2820 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2821 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2822 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2823 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2824 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2825 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2826 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2827 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2828 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2829 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2830 WREG32(mmTPC1_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2831 WREG32(mmTPC1_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2833 WREG32(mmTPC2_RTR_LBW_RANGE_HIT
, 0xFFFF);
2834 WREG32(mmTPC2_RTR_HBW_RANGE_HIT
, 0xFE);
2837 WREG32(mmTPC2_RTR_HBW_RANGE_BASE_L_0
, 0);
2838 WREG32(mmTPC2_RTR_HBW_RANGE_BASE_H_0
, 0);
2839 WREG32(mmTPC2_RTR_HBW_RANGE_MASK_L_0
, 0);
2840 WREG32(mmTPC2_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2844 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2845 * The mask protects the first 512MB
2847 WREG32(mmTPC2_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2848 WREG32(mmTPC2_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2849 WREG32(mmTPC2_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2850 WREG32(mmTPC2_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2852 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2853 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2854 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2855 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2856 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2857 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2858 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2859 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2860 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2861 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2862 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2863 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2864 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2865 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2866 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2867 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2868 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2869 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2870 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2871 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2872 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2873 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2874 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2875 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2876 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2877 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2878 WREG32(mmTPC2_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2879 WREG32(mmTPC2_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2881 WREG32(mmTPC3_RTR_LBW_RANGE_HIT
, 0xFFFF);
2882 WREG32(mmTPC3_RTR_HBW_RANGE_HIT
, 0xFE);
2885 WREG32(mmTPC3_RTR_HBW_RANGE_BASE_L_0
, 0);
2886 WREG32(mmTPC3_RTR_HBW_RANGE_BASE_H_0
, 0);
2887 WREG32(mmTPC3_RTR_HBW_RANGE_MASK_L_0
, 0);
2888 WREG32(mmTPC3_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2892 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2893 * The mask protects the first 512MB
2895 WREG32(mmTPC3_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2896 WREG32(mmTPC3_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2897 WREG32(mmTPC3_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2898 WREG32(mmTPC3_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2900 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2901 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2902 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2903 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2904 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2905 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2906 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2907 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2908 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2909 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2910 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2911 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2912 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2913 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2914 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2915 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2916 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2917 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2918 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2919 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2920 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2921 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2922 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2923 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2924 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2925 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2926 WREG32(mmTPC3_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2927 WREG32(mmTPC3_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2929 WREG32(mmTPC4_RTR_LBW_RANGE_HIT
, 0xFFFF);
2930 WREG32(mmTPC4_RTR_HBW_RANGE_HIT
, 0xFE);
2933 WREG32(mmTPC4_RTR_HBW_RANGE_BASE_L_0
, 0);
2934 WREG32(mmTPC4_RTR_HBW_RANGE_BASE_H_0
, 0);
2935 WREG32(mmTPC4_RTR_HBW_RANGE_MASK_L_0
, 0);
2936 WREG32(mmTPC4_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2940 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2941 * The mask protects the first 512MB
2943 WREG32(mmTPC4_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2944 WREG32(mmTPC4_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2945 WREG32(mmTPC4_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2946 WREG32(mmTPC4_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2948 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2949 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2950 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2951 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
2952 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
2953 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
2954 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
2955 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
2956 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
2957 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
2958 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
2959 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
2960 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
2961 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
2962 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
2963 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
2964 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
2965 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
2966 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
2967 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
2968 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
2969 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
2970 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
2971 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
2972 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
2973 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
2974 WREG32(mmTPC4_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
2975 WREG32(mmTPC4_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
2977 WREG32(mmTPC5_RTR_LBW_RANGE_HIT
, 0xFFFF);
2978 WREG32(mmTPC5_RTR_HBW_RANGE_HIT
, 0xFE);
2981 WREG32(mmTPC5_RTR_HBW_RANGE_BASE_L_0
, 0);
2982 WREG32(mmTPC5_RTR_HBW_RANGE_BASE_H_0
, 0);
2983 WREG32(mmTPC5_RTR_HBW_RANGE_MASK_L_0
, 0);
2984 WREG32(mmTPC5_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
2988 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
2989 * The mask protects the first 512MB
2991 WREG32(mmTPC5_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
2992 WREG32(mmTPC5_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
2993 WREG32(mmTPC5_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
2994 WREG32(mmTPC5_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
2996 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
2997 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
2998 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
2999 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
3000 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
3001 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
3002 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
3003 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
3004 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
3005 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
3006 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
3007 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
3008 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
3009 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
3010 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
3011 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
3012 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
3013 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
3014 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
3015 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
3016 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
3017 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
3018 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
3019 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
3020 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
3021 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
3022 WREG32(mmTPC5_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
3023 WREG32(mmTPC5_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
3025 WREG32(mmTPC6_RTR_LBW_RANGE_HIT
, 0xFFFF);
3026 WREG32(mmTPC6_RTR_HBW_RANGE_HIT
, 0xFE);
3029 WREG32(mmTPC6_RTR_HBW_RANGE_BASE_L_0
, 0);
3030 WREG32(mmTPC6_RTR_HBW_RANGE_BASE_H_0
, 0);
3031 WREG32(mmTPC6_RTR_HBW_RANGE_MASK_L_0
, 0);
3032 WREG32(mmTPC6_RTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
3036 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
3037 * The mask protects the first 512MB
3039 WREG32(mmTPC6_RTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
3040 WREG32(mmTPC6_RTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
3041 WREG32(mmTPC6_RTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
3042 WREG32(mmTPC6_RTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
3044 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
3045 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
3046 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
3047 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
3048 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
3049 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
3050 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
3051 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
3052 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
3053 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
3054 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
3055 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
3056 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
3057 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
3058 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
3059 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
3060 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
3061 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
3062 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
3063 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
3064 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
3065 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
3066 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
3067 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
3068 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
3069 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
3070 WREG32(mmTPC6_RTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
3071 WREG32(mmTPC6_RTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
3073 WREG32(mmTPC7_NRTR_LBW_RANGE_HIT
, 0xFFFF);
3074 WREG32(mmTPC7_NRTR_HBW_RANGE_HIT
, 0xFE);
3077 WREG32(mmTPC7_NRTR_HBW_RANGE_BASE_L_0
, 0);
3078 WREG32(mmTPC7_NRTR_HBW_RANGE_BASE_H_0
, 0);
3079 WREG32(mmTPC7_NRTR_HBW_RANGE_MASK_L_0
, 0);
3080 WREG32(mmTPC7_NRTR_HBW_RANGE_MASK_H_0
, 0xFFF80);
3084 * DRAM_VIRT_BASE : DRAM_VIRT_BASE + DRAM_VIRT_END
3085 * The mask protects the first 512MB
3087 WREG32(mmTPC7_NRTR_HBW_RANGE_BASE_L_1
, dram_addr_lo
);
3088 WREG32(mmTPC7_NRTR_HBW_RANGE_BASE_H_1
, dram_addr_hi
);
3089 WREG32(mmTPC7_NRTR_HBW_RANGE_MASK_L_1
, 0xE0000000);
3090 WREG32(mmTPC7_NRTR_HBW_RANGE_MASK_H_1
, 0x3FFFF);
3092 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_0
, lbw_rng0_base
);
3093 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_0
, lbw_rng0_mask
);
3094 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_1
, lbw_rng1_base
);
3095 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_1
, lbw_rng1_mask
);
3096 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_2
, lbw_rng2_base
);
3097 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_2
, lbw_rng2_mask
);
3098 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_3
, lbw_rng3_base
);
3099 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_3
, lbw_rng3_mask
);
3100 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_4
, lbw_rng4_base
);
3101 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_4
, lbw_rng4_mask
);
3102 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_5
, lbw_rng5_base
);
3103 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_5
, lbw_rng5_mask
);
3104 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_6
, lbw_rng6_base
);
3105 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_6
, lbw_rng6_mask
);
3106 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_7
, lbw_rng7_base
);
3107 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_7
, lbw_rng7_mask
);
3108 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_8
, lbw_rng8_base
);
3109 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_8
, lbw_rng8_mask
);
3110 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_9
, lbw_rng9_base
);
3111 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_9
, lbw_rng9_mask
);
3112 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_10
, lbw_rng10_base
);
3113 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_10
, lbw_rng10_mask
);
3114 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_11
, lbw_rng11_base
);
3115 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_11
, lbw_rng11_mask
);
3116 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_12
, lbw_rng12_base
);
3117 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_12
, lbw_rng12_mask
);
3118 WREG32(mmTPC7_NRTR_LBW_RANGE_BASE_13
, lbw_rng13_base
);
3119 WREG32(mmTPC7_NRTR_LBW_RANGE_MASK_13
, lbw_rng13_mask
);
3121 goya_init_protection_bits(hdev
);
3124 void goya_ack_protection_bits_errors(struct hl_device
*hdev
)