1/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * AMD ACP 5.x Register Documentation
4 *
5 * Copyright 2021 Advanced Micro Devices, Inc.
6 */
7
8#ifndef _acp_ip_OFFSET_HEADER
9#define _acp_ip_OFFSET_HEADER
10
11/* Registers from ACP_DMA block */
12#define ACP_DMA_CNTL_0 0x1240000
13#define ACP_DMA_CNTL_1 0x1240004
14#define ACP_DMA_CNTL_2 0x1240008
15#define ACP_DMA_CNTL_3 0x124000C
16#define ACP_DMA_CNTL_4 0x1240010
17#define ACP_DMA_CNTL_5 0x1240014
18#define ACP_DMA_CNTL_6 0x1240018
19#define ACP_DMA_CNTL_7 0x124001C
20#define ACP_DMA_DSCR_STRT_IDX_0 0x1240020
21#define ACP_DMA_DSCR_STRT_IDX_1 0x1240024
22#define ACP_DMA_DSCR_STRT_IDX_2 0x1240028
23#define ACP_DMA_DSCR_STRT_IDX_3 0x124002C
24#define ACP_DMA_DSCR_STRT_IDX_4 0x1240030
25#define ACP_DMA_DSCR_STRT_IDX_5 0x1240034
26#define ACP_DMA_DSCR_STRT_IDX_6 0x1240038
27#define ACP_DMA_DSCR_STRT_IDX_7 0x124003C
28#define ACP_DMA_DSCR_CNT_0 0x1240040
29#define ACP_DMA_DSCR_CNT_1 0x1240044
30#define ACP_DMA_DSCR_CNT_2 0x1240048
31#define ACP_DMA_DSCR_CNT_3 0x124004C
32#define ACP_DMA_DSCR_CNT_4 0x1240050
33#define ACP_DMA_DSCR_CNT_5 0x1240054
34#define ACP_DMA_DSCR_CNT_6 0x1240058
35#define ACP_DMA_DSCR_CNT_7 0x124005C
36#define ACP_DMA_PRIO_0 0x1240060
37#define ACP_DMA_PRIO_1 0x1240064
38#define ACP_DMA_PRIO_2 0x1240068
39#define ACP_DMA_PRIO_3 0x124006C
40#define ACP_DMA_PRIO_4 0x1240070
41#define ACP_DMA_PRIO_5 0x1240074
42#define ACP_DMA_PRIO_6 0x1240078
43#define ACP_DMA_PRIO_7 0x124007C
44#define ACP_DMA_CUR_DSCR_0 0x1240080
45#define ACP_DMA_CUR_DSCR_1 0x1240084
46#define ACP_DMA_CUR_DSCR_2 0x1240088
47#define ACP_DMA_CUR_DSCR_3 0x124008C
48#define ACP_DMA_CUR_DSCR_4 0x1240090
49#define ACP_DMA_CUR_DSCR_5 0x1240094
50#define ACP_DMA_CUR_DSCR_6 0x1240098
51#define ACP_DMA_CUR_DSCR_7 0x124009C
52#define ACP_DMA_CUR_TRANS_CNT_0 0x12400A0
53#define ACP_DMA_CUR_TRANS_CNT_1 0x12400A4
54#define ACP_DMA_CUR_TRANS_CNT_2 0x12400A8
55#define ACP_DMA_CUR_TRANS_CNT_3 0x12400AC
56#define ACP_DMA_CUR_TRANS_CNT_4 0x12400B0
57#define ACP_DMA_CUR_TRANS_CNT_5 0x12400B4
58#define ACP_DMA_CUR_TRANS_CNT_6 0x12400B8
59#define ACP_DMA_CUR_TRANS_CNT_7 0x12400BC
60#define ACP_DMA_ERR_STS_0 0x12400C0
61#define ACP_DMA_ERR_STS_1 0x12400C4
62#define ACP_DMA_ERR_STS_2 0x12400C8
63#define ACP_DMA_ERR_STS_3 0x12400CC
64#define ACP_DMA_ERR_STS_4 0x12400D0
65#define ACP_DMA_ERR_STS_5 0x12400D4
66#define ACP_DMA_ERR_STS_6 0x12400D8
67#define ACP_DMA_ERR_STS_7 0x12400DC
68#define ACP_DMA_DESC_BASE_ADDR 0x12400E0
69#define ACP_DMA_DESC_MAX_NUM_DSCR 0x12400E4
70#define ACP_DMA_CH_STS 0x12400E8
71#define ACP_DMA_CH_GROUP 0x12400EC
72#define ACP_DMA_CH_RST_STS 0x12400F0
73
74/* Registers from ACP_AXI2AXIATU block */
75#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_1 0x1240C00
76#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_1 0x1240C04
77#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_2 0x1240C08
78#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_2 0x1240C0C
79#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_3 0x1240C10
80#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_3 0x1240C14
81#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_4 0x1240C18
82#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_4 0x1240C1C
83#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_5 0x1240C20
84#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_5 0x1240C24
85#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_6 0x1240C28
86#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_6 0x1240C2C
87#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_7 0x1240C30
88#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_7 0x1240C34
89#define ACPAXI2AXI_ATU_PAGE_SIZE_GRP_8 0x1240C38
90#define ACPAXI2AXI_ATU_BASE_ADDR_GRP_8 0x1240C3C
91#define ACPAXI2AXI_ATU_CTRL 0x1240C40
92
93/* Registers from ACP_CLKRST block */
94#define ACP_SOFT_RESET 0x1241000
95#define ACP_CONTROL 0x1241004
96#define ACP_STATUS 0x1241008
97#define ACP_DYNAMIC_CG_MASTER_CONTROL 0x1241010
98
99/* Registers from ACP_MISC block */
100#define ACP_EXTERNAL_INTR_ENB 0x1241800
101#define ACP_EXTERNAL_INTR_CNTL 0x1241804
102#define ACP_EXTERNAL_INTR_STAT 0x1241808
103#define ACP_ERROR_STATUS 0x12418C4
104#define ACP_SW_I2S_ERROR_REASON 0x12418C8
105#define ACP_MEM_PG_STS 0x12418CC
106#define ACP_PGMEM_DEEP_SLEEP_CTRL 0x12418D0
107#define ACP_PGMEM_SHUT_DOWN_CTRL 0x12418D4
108
109/* Registers from ACP_PGFSM block */
110#define ACP_PIN_CONFIG 0x1241400
111#define ACP_PAD_PULLUP_CTRL 0x1241404
112#define ACP_PAD_PULLDOWN_CTRL 0x1241408
113#define ACP_PAD_DRIVE_STRENGTH_CTRL 0x124140C
114#define ACP_PAD_SCHMEN_CTRL 0x1241410
115#define ACP_SW_PAD_KEEPER_EN 0x1241414
116#define ACP_SW_WAKE_EN 0x1241418
117#define ACP_I2S_WAKE_EN 0x124141C
118#define ACP_PME_EN 0x1241420
119#define ACP_PGFSM_CONTROL 0x1241424
120#define ACP_PGFSM_STATUS 0x1241428
121#define ACP_CLKMUX_SEL 0x124142C
122#define ACP_DEVICE_STATE 0x1241430
123#define AZ_DEVICE_STATE 0x1241434
124#define ACP_INTR_URGENCY_TIMER 0x1241438
125#define AZ_INTR_URGENCY_TIMER 0x124143C
126#define ACP_AON_SW_INTR_TRIG 0x1241440
127
128/* Registers from ACP_SCRATCH block */
129#define ACP_SCRATCH_REG_0 0x1250000
130#define ACP_SCRATCH_REG_1 0x1250004
131#define ACP_SCRATCH_REG_2 0x1250008
132#define ACP_SCRATCH_REG_3 0x125000C
133#define ACP_SCRATCH_REG_4 0x1250010
134#define ACP_SCRATCH_REG_5 0x1250014
135#define ACP_SCRATCH_REG_6 0x1250018
136#define ACP_SCRATCH_REG_7 0x125001C
137#define ACP_SCRATCH_REG_8 0x1250020
138#define ACP_SCRATCH_REG_9 0x1250024
139#define ACP_SCRATCH_REG_10 0x1250028
140#define ACP_SCRATCH_REG_11 0x125002C
141#define ACP_SCRATCH_REG_12 0x1250030
142#define ACP_SCRATCH_REG_13 0x1250034
143#define ACP_SCRATCH_REG_14 0x1250038
144#define ACP_SCRATCH_REG_15 0x125003C
145#define ACP_SCRATCH_REG_16 0x1250040
146#define ACP_SCRATCH_REG_17 0x1250044
147#define ACP_SCRATCH_REG_18 0x1250048
148#define ACP_SCRATCH_REG_19 0x125004C
149#define ACP_SCRATCH_REG_20 0x1250050
150#define ACP_SCRATCH_REG_21 0x1250054
151#define ACP_SCRATCH_REG_22 0x1250058
152#define ACP_SCRATCH_REG_23 0x125005C
153#define ACP_SCRATCH_REG_24 0x1250060
154#define ACP_SCRATCH_REG_25 0x1250064
155#define ACP_SCRATCH_REG_26 0x1250068
156#define ACP_SCRATCH_REG_27 0x125006C
157#define ACP_SCRATCH_REG_28 0x1250070
158#define ACP_SCRATCH_REG_29 0x1250074
159#define ACP_SCRATCH_REG_30 0x1250078
160#define ACP_SCRATCH_REG_31 0x125007C
161#define ACP_SCRATCH_REG_32 0x1250080
162#define ACP_SCRATCH_REG_33 0x1250084
163#define ACP_SCRATCH_REG_34 0x1250088
164#define ACP_SCRATCH_REG_35 0x125008C
165#define ACP_SCRATCH_REG_36 0x1250090
166#define ACP_SCRATCH_REG_37 0x1250094
167#define ACP_SCRATCH_REG_38 0x1250098
168#define ACP_SCRATCH_REG_39 0x125009C
169#define ACP_SCRATCH_REG_40 0x12500A0
170#define ACP_SCRATCH_REG_41 0x12500A4
171#define ACP_SCRATCH_REG_42 0x12500A8
172#define ACP_SCRATCH_REG_43 0x12500AC
173#define ACP_SCRATCH_REG_44 0x12500B0
174#define ACP_SCRATCH_REG_45 0x12500B4
175#define ACP_SCRATCH_REG_46 0x12500B8
176#define ACP_SCRATCH_REG_47 0x12500BC
177#define ACP_SCRATCH_REG_48 0x12500C0
178#define ACP_SCRATCH_REG_49 0x12500C4
179#define ACP_SCRATCH_REG_50 0x12500C8
180#define ACP_SCRATCH_REG_51 0x12500CC
181#define ACP_SCRATCH_REG_52 0x12500D0
182#define ACP_SCRATCH_REG_53 0x12500D4
183#define ACP_SCRATCH_REG_54 0x12500D8
184#define ACP_SCRATCH_REG_55 0x12500DC
185#define ACP_SCRATCH_REG_56 0x12500E0
186#define ACP_SCRATCH_REG_57 0x12500E4
187#define ACP_SCRATCH_REG_58 0x12500E8
188#define ACP_SCRATCH_REG_59 0x12500EC
189#define ACP_SCRATCH_REG_60 0x12500F0
190#define ACP_SCRATCH_REG_61 0x12500F4
191#define ACP_SCRATCH_REG_62 0x12500F8
192#define ACP_SCRATCH_REG_63 0x12500FC
193#define ACP_SCRATCH_REG_64 0x1250100
194#define ACP_SCRATCH_REG_65 0x1250104
195#define ACP_SCRATCH_REG_66 0x1250108
196#define ACP_SCRATCH_REG_67 0x125010C
197#define ACP_SCRATCH_REG_68 0x1250110
198#define ACP_SCRATCH_REG_69 0x1250114
199#define ACP_SCRATCH_REG_70 0x1250118
200#define ACP_SCRATCH_REG_71 0x125011C
201#define ACP_SCRATCH_REG_72 0x1250120
202#define ACP_SCRATCH_REG_73 0x1250124
203#define ACP_SCRATCH_REG_74 0x1250128
204#define ACP_SCRATCH_REG_75 0x125012C
205#define ACP_SCRATCH_REG_76 0x1250130
206#define ACP_SCRATCH_REG_77 0x1250134
207#define ACP_SCRATCH_REG_78 0x1250138
208#define ACP_SCRATCH_REG_79 0x125013C
209#define ACP_SCRATCH_REG_80 0x1250140
210#define ACP_SCRATCH_REG_81 0x1250144
211#define ACP_SCRATCH_REG_82 0x1250148
212#define ACP_SCRATCH_REG_83 0x125014C
213#define ACP_SCRATCH_REG_84 0x1250150
214#define ACP_SCRATCH_REG_85 0x1250154
215#define ACP_SCRATCH_REG_86 0x1250158
216#define ACP_SCRATCH_REG_87 0x125015C
217#define ACP_SCRATCH_REG_88 0x1250160
218#define ACP_SCRATCH_REG_89 0x1250164
219#define ACP_SCRATCH_REG_90 0x1250168
220#define ACP_SCRATCH_REG_91 0x125016C
221#define ACP_SCRATCH_REG_92 0x1250170
222#define ACP_SCRATCH_REG_93 0x1250174
223#define ACP_SCRATCH_REG_94 0x1250178
224#define ACP_SCRATCH_REG_95 0x125017C
225#define ACP_SCRATCH_REG_96 0x1250180
226#define ACP_SCRATCH_REG_97 0x1250184
227#define ACP_SCRATCH_REG_98 0x1250188
228#define ACP_SCRATCH_REG_99 0x125018C
229#define ACP_SCRATCH_REG_100 0x1250190
230#define ACP_SCRATCH_REG_101 0x1250194
231#define ACP_SCRATCH_REG_102 0x1250198
232#define ACP_SCRATCH_REG_103 0x125019C
233#define ACP_SCRATCH_REG_104 0x12501A0
234#define ACP_SCRATCH_REG_105 0x12501A4
235#define ACP_SCRATCH_REG_106 0x12501A8
236#define ACP_SCRATCH_REG_107 0x12501AC
237#define ACP_SCRATCH_REG_108 0x12501B0
238#define ACP_SCRATCH_REG_109 0x12501B4
239#define ACP_SCRATCH_REG_110 0x12501B8
240#define ACP_SCRATCH_REG_111 0x12501BC
241#define ACP_SCRATCH_REG_112 0x12501C0
242#define ACP_SCRATCH_REG_113 0x12501C4
243#define ACP_SCRATCH_REG_114 0x12501C8
244#define ACP_SCRATCH_REG_115 0x12501CC
245#define ACP_SCRATCH_REG_116 0x12501D0
246#define ACP_SCRATCH_REG_117 0x12501D4
247#define ACP_SCRATCH_REG_118 0x12501D8
248#define ACP_SCRATCH_REG_119 0x12501DC
249#define ACP_SCRATCH_REG_120 0x12501E0
250#define ACP_SCRATCH_REG_121 0x12501E4
251#define ACP_SCRATCH_REG_122 0x12501E8
252#define ACP_SCRATCH_REG_123 0x12501EC
253#define ACP_SCRATCH_REG_124 0x12501F0
254#define ACP_SCRATCH_REG_125 0x12501F4
255#define ACP_SCRATCH_REG_126 0x12501F8
256#define ACP_SCRATCH_REG_127 0x12501FC
257#define ACP_SCRATCH_REG_128 0x1250200
258
259/* Registers from ACP_AUDIO_BUFFERS block */
260#define ACP_I2S_RX_RINGBUFADDR 0x1242000
261#define ACP_I2S_RX_RINGBUFSIZE 0x1242004
262#define ACP_I2S_RX_LINKPOSITIONCNTR 0x1242008
263#define ACP_I2S_RX_FIFOADDR 0x124200C
264#define ACP_I2S_RX_FIFOSIZE 0x1242010
265#define ACP_I2S_RX_DMA_SIZE 0x1242014
266#define ACP_I2S_RX_LINEARPOSCNTR_HIGH 0x1242018
267#define ACP_I2S_RX_LINEARPOSCNTR_LOW 0x124201C
268#define ACP_I2S_RX_INTR_WATERMARK_SIZE 0x1242020
269#define ACP_I2S_TX_RINGBUFADDR 0x1242024
270#define ACP_I2S_TX_RINGBUFSIZE 0x1242028
271#define ACP_I2S_TX_LINKPOSITIONCNTR 0x124202C
272#define ACP_I2S_TX_FIFOADDR 0x1242030
273#define ACP_I2S_TX_FIFOSIZE 0x1242034
274#define ACP_I2S_TX_DMA_SIZE 0x1242038
275#define ACP_I2S_TX_LINEARPOSCNTR_HIGH 0x124203C
276#define ACP_I2S_TX_LINEARPOSCNTR_LOW 0x1242040
277#define ACP_I2S_TX_INTR_WATERMARK_SIZE 0x1242044
278#define ACP_BT_RX_RINGBUFADDR 0x1242048
279#define ACP_BT_RX_RINGBUFSIZE 0x124204C
280#define ACP_BT_RX_LINKPOSITIONCNTR 0x1242050
281#define ACP_BT_RX_FIFOADDR 0x1242054
282#define ACP_BT_RX_FIFOSIZE 0x1242058
283#define ACP_BT_RX_DMA_SIZE 0x124205C
284#define ACP_BT_RX_LINEARPOSCNTR_HIGH 0x1242060
285#define ACP_BT_RX_LINEARPOSCNTR_LOW 0x1242064
286#define ACP_BT_RX_INTR_WATERMARK_SIZE 0x1242068
287#define ACP_BT_TX_RINGBUFADDR 0x124206C
288#define ACP_BT_TX_RINGBUFSIZE 0x1242070
289#define ACP_BT_TX_LINKPOSITIONCNTR 0x1242074
290#define ACP_BT_TX_FIFOADDR 0x1242078
291#define ACP_BT_TX_FIFOSIZE 0x124207C
292#define ACP_BT_TX_DMA_SIZE 0x1242080
293#define ACP_BT_TX_LINEARPOSCNTR_HIGH 0x1242084
294#define ACP_BT_TX_LINEARPOSCNTR_LOW 0x1242088
295#define ACP_BT_TX_INTR_WATERMARK_SIZE 0x124208C
296#define ACP_HS_RX_RINGBUFADDR 0x1242090
297#define ACP_HS_RX_RINGBUFSIZE 0x1242094
298#define ACP_HS_RX_LINKPOSITIONCNTR 0x1242098
299#define ACP_HS_RX_FIFOADDR 0x124209C
300#define ACP_HS_RX_FIFOSIZE 0x12420A0
301#define ACP_HS_RX_DMA_SIZE 0x12420A4
302#define ACP_HS_RX_LINEARPOSCNTR_HIGH 0x12420A8
303#define ACP_HS_RX_LINEARPOSCNTR_LOW 0x12420AC
304#define ACP_HS_RX_INTR_WATERMARK_SIZE 0x12420B0
305#define ACP_HS_TX_RINGBUFADDR 0x12420B4
306#define ACP_HS_TX_RINGBUFSIZE 0x12420B8
307#define ACP_HS_TX_LINKPOSITIONCNTR 0x12420BC
308#define ACP_HS_TX_FIFOADDR 0x12420C0
309#define ACP_HS_TX_FIFOSIZE 0x12420C4
310#define ACP_HS_TX_DMA_SIZE 0x12420C8
311#define ACP_HS_TX_LINEARPOSCNTR_HIGH 0x12420CC
312#define ACP_HS_TX_LINEARPOSCNTR_LOW 0x12420D0
313#define ACP_HS_TX_INTR_WATERMARK_SIZE 0x12420D4
314
315/* Registers from ACP_I2S_TDM block */
316#define ACP_I2STDM_IER 0x1242400
317#define ACP_I2STDM_IRER 0x1242404
318#define ACP_I2STDM_RXFRMT 0x1242408
319#define ACP_I2STDM_ITER 0x124240C
320#define ACP_I2STDM_TXFRMT 0x1242410
321#define ACP_I2STDM0_MSTRCLKGEN 0x1242414
322#define ACP_I2STDM1_MSTRCLKGEN 0x1242418
323#define ACP_I2STDM2_MSTRCLKGEN 0x124241C
324#define ACP_I2STDM_REFCLKGEN 0x1242420
325
326/* Registers from ACP_BT_TDM block */
327#define ACP_BTTDM_IER 0x1242800
328#define ACP_BTTDM_IRER 0x1242804
329#define ACP_BTTDM_RXFRMT 0x1242808
330#define ACP_BTTDM_ITER 0x124280C
331#define ACP_BTTDM_TXFRMT 0x1242810
332#define ACP_HSTDM_IER 0x1242814
333#define ACP_HSTDM_IRER 0x1242818
334#define ACP_HSTDM_RXFRMT 0x124281C
335#define ACP_HSTDM_ITER 0x1242820
336#define ACP_HSTDM_TXFRMT 0x1242824
337#endif
338

source code of linux/sound/soc/amd/vangogh/vg_chip_offset_byte.h