2 * AMD ALSA SoC PCM Driver for ACP 2.x
4 * Copyright 2014-2015 Advanced Micro Devices, Inc.
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms and conditions of the GNU General Public License,
8 * version 2, as published by the Free Software Foundation.
10 * This program is distributed in the hope it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
16 #include <linux/module.h>
17 #include <linux/delay.h>
19 #include <linux/sizes.h>
20 #include <linux/pm_runtime.h>
22 #include <sound/soc.h>
23 #include <drm/amd_asic_type.h>
26 #define PLAYBACK_MIN_NUM_PERIODS 2
27 #define PLAYBACK_MAX_NUM_PERIODS 2
28 #define PLAYBACK_MAX_PERIOD_SIZE 16384
29 #define PLAYBACK_MIN_PERIOD_SIZE 1024
30 #define CAPTURE_MIN_NUM_PERIODS 2
31 #define CAPTURE_MAX_NUM_PERIODS 2
32 #define CAPTURE_MAX_PERIOD_SIZE 16384
33 #define CAPTURE_MIN_PERIOD_SIZE 1024
35 #define MAX_BUFFER (PLAYBACK_MAX_PERIOD_SIZE * PLAYBACK_MAX_NUM_PERIODS)
36 #define MIN_BUFFER MAX_BUFFER
38 #define ST_PLAYBACK_MAX_PERIOD_SIZE 8192
39 #define ST_CAPTURE_MAX_PERIOD_SIZE ST_PLAYBACK_MAX_PERIOD_SIZE
40 #define ST_MAX_BUFFER (ST_PLAYBACK_MAX_PERIOD_SIZE * PLAYBACK_MAX_NUM_PERIODS)
41 #define ST_MIN_BUFFER ST_MAX_BUFFER
43 #define DRV_NAME "acp_audio_dma"
45 static const struct snd_pcm_hardware acp_pcm_hardware_playback
= {
46 .info
= SNDRV_PCM_INFO_INTERLEAVED
|
47 SNDRV_PCM_INFO_BLOCK_TRANSFER
| SNDRV_PCM_INFO_MMAP
|
48 SNDRV_PCM_INFO_MMAP_VALID
| SNDRV_PCM_INFO_BATCH
|
49 SNDRV_PCM_INFO_PAUSE
| SNDRV_PCM_INFO_RESUME
,
50 .formats
= SNDRV_PCM_FMTBIT_S16_LE
|
51 SNDRV_PCM_FMTBIT_S24_LE
| SNDRV_PCM_FMTBIT_S32_LE
,
54 .rates
= SNDRV_PCM_RATE_8000_96000
,
57 .buffer_bytes_max
= PLAYBACK_MAX_NUM_PERIODS
* PLAYBACK_MAX_PERIOD_SIZE
,
58 .period_bytes_min
= PLAYBACK_MIN_PERIOD_SIZE
,
59 .period_bytes_max
= PLAYBACK_MAX_PERIOD_SIZE
,
60 .periods_min
= PLAYBACK_MIN_NUM_PERIODS
,
61 .periods_max
= PLAYBACK_MAX_NUM_PERIODS
,
64 static const struct snd_pcm_hardware acp_pcm_hardware_capture
= {
65 .info
= SNDRV_PCM_INFO_INTERLEAVED
|
66 SNDRV_PCM_INFO_BLOCK_TRANSFER
| SNDRV_PCM_INFO_MMAP
|
67 SNDRV_PCM_INFO_MMAP_VALID
| SNDRV_PCM_INFO_BATCH
|
68 SNDRV_PCM_INFO_PAUSE
| SNDRV_PCM_INFO_RESUME
,
69 .formats
= SNDRV_PCM_FMTBIT_S16_LE
|
70 SNDRV_PCM_FMTBIT_S24_LE
| SNDRV_PCM_FMTBIT_S32_LE
,
73 .rates
= SNDRV_PCM_RATE_8000_48000
,
76 .buffer_bytes_max
= CAPTURE_MAX_NUM_PERIODS
* CAPTURE_MAX_PERIOD_SIZE
,
77 .period_bytes_min
= CAPTURE_MIN_PERIOD_SIZE
,
78 .period_bytes_max
= CAPTURE_MAX_PERIOD_SIZE
,
79 .periods_min
= CAPTURE_MIN_NUM_PERIODS
,
80 .periods_max
= CAPTURE_MAX_NUM_PERIODS
,
83 static const struct snd_pcm_hardware acp_st_pcm_hardware_playback
= {
84 .info
= SNDRV_PCM_INFO_INTERLEAVED
|
85 SNDRV_PCM_INFO_BLOCK_TRANSFER
| SNDRV_PCM_INFO_MMAP
|
86 SNDRV_PCM_INFO_MMAP_VALID
| SNDRV_PCM_INFO_BATCH
|
87 SNDRV_PCM_INFO_PAUSE
| SNDRV_PCM_INFO_RESUME
,
88 .formats
= SNDRV_PCM_FMTBIT_S16_LE
|
89 SNDRV_PCM_FMTBIT_S24_LE
| SNDRV_PCM_FMTBIT_S32_LE
,
92 .rates
= SNDRV_PCM_RATE_8000_96000
,
95 .buffer_bytes_max
= ST_MAX_BUFFER
,
96 .period_bytes_min
= PLAYBACK_MIN_PERIOD_SIZE
,
97 .period_bytes_max
= ST_PLAYBACK_MAX_PERIOD_SIZE
,
98 .periods_min
= PLAYBACK_MIN_NUM_PERIODS
,
99 .periods_max
= PLAYBACK_MAX_NUM_PERIODS
,
102 static const struct snd_pcm_hardware acp_st_pcm_hardware_capture
= {
103 .info
= SNDRV_PCM_INFO_INTERLEAVED
|
104 SNDRV_PCM_INFO_BLOCK_TRANSFER
| SNDRV_PCM_INFO_MMAP
|
105 SNDRV_PCM_INFO_MMAP_VALID
| SNDRV_PCM_INFO_BATCH
|
106 SNDRV_PCM_INFO_PAUSE
| SNDRV_PCM_INFO_RESUME
,
107 .formats
= SNDRV_PCM_FMTBIT_S16_LE
|
108 SNDRV_PCM_FMTBIT_S24_LE
| SNDRV_PCM_FMTBIT_S32_LE
,
111 .rates
= SNDRV_PCM_RATE_8000_48000
,
114 .buffer_bytes_max
= ST_MAX_BUFFER
,
115 .period_bytes_min
= CAPTURE_MIN_PERIOD_SIZE
,
116 .period_bytes_max
= ST_CAPTURE_MAX_PERIOD_SIZE
,
117 .periods_min
= CAPTURE_MIN_NUM_PERIODS
,
118 .periods_max
= CAPTURE_MAX_NUM_PERIODS
,
121 static u32
acp_reg_read(void __iomem
*acp_mmio
, u32 reg
)
123 return readl(acp_mmio
+ (reg
* 4));
126 static void acp_reg_write(u32 val
, void __iomem
*acp_mmio
, u32 reg
)
128 writel(val
, acp_mmio
+ (reg
* 4));
131 /* Configure a given dma channel parameters - enable/disable,
132 * number of descriptors, priority
134 static void config_acp_dma_channel(void __iomem
*acp_mmio
, u8 ch_num
,
135 u16 dscr_strt_idx
, u16 num_dscrs
,
136 enum acp_dma_priority_level priority_level
)
140 /* disable the channel run field */
141 dma_ctrl
= acp_reg_read(acp_mmio
, mmACP_DMA_CNTL_0
+ ch_num
);
142 dma_ctrl
&= ~ACP_DMA_CNTL_0__DMAChRun_MASK
;
143 acp_reg_write(dma_ctrl
, acp_mmio
, mmACP_DMA_CNTL_0
+ ch_num
);
145 /* program a DMA channel with first descriptor to be processed. */
146 acp_reg_write((ACP_DMA_DSCR_STRT_IDX_0__DMAChDscrStrtIdx_MASK
148 acp_mmio
, mmACP_DMA_DSCR_STRT_IDX_0
+ ch_num
);
150 /* program a DMA channel with the number of descriptors to be
151 * processed in the transfer
153 acp_reg_write(ACP_DMA_DSCR_CNT_0__DMAChDscrCnt_MASK
& num_dscrs
,
154 acp_mmio
, mmACP_DMA_DSCR_CNT_0
+ ch_num
);
156 /* set DMA channel priority */
157 acp_reg_write(priority_level
, acp_mmio
, mmACP_DMA_PRIO_0
+ ch_num
);
160 /* Initialize a dma descriptor in SRAM based on descritor information passed */
161 static void config_dma_descriptor_in_sram(void __iomem
*acp_mmio
,
163 acp_dma_dscr_transfer_t
*descr_info
)
167 sram_offset
= (descr_idx
* sizeof(acp_dma_dscr_transfer_t
));
169 /* program the source base address. */
170 acp_reg_write(sram_offset
, acp_mmio
, mmACP_SRBM_Targ_Idx_Addr
);
171 acp_reg_write(descr_info
->src
, acp_mmio
, mmACP_SRBM_Targ_Idx_Data
);
172 /* program the destination base address. */
173 acp_reg_write(sram_offset
+ 4, acp_mmio
, mmACP_SRBM_Targ_Idx_Addr
);
174 acp_reg_write(descr_info
->dest
, acp_mmio
, mmACP_SRBM_Targ_Idx_Data
);
176 /* program the number of bytes to be transferred for this descriptor. */
177 acp_reg_write(sram_offset
+ 8, acp_mmio
, mmACP_SRBM_Targ_Idx_Addr
);
178 acp_reg_write(descr_info
->xfer_val
, acp_mmio
, mmACP_SRBM_Targ_Idx_Data
);
181 /* Initialize the DMA descriptor information for transfer between
182 * system memory <-> ACP SRAM
184 static void set_acp_sysmem_dma_descriptors(void __iomem
*acp_mmio
,
185 u32 size
, int direction
,
186 u32 pte_offset
, u32 asic_type
)
189 u16 dma_dscr_idx
= PLAYBACK_START_DMA_DESCR_CH12
;
190 acp_dma_dscr_transfer_t dmadscr
[NUM_DSCRS_PER_CHANNEL
];
192 for (i
= 0; i
< NUM_DSCRS_PER_CHANNEL
; i
++) {
193 dmadscr
[i
].xfer_val
= 0;
194 if (direction
== SNDRV_PCM_STREAM_PLAYBACK
) {
195 dma_dscr_idx
= PLAYBACK_START_DMA_DESCR_CH12
+ i
;
196 dmadscr
[i
].dest
= ACP_SHARED_RAM_BANK_1_ADDRESS
198 dmadscr
[i
].src
= ACP_INTERNAL_APERTURE_WINDOW_0_ADDRESS
199 + (pte_offset
* SZ_4K
) + (i
* (size
/2));
202 dmadscr
[i
].xfer_val
|=
203 (ACP_DMA_ATTRIBUTES_DAGB_GARLIC_TO_SHAREDMEM
<< 16) |
207 dmadscr
[i
].xfer_val
|=
208 (ACP_DMA_ATTRIBUTES_DAGB_ONION_TO_SHAREDMEM
<< 16) |
212 dma_dscr_idx
= CAPTURE_START_DMA_DESCR_CH14
+ i
;
215 dmadscr
[i
].src
= ACP_SHARED_RAM_BANK_3_ADDRESS
+
218 ACP_INTERNAL_APERTURE_WINDOW_0_ADDRESS
+
219 (pte_offset
* SZ_4K
) + (i
* (size
/2));
220 dmadscr
[i
].xfer_val
|=
222 (ACP_DMA_ATTRIBUTES_SHARED_MEM_TO_DAGB_GARLIC
<< 16) |
226 dmadscr
[i
].src
= ACP_SHARED_RAM_BANK_5_ADDRESS
+
229 ACP_INTERNAL_APERTURE_WINDOW_0_ADDRESS
+
230 (pte_offset
* SZ_4K
) + (i
* (size
/2));
231 dmadscr
[i
].xfer_val
|=
233 (ACP_DMA_ATTRIBUTES_SHAREDMEM_TO_DAGB_ONION
<< 16) |
237 config_dma_descriptor_in_sram(acp_mmio
, dma_dscr_idx
,
240 if (direction
== SNDRV_PCM_STREAM_PLAYBACK
)
241 config_acp_dma_channel(acp_mmio
, SYSRAM_TO_ACP_CH_NUM
,
242 PLAYBACK_START_DMA_DESCR_CH12
,
243 NUM_DSCRS_PER_CHANNEL
,
244 ACP_DMA_PRIORITY_LEVEL_NORMAL
);
246 config_acp_dma_channel(acp_mmio
, ACP_TO_SYSRAM_CH_NUM
,
247 CAPTURE_START_DMA_DESCR_CH14
,
248 NUM_DSCRS_PER_CHANNEL
,
249 ACP_DMA_PRIORITY_LEVEL_NORMAL
);
252 /* Initialize the DMA descriptor information for transfer between
255 static void set_acp_to_i2s_dma_descriptors(void __iomem
*acp_mmio
,
256 u32 size
, int direction
,
261 u16 dma_dscr_idx
= PLAYBACK_START_DMA_DESCR_CH13
;
262 acp_dma_dscr_transfer_t dmadscr
[NUM_DSCRS_PER_CHANNEL
];
264 for (i
= 0; i
< NUM_DSCRS_PER_CHANNEL
; i
++) {
265 dmadscr
[i
].xfer_val
= 0;
266 if (direction
== SNDRV_PCM_STREAM_PLAYBACK
) {
267 dma_dscr_idx
= PLAYBACK_START_DMA_DESCR_CH13
+ i
;
268 dmadscr
[i
].src
= ACP_SHARED_RAM_BANK_1_ADDRESS
+
270 /* dmadscr[i].dest is unused by hardware. */
272 dmadscr
[i
].xfer_val
|= BIT(22) | (TO_ACP_I2S_1
<< 16) |
275 dma_dscr_idx
= CAPTURE_START_DMA_DESCR_CH15
+ i
;
276 /* dmadscr[i].src is unused by hardware. */
281 ACP_SHARED_RAM_BANK_3_ADDRESS
+
286 ACP_SHARED_RAM_BANK_5_ADDRESS
+
289 dmadscr
[i
].xfer_val
|= BIT(22) |
290 (FROM_ACP_I2S_1
<< 16) | (size
/ 2);
292 config_dma_descriptor_in_sram(acp_mmio
, dma_dscr_idx
,
295 /* Configure the DMA channel with the above descriptore */
296 if (direction
== SNDRV_PCM_STREAM_PLAYBACK
)
297 config_acp_dma_channel(acp_mmio
, ACP_TO_I2S_DMA_CH_NUM
,
298 PLAYBACK_START_DMA_DESCR_CH13
,
299 NUM_DSCRS_PER_CHANNEL
,
300 ACP_DMA_PRIORITY_LEVEL_NORMAL
);
302 config_acp_dma_channel(acp_mmio
, I2S_TO_ACP_DMA_CH_NUM
,
303 CAPTURE_START_DMA_DESCR_CH15
,
304 NUM_DSCRS_PER_CHANNEL
,
305 ACP_DMA_PRIORITY_LEVEL_NORMAL
);
308 /* Create page table entries in ACP SRAM for the allocated memory */
309 static void acp_pte_config(void __iomem
*acp_mmio
, struct page
*pg
,
310 u16 num_of_pages
, u32 pte_offset
)
318 offset
= ACP_DAGB_GRP_SRBM_SRAM_BASE_OFFSET
+ (pte_offset
* 8);
319 for (page_idx
= 0; page_idx
< (num_of_pages
); page_idx
++) {
320 /* Load the low address of page int ACP SRAM through SRBM */
321 acp_reg_write((offset
+ (page_idx
* 8)),
322 acp_mmio
, mmACP_SRBM_Targ_Idx_Addr
);
323 addr
= page_to_phys(pg
);
325 low
= lower_32_bits(addr
);
326 high
= upper_32_bits(addr
);
328 acp_reg_write(low
, acp_mmio
, mmACP_SRBM_Targ_Idx_Data
);
330 /* Load the High address of page int ACP SRAM through SRBM */
331 acp_reg_write((offset
+ (page_idx
* 8) + 4),
332 acp_mmio
, mmACP_SRBM_Targ_Idx_Addr
);
334 /* page enable in ACP */
336 acp_reg_write(high
, acp_mmio
, mmACP_SRBM_Targ_Idx_Data
);
338 /* Move to next physically contiguos page */
343 static void config_acp_dma(void __iomem
*acp_mmio
,
344 struct audio_substream_data
*audio_config
,
349 if (audio_config
->direction
== SNDRV_PCM_STREAM_PLAYBACK
)
350 pte_offset
= ACP_PLAYBACK_PTE_OFFSET
;
352 pte_offset
= ACP_CAPTURE_PTE_OFFSET
;
354 acp_pte_config(acp_mmio
, audio_config
->pg
, audio_config
->num_of_pages
,
357 /* Configure System memory <-> ACP SRAM DMA descriptors */
358 set_acp_sysmem_dma_descriptors(acp_mmio
, audio_config
->size
,
359 audio_config
->direction
, pte_offset
, asic_type
);
361 /* Configure ACP SRAM <-> I2S DMA descriptors */
362 set_acp_to_i2s_dma_descriptors(acp_mmio
, audio_config
->size
,
363 audio_config
->direction
, asic_type
);
366 /* Start a given DMA channel transfer */
367 static void acp_dma_start(void __iomem
*acp_mmio
,
368 u16 ch_num
, bool is_circular
)
372 /* read the dma control register and disable the channel run field */
373 dma_ctrl
= acp_reg_read(acp_mmio
, mmACP_DMA_CNTL_0
+ ch_num
);
375 /* Invalidating the DAGB cache */
376 acp_reg_write(1, acp_mmio
, mmACP_DAGB_ATU_CTRL
);
378 /* configure the DMA channel and start the DMA transfer
379 * set dmachrun bit to start the transfer and enable the
380 * interrupt on completion of the dma transfer
382 dma_ctrl
|= ACP_DMA_CNTL_0__DMAChRun_MASK
;
385 case ACP_TO_I2S_DMA_CH_NUM
:
386 case ACP_TO_SYSRAM_CH_NUM
:
387 case I2S_TO_ACP_DMA_CH_NUM
:
388 dma_ctrl
|= ACP_DMA_CNTL_0__DMAChIOCEn_MASK
;
391 dma_ctrl
&= ~ACP_DMA_CNTL_0__DMAChIOCEn_MASK
;
395 /* enable for ACP SRAM to/from I2S DMA channel */
396 if (is_circular
== true)
397 dma_ctrl
|= ACP_DMA_CNTL_0__Circular_DMA_En_MASK
;
399 dma_ctrl
&= ~ACP_DMA_CNTL_0__Circular_DMA_En_MASK
;
401 acp_reg_write(dma_ctrl
, acp_mmio
, mmACP_DMA_CNTL_0
+ ch_num
);
404 /* Stop a given DMA channel transfer */
405 static int acp_dma_stop(void __iomem
*acp_mmio
, u8 ch_num
)
409 u32 count
= ACP_DMA_RESET_TIME
;
411 dma_ctrl
= acp_reg_read(acp_mmio
, mmACP_DMA_CNTL_0
+ ch_num
);
413 /* clear the dma control register fields before writing zero
416 dma_ctrl
&= ~ACP_DMA_CNTL_0__DMAChRun_MASK
;
417 dma_ctrl
&= ~ACP_DMA_CNTL_0__DMAChIOCEn_MASK
;
419 acp_reg_write(dma_ctrl
, acp_mmio
, mmACP_DMA_CNTL_0
+ ch_num
);
420 dma_ch_sts
= acp_reg_read(acp_mmio
, mmACP_DMA_CH_STS
);
422 if (dma_ch_sts
& BIT(ch_num
)) {
423 /* set the reset bit for this channel to stop the dma
426 dma_ctrl
|= ACP_DMA_CNTL_0__DMAChRst_MASK
;
427 acp_reg_write(dma_ctrl
, acp_mmio
, mmACP_DMA_CNTL_0
+ ch_num
);
430 /* check the channel status bit for some time and return the status */
432 dma_ch_sts
= acp_reg_read(acp_mmio
, mmACP_DMA_CH_STS
);
433 if (!(dma_ch_sts
& BIT(ch_num
))) {
434 /* clear the reset flag after successfully stopping
435 * the dma transfer and break from the loop
437 dma_ctrl
&= ~ACP_DMA_CNTL_0__DMAChRst_MASK
;
439 acp_reg_write(dma_ctrl
, acp_mmio
, mmACP_DMA_CNTL_0
444 pr_err("Failed to stop ACP DMA channel : %d\n", ch_num
);
452 static void acp_set_sram_bank_state(void __iomem
*acp_mmio
, u16 bank
,
455 u32 val
, req_reg
, sts_reg
, sts_reg_mask
;
459 req_reg
= mmACP_MEM_SHUT_DOWN_REQ_LO
;
460 sts_reg
= mmACP_MEM_SHUT_DOWN_STS_LO
;
461 sts_reg_mask
= 0xFFFFFFFF;
465 req_reg
= mmACP_MEM_SHUT_DOWN_REQ_HI
;
466 sts_reg
= mmACP_MEM_SHUT_DOWN_STS_HI
;
467 sts_reg_mask
= 0x0000FFFF;
470 val
= acp_reg_read(acp_mmio
, req_reg
);
471 if (val
& (1 << bank
)) {
472 /* bank is in off state */
473 if (power_on
== true)
480 /* bank is in on state */
481 if (power_on
== false)
488 acp_reg_write(val
, acp_mmio
, req_reg
);
490 while (acp_reg_read(acp_mmio
, sts_reg
) != sts_reg_mask
) {
492 pr_err("ACP SRAM bank %d state change failed\n", bank
);
499 /* Initialize and bring ACP hardware to default state. */
500 static int acp_init(void __iomem
*acp_mmio
, u32 asic_type
)
503 u32 val
, count
, sram_pte_offset
;
505 /* Assert Soft reset of ACP */
506 val
= acp_reg_read(acp_mmio
, mmACP_SOFT_RESET
);
508 val
|= ACP_SOFT_RESET__SoftResetAud_MASK
;
509 acp_reg_write(val
, acp_mmio
, mmACP_SOFT_RESET
);
511 count
= ACP_SOFT_RESET_DONE_TIME_OUT_VALUE
;
513 val
= acp_reg_read(acp_mmio
, mmACP_SOFT_RESET
);
514 if (ACP_SOFT_RESET__SoftResetAudDone_MASK
==
515 (val
& ACP_SOFT_RESET__SoftResetAudDone_MASK
))
518 pr_err("Failed to reset ACP\n");
524 /* Enable clock to ACP and wait until the clock is enabled */
525 val
= acp_reg_read(acp_mmio
, mmACP_CONTROL
);
526 val
= val
| ACP_CONTROL__ClkEn_MASK
;
527 acp_reg_write(val
, acp_mmio
, mmACP_CONTROL
);
529 count
= ACP_CLOCK_EN_TIME_OUT_VALUE
;
532 val
= acp_reg_read(acp_mmio
, mmACP_STATUS
);
536 pr_err("Failed to reset ACP\n");
542 /* Deassert the SOFT RESET flags */
543 val
= acp_reg_read(acp_mmio
, mmACP_SOFT_RESET
);
544 val
&= ~ACP_SOFT_RESET__SoftResetAud_MASK
;
545 acp_reg_write(val
, acp_mmio
, mmACP_SOFT_RESET
);
547 /* initiailize Onion control DAGB register */
548 acp_reg_write(ACP_ONION_CNTL_DEFAULT
, acp_mmio
,
549 mmACP_AXI2DAGB_ONION_CNTL
);
551 /* initiailize Garlic control DAGB registers */
552 acp_reg_write(ACP_GARLIC_CNTL_DEFAULT
, acp_mmio
,
553 mmACP_AXI2DAGB_GARLIC_CNTL
);
555 sram_pte_offset
= ACP_DAGB_GRP_SRAM_BASE_ADDRESS
|
556 ACP_DAGB_BASE_ADDR_GRP_1__AXI2DAGBSnoopSel_MASK
|
557 ACP_DAGB_BASE_ADDR_GRP_1__AXI2DAGBTargetMemSel_MASK
|
558 ACP_DAGB_BASE_ADDR_GRP_1__AXI2DAGBGrpEnable_MASK
;
559 acp_reg_write(sram_pte_offset
, acp_mmio
, mmACP_DAGB_BASE_ADDR_GRP_1
);
560 acp_reg_write(ACP_PAGE_SIZE_4K_ENABLE
, acp_mmio
,
561 mmACP_DAGB_PAGE_SIZE_GRP_1
);
563 acp_reg_write(ACP_SRAM_BASE_ADDRESS
, acp_mmio
,
564 mmACP_DMA_DESC_BASE_ADDR
);
566 /* Num of descriptiors in SRAM 0x4, means 256 descriptors;(64 * 4) */
567 acp_reg_write(0x4, acp_mmio
, mmACP_DMA_DESC_MAX_NUM_DSCR
);
568 acp_reg_write(ACP_EXTERNAL_INTR_CNTL__DMAIOCMask_MASK
,
569 acp_mmio
, mmACP_EXTERNAL_INTR_CNTL
);
571 /* When ACP_TILE_P1 is turned on, all SRAM banks get turned on.
572 * Now, turn off all of them. This can't be done in 'poweron' of
573 * ACP pm domain, as this requires ACP to be initialized.
574 * For Stoney, Memory gating is disabled,i.e SRAM Banks
575 * won't be turned off. The default state for SRAM banks is ON.
576 * Setting SRAM bank state code skipped for STONEY platform.
578 if (asic_type
!= CHIP_STONEY
) {
579 for (bank
= 1; bank
< 48; bank
++)
580 acp_set_sram_bank_state(acp_mmio
, bank
, false);
583 /* Stoney supports 16bit resolution */
584 if (asic_type
== CHIP_STONEY
) {
585 val
= acp_reg_read(acp_mmio
, mmACP_I2S_16BIT_RESOLUTION_EN
);
587 acp_reg_write(val
, acp_mmio
, mmACP_I2S_16BIT_RESOLUTION_EN
);
592 /* Deinitialize ACP */
593 static int acp_deinit(void __iomem
*acp_mmio
)
598 /* Assert Soft reset of ACP */
599 val
= acp_reg_read(acp_mmio
, mmACP_SOFT_RESET
);
601 val
|= ACP_SOFT_RESET__SoftResetAud_MASK
;
602 acp_reg_write(val
, acp_mmio
, mmACP_SOFT_RESET
);
604 count
= ACP_SOFT_RESET_DONE_TIME_OUT_VALUE
;
606 val
= acp_reg_read(acp_mmio
, mmACP_SOFT_RESET
);
607 if (ACP_SOFT_RESET__SoftResetAudDone_MASK
==
608 (val
& ACP_SOFT_RESET__SoftResetAudDone_MASK
))
611 pr_err("Failed to reset ACP\n");
616 /** Disable ACP clock */
617 val
= acp_reg_read(acp_mmio
, mmACP_CONTROL
);
618 val
&= ~ACP_CONTROL__ClkEn_MASK
;
619 acp_reg_write(val
, acp_mmio
, mmACP_CONTROL
);
621 count
= ACP_CLOCK_EN_TIME_OUT_VALUE
;
624 val
= acp_reg_read(acp_mmio
, mmACP_STATUS
);
625 if (!(val
& (u32
) 0x1))
628 pr_err("Failed to reset ACP\n");
636 /* ACP DMA irq handler routine for playback, capture usecases */
637 static irqreturn_t
dma_irq_handler(int irq
, void *arg
)
640 u32 intr_flag
, ext_intr_status
;
641 struct audio_drv_data
*irq_data
;
642 void __iomem
*acp_mmio
;
643 struct device
*dev
= arg
;
644 bool valid_irq
= false;
646 irq_data
= dev_get_drvdata(dev
);
647 acp_mmio
= irq_data
->acp_mmio
;
649 ext_intr_status
= acp_reg_read(acp_mmio
, mmACP_EXTERNAL_INTR_STAT
);
650 intr_flag
= (((ext_intr_status
&
651 ACP_EXTERNAL_INTR_STAT__DMAIOCStat_MASK
) >>
652 ACP_EXTERNAL_INTR_STAT__DMAIOCStat__SHIFT
));
654 if ((intr_flag
& BIT(ACP_TO_I2S_DMA_CH_NUM
)) != 0) {
656 if (acp_reg_read(acp_mmio
, mmACP_DMA_CUR_DSCR_13
) ==
657 PLAYBACK_START_DMA_DESCR_CH13
)
658 dscr_idx
= PLAYBACK_END_DMA_DESCR_CH12
;
660 dscr_idx
= PLAYBACK_START_DMA_DESCR_CH12
;
661 config_acp_dma_channel(acp_mmio
, SYSRAM_TO_ACP_CH_NUM
, dscr_idx
,
663 acp_dma_start(acp_mmio
, SYSRAM_TO_ACP_CH_NUM
, false);
665 snd_pcm_period_elapsed(irq_data
->play_stream
);
667 acp_reg_write((intr_flag
& BIT(ACP_TO_I2S_DMA_CH_NUM
)) << 16,
668 acp_mmio
, mmACP_EXTERNAL_INTR_STAT
);
671 if ((intr_flag
& BIT(I2S_TO_ACP_DMA_CH_NUM
)) != 0) {
673 if (acp_reg_read(acp_mmio
, mmACP_DMA_CUR_DSCR_15
) ==
674 CAPTURE_START_DMA_DESCR_CH15
)
675 dscr_idx
= CAPTURE_END_DMA_DESCR_CH14
;
677 dscr_idx
= CAPTURE_START_DMA_DESCR_CH14
;
678 config_acp_dma_channel(acp_mmio
, ACP_TO_SYSRAM_CH_NUM
, dscr_idx
,
680 acp_dma_start(acp_mmio
, ACP_TO_SYSRAM_CH_NUM
, false);
682 acp_reg_write((intr_flag
& BIT(I2S_TO_ACP_DMA_CH_NUM
)) << 16,
683 acp_mmio
, mmACP_EXTERNAL_INTR_STAT
);
686 if ((intr_flag
& BIT(ACP_TO_SYSRAM_CH_NUM
)) != 0) {
688 snd_pcm_period_elapsed(irq_data
->capture_stream
);
689 acp_reg_write((intr_flag
& BIT(ACP_TO_SYSRAM_CH_NUM
)) << 16,
690 acp_mmio
, mmACP_EXTERNAL_INTR_STAT
);
699 static int acp_dma_open(struct snd_pcm_substream
*substream
)
703 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
704 struct snd_soc_pcm_runtime
*prtd
= substream
->private_data
;
705 struct audio_drv_data
*intr_data
= dev_get_drvdata(prtd
->platform
->dev
);
707 struct audio_substream_data
*adata
=
708 kzalloc(sizeof(struct audio_substream_data
), GFP_KERNEL
);
712 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
713 switch (intr_data
->asic_type
) {
715 runtime
->hw
= acp_st_pcm_hardware_playback
;
718 runtime
->hw
= acp_pcm_hardware_playback
;
721 switch (intr_data
->asic_type
) {
723 runtime
->hw
= acp_st_pcm_hardware_capture
;
726 runtime
->hw
= acp_pcm_hardware_capture
;
730 ret
= snd_pcm_hw_constraint_integer(runtime
,
731 SNDRV_PCM_HW_PARAM_PERIODS
);
733 dev_err(prtd
->platform
->dev
, "set integer constraint failed\n");
738 adata
->acp_mmio
= intr_data
->acp_mmio
;
739 runtime
->private_data
= adata
;
741 /* Enable ACP irq, when neither playback or capture streams are
742 * active by the time when a new stream is being opened.
743 * This enablement is not required for another stream, if current
744 * stream is not closed
746 if (!intr_data
->play_stream
&& !intr_data
->capture_stream
)
747 acp_reg_write(1, adata
->acp_mmio
, mmACP_EXTERNAL_INTR_ENB
);
749 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
750 intr_data
->play_stream
= substream
;
751 /* For Stoney, Memory gating is disabled,i.e SRAM Banks
752 * won't be turned off. The default state for SRAM banks is ON.
753 * Setting SRAM bank state code skipped for STONEY platform.
755 if (intr_data
->asic_type
!= CHIP_STONEY
) {
756 for (bank
= 1; bank
<= 4; bank
++)
757 acp_set_sram_bank_state(intr_data
->acp_mmio
,
761 intr_data
->capture_stream
= substream
;
762 if (intr_data
->asic_type
!= CHIP_STONEY
) {
763 for (bank
= 5; bank
<= 8; bank
++)
764 acp_set_sram_bank_state(intr_data
->acp_mmio
,
772 static int acp_dma_hw_params(struct snd_pcm_substream
*substream
,
773 struct snd_pcm_hw_params
*params
)
778 struct snd_pcm_runtime
*runtime
;
779 struct audio_substream_data
*rtd
;
780 struct snd_soc_pcm_runtime
*prtd
= substream
->private_data
;
781 struct audio_drv_data
*adata
= dev_get_drvdata(prtd
->platform
->dev
);
783 runtime
= substream
->runtime
;
784 rtd
= runtime
->private_data
;
789 size
= params_buffer_bytes(params
);
790 status
= snd_pcm_lib_malloc_pages(substream
, size
);
794 memset(substream
->runtime
->dma_area
, 0, params_buffer_bytes(params
));
795 pg
= virt_to_page(substream
->dma_buffer
.area
);
798 acp_set_sram_bank_state(rtd
->acp_mmio
, 0, true);
799 /* Save for runtime private data */
801 rtd
->order
= get_order(size
);
803 /* Fill the page table entries in ACP SRAM */
806 rtd
->num_of_pages
= PAGE_ALIGN(size
) >> PAGE_SHIFT
;
807 rtd
->direction
= substream
->stream
;
809 config_acp_dma(rtd
->acp_mmio
, rtd
, adata
->asic_type
);
817 static int acp_dma_hw_free(struct snd_pcm_substream
*substream
)
819 return snd_pcm_lib_free_pages(substream
);
822 static u64
acp_get_byte_count(void __iomem
*acp_mmio
, int stream
)
824 union acp_dma_count playback_dma_count
;
825 union acp_dma_count capture_dma_count
;
828 if (stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
829 playback_dma_count
.bcount
.high
= acp_reg_read(acp_mmio
,
830 mmACP_I2S_TRANSMIT_BYTE_CNT_HIGH
);
831 playback_dma_count
.bcount
.low
= acp_reg_read(acp_mmio
,
832 mmACP_I2S_TRANSMIT_BYTE_CNT_LOW
);
833 bytescount
= playback_dma_count
.bytescount
;
835 capture_dma_count
.bcount
.high
= acp_reg_read(acp_mmio
,
836 mmACP_I2S_RECEIVED_BYTE_CNT_HIGH
);
837 capture_dma_count
.bcount
.low
= acp_reg_read(acp_mmio
,
838 mmACP_I2S_RECEIVED_BYTE_CNT_LOW
);
839 bytescount
= capture_dma_count
.bytescount
;
844 static snd_pcm_uframes_t
acp_dma_pointer(struct snd_pcm_substream
*substream
)
850 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
851 struct audio_substream_data
*rtd
= runtime
->private_data
;
856 buffersize
= frames_to_bytes(runtime
, runtime
->buffer_size
);
857 bytescount
= acp_get_byte_count(rtd
->acp_mmio
, substream
->stream
);
859 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
860 if (bytescount
> rtd
->renderbytescount
)
861 bytescount
= bytescount
- rtd
->renderbytescount
;
863 if (bytescount
> rtd
->capturebytescount
)
864 bytescount
= bytescount
- rtd
->capturebytescount
;
866 pos
= do_div(bytescount
, buffersize
);
867 return bytes_to_frames(runtime
, pos
);
870 static int acp_dma_mmap(struct snd_pcm_substream
*substream
,
871 struct vm_area_struct
*vma
)
873 return snd_pcm_lib_default_mmap(substream
, vma
);
876 static int acp_dma_prepare(struct snd_pcm_substream
*substream
)
878 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
879 struct audio_substream_data
*rtd
= runtime
->private_data
;
883 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
884 config_acp_dma_channel(rtd
->acp_mmio
, SYSRAM_TO_ACP_CH_NUM
,
885 PLAYBACK_START_DMA_DESCR_CH12
,
886 NUM_DSCRS_PER_CHANNEL
, 0);
887 config_acp_dma_channel(rtd
->acp_mmio
, ACP_TO_I2S_DMA_CH_NUM
,
888 PLAYBACK_START_DMA_DESCR_CH13
,
889 NUM_DSCRS_PER_CHANNEL
, 0);
891 config_acp_dma_channel(rtd
->acp_mmio
, ACP_TO_SYSRAM_CH_NUM
,
892 CAPTURE_START_DMA_DESCR_CH14
,
893 NUM_DSCRS_PER_CHANNEL
, 0);
894 config_acp_dma_channel(rtd
->acp_mmio
, I2S_TO_ACP_DMA_CH_NUM
,
895 CAPTURE_START_DMA_DESCR_CH15
,
896 NUM_DSCRS_PER_CHANNEL
, 0);
901 static int acp_dma_trigger(struct snd_pcm_substream
*substream
, int cmd
)
907 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
908 struct snd_soc_pcm_runtime
*prtd
= substream
->private_data
;
909 struct audio_substream_data
*rtd
= runtime
->private_data
;
914 case SNDRV_PCM_TRIGGER_START
:
915 case SNDRV_PCM_TRIGGER_PAUSE_RELEASE
:
916 case SNDRV_PCM_TRIGGER_RESUME
:
917 bytescount
= acp_get_byte_count(rtd
->acp_mmio
,
919 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
920 if (rtd
->renderbytescount
== 0)
921 rtd
->renderbytescount
= bytescount
;
922 acp_dma_start(rtd
->acp_mmio
,
923 SYSRAM_TO_ACP_CH_NUM
, false);
924 while (acp_reg_read(rtd
->acp_mmio
, mmACP_DMA_CH_STS
) &
925 BIT(SYSRAM_TO_ACP_CH_NUM
)) {
927 dev_err(prtd
->platform
->dev
,
928 "acp dma start timeout\n");
934 acp_dma_start(rtd
->acp_mmio
,
935 ACP_TO_I2S_DMA_CH_NUM
, true);
938 if (rtd
->capturebytescount
== 0)
939 rtd
->capturebytescount
= bytescount
;
940 acp_dma_start(rtd
->acp_mmio
,
941 I2S_TO_ACP_DMA_CH_NUM
, true);
945 case SNDRV_PCM_TRIGGER_STOP
:
946 case SNDRV_PCM_TRIGGER_PAUSE_PUSH
:
947 case SNDRV_PCM_TRIGGER_SUSPEND
:
948 /* Need to stop only circular DMA channels :
949 * ACP_TO_I2S_DMA_CH_NUM / I2S_TO_ACP_DMA_CH_NUM. Non-circular
950 * channels will stopped automatically after its transfer
951 * completes : SYSRAM_TO_ACP_CH_NUM / ACP_TO_SYSRAM_CH_NUM
953 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
954 ret
= acp_dma_stop(rtd
->acp_mmio
,
955 ACP_TO_I2S_DMA_CH_NUM
);
956 rtd
->renderbytescount
= 0;
958 ret
= acp_dma_stop(rtd
->acp_mmio
,
959 I2S_TO_ACP_DMA_CH_NUM
);
960 rtd
->capturebytescount
= 0;
970 static int acp_dma_new(struct snd_soc_pcm_runtime
*rtd
)
973 struct audio_drv_data
*adata
= dev_get_drvdata(rtd
->platform
->dev
);
975 switch (adata
->asic_type
) {
977 ret
= snd_pcm_lib_preallocate_pages_for_all(rtd
->pcm
,
983 ret
= snd_pcm_lib_preallocate_pages_for_all(rtd
->pcm
,
990 dev_err(rtd
->platform
->dev
,
991 "buffer preallocation failer error:%d\n", ret
);
995 static int acp_dma_close(struct snd_pcm_substream
*substream
)
998 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
999 struct audio_substream_data
*rtd
= runtime
->private_data
;
1000 struct snd_soc_pcm_runtime
*prtd
= substream
->private_data
;
1001 struct audio_drv_data
*adata
= dev_get_drvdata(prtd
->platform
->dev
);
1005 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
1006 adata
->play_stream
= NULL
;
1007 /* For Stoney, Memory gating is disabled,i.e SRAM Banks
1008 * won't be turned off. The default state for SRAM banks is ON.
1009 * Setting SRAM bank state code skipped for STONEY platform.
1010 * added condition checks for Carrizo platform only
1012 if (adata
->asic_type
!= CHIP_STONEY
) {
1013 for (bank
= 1; bank
<= 4; bank
++)
1014 acp_set_sram_bank_state(adata
->acp_mmio
, bank
,
1018 adata
->capture_stream
= NULL
;
1019 if (adata
->asic_type
!= CHIP_STONEY
) {
1020 for (bank
= 5; bank
<= 8; bank
++)
1021 acp_set_sram_bank_state(adata
->acp_mmio
, bank
,
1026 /* Disable ACP irq, when the current stream is being closed and
1027 * another stream is also not active.
1029 if (!adata
->play_stream
&& !adata
->capture_stream
)
1030 acp_reg_write(0, adata
->acp_mmio
, mmACP_EXTERNAL_INTR_ENB
);
1035 static const struct snd_pcm_ops acp_dma_ops
= {
1036 .open
= acp_dma_open
,
1037 .close
= acp_dma_close
,
1038 .ioctl
= snd_pcm_lib_ioctl
,
1039 .hw_params
= acp_dma_hw_params
,
1040 .hw_free
= acp_dma_hw_free
,
1041 .trigger
= acp_dma_trigger
,
1042 .pointer
= acp_dma_pointer
,
1043 .mmap
= acp_dma_mmap
,
1044 .prepare
= acp_dma_prepare
,
1047 static struct snd_soc_platform_driver acp_asoc_platform
= {
1048 .ops
= &acp_dma_ops
,
1049 .pcm_new
= acp_dma_new
,
1052 static int acp_audio_probe(struct platform_device
*pdev
)
1055 struct audio_drv_data
*audio_drv_data
;
1056 struct resource
*res
;
1057 const u32
*pdata
= pdev
->dev
.platform_data
;
1060 dev_err(&pdev
->dev
, "Missing platform data\n");
1064 audio_drv_data
= devm_kzalloc(&pdev
->dev
, sizeof(struct audio_drv_data
),
1066 if (audio_drv_data
== NULL
)
1069 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, 0);
1070 audio_drv_data
->acp_mmio
= devm_ioremap_resource(&pdev
->dev
, res
);
1071 if (IS_ERR(audio_drv_data
->acp_mmio
))
1072 return PTR_ERR(audio_drv_data
->acp_mmio
);
1074 /* The following members gets populated in device 'open'
1075 * function. Till then interrupts are disabled in 'acp_init'
1076 * and device doesn't generate any interrupts.
1079 audio_drv_data
->play_stream
= NULL
;
1080 audio_drv_data
->capture_stream
= NULL
;
1081 audio_drv_data
->asic_type
= *pdata
;
1083 res
= platform_get_resource(pdev
, IORESOURCE_IRQ
, 0);
1085 dev_err(&pdev
->dev
, "IORESOURCE_IRQ FAILED\n");
1089 status
= devm_request_irq(&pdev
->dev
, res
->start
, dma_irq_handler
,
1090 0, "ACP_IRQ", &pdev
->dev
);
1092 dev_err(&pdev
->dev
, "ACP IRQ request failed\n");
1096 dev_set_drvdata(&pdev
->dev
, audio_drv_data
);
1098 /* Initialize the ACP */
1099 status
= acp_init(audio_drv_data
->acp_mmio
, audio_drv_data
->asic_type
);
1101 dev_err(&pdev
->dev
, "ACP Init failed status:%d\n", status
);
1105 status
= snd_soc_register_platform(&pdev
->dev
, &acp_asoc_platform
);
1107 dev_err(&pdev
->dev
, "Fail to register ALSA platform device\n");
1111 pm_runtime_set_autosuspend_delay(&pdev
->dev
, 10000);
1112 pm_runtime_use_autosuspend(&pdev
->dev
);
1113 pm_runtime_enable(&pdev
->dev
);
1118 static int acp_audio_remove(struct platform_device
*pdev
)
1121 struct audio_drv_data
*adata
= dev_get_drvdata(&pdev
->dev
);
1123 status
= acp_deinit(adata
->acp_mmio
);
1125 dev_err(&pdev
->dev
, "ACP Deinit failed status:%d\n", status
);
1126 snd_soc_unregister_platform(&pdev
->dev
);
1127 pm_runtime_disable(&pdev
->dev
);
1132 static int acp_pcm_resume(struct device
*dev
)
1136 struct audio_drv_data
*adata
= dev_get_drvdata(dev
);
1138 status
= acp_init(adata
->acp_mmio
, adata
->asic_type
);
1140 dev_err(dev
, "ACP Init failed status:%d\n", status
);
1144 if (adata
->play_stream
&& adata
->play_stream
->runtime
) {
1145 /* For Stoney, Memory gating is disabled,i.e SRAM Banks
1146 * won't be turned off. The default state for SRAM banks is ON.
1147 * Setting SRAM bank state code skipped for STONEY platform.
1149 if (adata
->asic_type
!= CHIP_STONEY
) {
1150 for (bank
= 1; bank
<= 4; bank
++)
1151 acp_set_sram_bank_state(adata
->acp_mmio
, bank
,
1154 config_acp_dma(adata
->acp_mmio
,
1155 adata
->play_stream
->runtime
->private_data
,
1158 if (adata
->capture_stream
&& adata
->capture_stream
->runtime
) {
1159 if (adata
->asic_type
!= CHIP_STONEY
) {
1160 for (bank
= 5; bank
<= 8; bank
++)
1161 acp_set_sram_bank_state(adata
->acp_mmio
, bank
,
1164 config_acp_dma(adata
->acp_mmio
,
1165 adata
->capture_stream
->runtime
->private_data
,
1168 acp_reg_write(1, adata
->acp_mmio
, mmACP_EXTERNAL_INTR_ENB
);
1172 static int acp_pcm_runtime_suspend(struct device
*dev
)
1175 struct audio_drv_data
*adata
= dev_get_drvdata(dev
);
1177 status
= acp_deinit(adata
->acp_mmio
);
1179 dev_err(dev
, "ACP Deinit failed status:%d\n", status
);
1180 acp_reg_write(0, adata
->acp_mmio
, mmACP_EXTERNAL_INTR_ENB
);
1184 static int acp_pcm_runtime_resume(struct device
*dev
)
1187 struct audio_drv_data
*adata
= dev_get_drvdata(dev
);
1189 status
= acp_init(adata
->acp_mmio
, adata
->asic_type
);
1191 dev_err(dev
, "ACP Init failed status:%d\n", status
);
1194 acp_reg_write(1, adata
->acp_mmio
, mmACP_EXTERNAL_INTR_ENB
);
1198 static const struct dev_pm_ops acp_pm_ops
= {
1199 .resume
= acp_pcm_resume
,
1200 .runtime_suspend
= acp_pcm_runtime_suspend
,
1201 .runtime_resume
= acp_pcm_runtime_resume
,
1204 static struct platform_driver acp_dma_driver
= {
1205 .probe
= acp_audio_probe
,
1206 .remove
= acp_audio_remove
,
1213 module_platform_driver(acp_dma_driver
);
1215 MODULE_AUTHOR("Vijendar.Mukunda@amd.com");
1216 MODULE_AUTHOR("Maruthi.Bayyavarapu@amd.com");
1217 MODULE_DESCRIPTION("AMD ACP PCM Driver");
1218 MODULE_LICENSE("GPL v2");
1219 MODULE_ALIAS("platform:"DRV_NAME
);