1 // SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
2 // Copyright(c) 2015-17 Intel Corporation.
5 * Soundwire Intel Master Driver
8 #include <linux/acpi.h>
9 #include <linux/debugfs.h>
10 #include <linux/delay.h>
11 #include <linux/module.h>
12 #include <linux/interrupt.h>
14 #include <linux/platform_device.h>
15 #include <sound/pcm_params.h>
16 #include <sound/soc.h>
17 #include <linux/soundwire/sdw_registers.h>
18 #include <linux/soundwire/sdw.h>
19 #include <linux/soundwire/sdw_intel.h>
20 #include "cadence_master.h"
24 /* Intel SHIM Registers Definition */
25 #define SDW_SHIM_LCAP 0x0
26 #define SDW_SHIM_LCTL 0x4
27 #define SDW_SHIM_IPPTR 0x8
28 #define SDW_SHIM_SYNC 0xC
30 #define SDW_SHIM_CTLSCAP(x) (0x010 + 0x60 * (x))
31 #define SDW_SHIM_CTLS0CM(x) (0x012 + 0x60 * (x))
32 #define SDW_SHIM_CTLS1CM(x) (0x014 + 0x60 * (x))
33 #define SDW_SHIM_CTLS2CM(x) (0x016 + 0x60 * (x))
34 #define SDW_SHIM_CTLS3CM(x) (0x018 + 0x60 * (x))
35 #define SDW_SHIM_PCMSCAP(x) (0x020 + 0x60 * (x))
37 #define SDW_SHIM_PCMSYCHM(x, y) (0x022 + (0x60 * (x)) + (0x2 * (y)))
38 #define SDW_SHIM_PCMSYCHC(x, y) (0x042 + (0x60 * (x)) + (0x2 * (y)))
39 #define SDW_SHIM_PDMSCAP(x) (0x062 + 0x60 * (x))
40 #define SDW_SHIM_IOCTL(x) (0x06C + 0x60 * (x))
41 #define SDW_SHIM_CTMCTL(x) (0x06E + 0x60 * (x))
43 #define SDW_SHIM_WAKEEN 0x190
44 #define SDW_SHIM_WAKESTS 0x192
46 #define SDW_SHIM_LCTL_SPA BIT(0)
47 #define SDW_SHIM_LCTL_CPA BIT(8)
49 #define SDW_SHIM_SYNC_SYNCPRD_VAL 0x176F
50 #define SDW_SHIM_SYNC_SYNCPRD GENMASK(14, 0)
51 #define SDW_SHIM_SYNC_SYNCCPU BIT(15)
52 #define SDW_SHIM_SYNC_CMDSYNC_MASK GENMASK(19, 16)
53 #define SDW_SHIM_SYNC_CMDSYNC BIT(16)
54 #define SDW_SHIM_SYNC_SYNCGO BIT(24)
56 #define SDW_SHIM_PCMSCAP_ISS GENMASK(3, 0)
57 #define SDW_SHIM_PCMSCAP_OSS GENMASK(7, 4)
58 #define SDW_SHIM_PCMSCAP_BSS GENMASK(12, 8)
60 #define SDW_SHIM_PCMSYCM_LCHN GENMASK(3, 0)
61 #define SDW_SHIM_PCMSYCM_HCHN GENMASK(7, 4)
62 #define SDW_SHIM_PCMSYCM_STREAM GENMASK(13, 8)
63 #define SDW_SHIM_PCMSYCM_DIR BIT(15)
65 #define SDW_SHIM_PDMSCAP_ISS GENMASK(3, 0)
66 #define SDW_SHIM_PDMSCAP_OSS GENMASK(7, 4)
67 #define SDW_SHIM_PDMSCAP_BSS GENMASK(12, 8)
68 #define SDW_SHIM_PDMSCAP_CPSS GENMASK(15, 13)
70 #define SDW_SHIM_IOCTL_MIF BIT(0)
71 #define SDW_SHIM_IOCTL_CO BIT(1)
72 #define SDW_SHIM_IOCTL_COE BIT(2)
73 #define SDW_SHIM_IOCTL_DO BIT(3)
74 #define SDW_SHIM_IOCTL_DOE BIT(4)
75 #define SDW_SHIM_IOCTL_BKE BIT(5)
76 #define SDW_SHIM_IOCTL_WPDD BIT(6)
77 #define SDW_SHIM_IOCTL_CIBD BIT(8)
78 #define SDW_SHIM_IOCTL_DIBD BIT(9)
80 #define SDW_SHIM_CTMCTL_DACTQE BIT(0)
81 #define SDW_SHIM_CTMCTL_DODS BIT(1)
82 #define SDW_SHIM_CTMCTL_DOAIS GENMASK(4, 3)
84 #define SDW_SHIM_WAKEEN_ENABLE BIT(0)
85 #define SDW_SHIM_WAKESTS_STATUS BIT(0)
87 /* Intel ALH Register definitions */
88 #define SDW_ALH_STRMZCFG(x) (0x000 + (0x4 * (x)))
89 #define SDW_ALH_NUM_STREAMS 64
91 #define SDW_ALH_STRMZCFG_DMAT_VAL 0x3
92 #define SDW_ALH_STRMZCFG_DMAT GENMASK(7, 0)
93 #define SDW_ALH_STRMZCFG_CHN GENMASK(19, 16)
95 #define SDW_INTEL_QUIRK_MASK_BUS_DISABLE BIT(1)
104 struct sdw_cdns cdns
;
106 struct sdw_intel_link_res
*link_res
;
107 #ifdef CONFIG_DEBUG_FS
108 struct dentry
*debugfs
;
112 #define cdns_to_intel(_cdns) container_of(_cdns, struct sdw_intel, cdns)
115 * Read, write helpers for HW registers
117 static inline int intel_readl(void __iomem
*base
, int offset
)
119 return readl(base
+ offset
);
122 static inline void intel_writel(void __iomem
*base
, int offset
, int value
)
124 writel(value
, base
+ offset
);
127 static inline u16
intel_readw(void __iomem
*base
, int offset
)
129 return readw(base
+ offset
);
132 static inline void intel_writew(void __iomem
*base
, int offset
, u16 value
)
134 writew(value
, base
+ offset
);
137 static int intel_clear_bit(void __iomem
*base
, int offset
, u32 value
, u32 mask
)
142 writel(value
, base
+ offset
);
144 reg_read
= readl(base
+ offset
);
145 if (!(reg_read
& mask
))
150 } while (timeout
!= 0);
155 static int intel_set_bit(void __iomem
*base
, int offset
, u32 value
, u32 mask
)
160 writel(value
, base
+ offset
);
162 reg_read
= readl(base
+ offset
);
168 } while (timeout
!= 0);
176 #ifdef CONFIG_DEBUG_FS
178 #define RD_BUF (2 * PAGE_SIZE)
180 static ssize_t
intel_sprintf(void __iomem
*mem
, bool l
,
181 char *buf
, size_t pos
, unsigned int reg
)
186 value
= intel_readl(mem
, reg
);
188 value
= intel_readw(mem
, reg
);
190 return scnprintf(buf
+ pos
, RD_BUF
- pos
, "%4x\t%4x\n", reg
, value
);
193 static int intel_reg_show(struct seq_file
*s_file
, void *data
)
195 struct sdw_intel
*sdw
= s_file
->private;
196 void __iomem
*s
= sdw
->link_res
->shim
;
197 void __iomem
*a
= sdw
->link_res
->alh
;
201 unsigned int links
, reg
;
203 buf
= kzalloc(RD_BUF
, GFP_KERNEL
);
207 links
= intel_readl(s
, SDW_SHIM_LCAP
) & GENMASK(2, 0);
209 ret
= scnprintf(buf
, RD_BUF
, "Register Value\n");
210 ret
+= scnprintf(buf
+ ret
, RD_BUF
- ret
, "\nShim\n");
212 for (i
= 0; i
< links
; i
++) {
213 reg
= SDW_SHIM_LCAP
+ i
* 4;
214 ret
+= intel_sprintf(s
, true, buf
, ret
, reg
);
217 for (i
= 0; i
< links
; i
++) {
218 ret
+= scnprintf(buf
+ ret
, RD_BUF
- ret
, "\nLink%d\n", i
);
219 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_CTLSCAP(i
));
220 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_CTLS0CM(i
));
221 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_CTLS1CM(i
));
222 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_CTLS2CM(i
));
223 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_CTLS3CM(i
));
224 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_PCMSCAP(i
));
226 ret
+= scnprintf(buf
+ ret
, RD_BUF
- ret
, "\n PCMSyCH registers\n");
229 * the value 10 is the number of PDIs. We will need a
230 * cleanup to remove hard-coded Intel configurations
231 * from cadence_master.c
233 for (j
= 0; j
< 10; j
++) {
234 ret
+= intel_sprintf(s
, false, buf
, ret
,
235 SDW_SHIM_PCMSYCHM(i
, j
));
236 ret
+= intel_sprintf(s
, false, buf
, ret
,
237 SDW_SHIM_PCMSYCHC(i
, j
));
239 ret
+= scnprintf(buf
+ ret
, RD_BUF
- ret
, "\n PDMSCAP, IOCTL, CTMCTL\n");
241 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_PDMSCAP(i
));
242 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_IOCTL(i
));
243 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_CTMCTL(i
));
246 ret
+= scnprintf(buf
+ ret
, RD_BUF
- ret
, "\nWake registers\n");
247 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_WAKEEN
);
248 ret
+= intel_sprintf(s
, false, buf
, ret
, SDW_SHIM_WAKESTS
);
250 ret
+= scnprintf(buf
+ ret
, RD_BUF
- ret
, "\nALH STRMzCFG\n");
251 for (i
= 0; i
< SDW_ALH_NUM_STREAMS
; i
++)
252 ret
+= intel_sprintf(a
, true, buf
, ret
, SDW_ALH_STRMZCFG(i
));
254 seq_printf(s_file
, "%s", buf
);
259 DEFINE_SHOW_ATTRIBUTE(intel_reg
);
261 static void intel_debugfs_init(struct sdw_intel
*sdw
)
263 struct dentry
*root
= sdw
->cdns
.bus
.debugfs
;
268 sdw
->debugfs
= debugfs_create_dir("intel-sdw", root
);
270 debugfs_create_file("intel-registers", 0400, sdw
->debugfs
, sdw
,
273 sdw_cdns_debugfs_init(&sdw
->cdns
, sdw
->debugfs
);
276 static void intel_debugfs_exit(struct sdw_intel
*sdw
)
278 debugfs_remove_recursive(sdw
->debugfs
);
281 static void intel_debugfs_init(struct sdw_intel
*sdw
) {}
282 static void intel_debugfs_exit(struct sdw_intel
*sdw
) {}
283 #endif /* CONFIG_DEBUG_FS */
289 static int intel_link_power_up(struct sdw_intel
*sdw
)
291 unsigned int link_id
= sdw
->instance
;
292 void __iomem
*shim
= sdw
->link_res
->shim
;
293 int spa_mask
, cpa_mask
;
294 int link_control
, ret
;
296 /* Link power up sequence */
297 link_control
= intel_readl(shim
, SDW_SHIM_LCTL
);
298 spa_mask
= (SDW_SHIM_LCTL_SPA
<< link_id
);
299 cpa_mask
= (SDW_SHIM_LCTL_CPA
<< link_id
);
300 link_control
|= spa_mask
;
302 ret
= intel_set_bit(shim
, SDW_SHIM_LCTL
, link_control
, cpa_mask
);
306 sdw
->cdns
.link_up
= true;
310 static int intel_shim_init(struct sdw_intel
*sdw
)
312 void __iomem
*shim
= sdw
->link_res
->shim
;
313 unsigned int link_id
= sdw
->instance
;
315 u16 ioctl
= 0, act
= 0;
317 /* Initialize Shim */
318 ioctl
|= SDW_SHIM_IOCTL_BKE
;
319 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
321 ioctl
|= SDW_SHIM_IOCTL_WPDD
;
322 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
324 ioctl
|= SDW_SHIM_IOCTL_DO
;
325 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
327 ioctl
|= SDW_SHIM_IOCTL_DOE
;
328 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
330 /* Switch to MIP from Glue logic */
331 ioctl
= intel_readw(shim
, SDW_SHIM_IOCTL(link_id
));
333 ioctl
&= ~(SDW_SHIM_IOCTL_DOE
);
334 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
336 ioctl
&= ~(SDW_SHIM_IOCTL_DO
);
337 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
339 ioctl
|= (SDW_SHIM_IOCTL_MIF
);
340 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
342 ioctl
&= ~(SDW_SHIM_IOCTL_BKE
);
343 ioctl
&= ~(SDW_SHIM_IOCTL_COE
);
345 intel_writew(shim
, SDW_SHIM_IOCTL(link_id
), ioctl
);
347 act
|= 0x1 << SDW_REG_SHIFT(SDW_SHIM_CTMCTL_DOAIS
);
348 act
|= SDW_SHIM_CTMCTL_DACTQE
;
349 act
|= SDW_SHIM_CTMCTL_DODS
;
350 intel_writew(shim
, SDW_SHIM_CTMCTL(link_id
), act
);
352 /* Now set SyncPRD period */
353 sync_reg
= intel_readl(shim
, SDW_SHIM_SYNC
);
354 sync_reg
|= (SDW_SHIM_SYNC_SYNCPRD_VAL
<<
355 SDW_REG_SHIFT(SDW_SHIM_SYNC_SYNCPRD
));
357 /* Set SyncCPU bit */
358 sync_reg
|= SDW_SHIM_SYNC_SYNCCPU
;
359 ret
= intel_clear_bit(shim
, SDW_SHIM_SYNC
, sync_reg
,
360 SDW_SHIM_SYNC_SYNCCPU
);
362 dev_err(sdw
->cdns
.dev
, "Failed to set sync period: %d\n", ret
);
370 static void intel_pdi_init(struct sdw_intel
*sdw
,
371 struct sdw_cdns_stream_config
*config
)
373 void __iomem
*shim
= sdw
->link_res
->shim
;
374 unsigned int link_id
= sdw
->instance
;
375 int pcm_cap
, pdm_cap
;
377 /* PCM Stream Capability */
378 pcm_cap
= intel_readw(shim
, SDW_SHIM_PCMSCAP(link_id
));
380 config
->pcm_bd
= (pcm_cap
& SDW_SHIM_PCMSCAP_BSS
) >>
381 SDW_REG_SHIFT(SDW_SHIM_PCMSCAP_BSS
);
382 config
->pcm_in
= (pcm_cap
& SDW_SHIM_PCMSCAP_ISS
) >>
383 SDW_REG_SHIFT(SDW_SHIM_PCMSCAP_ISS
);
384 config
->pcm_out
= (pcm_cap
& SDW_SHIM_PCMSCAP_OSS
) >>
385 SDW_REG_SHIFT(SDW_SHIM_PCMSCAP_OSS
);
387 dev_dbg(sdw
->cdns
.dev
, "PCM cap bd:%d in:%d out:%d\n",
388 config
->pcm_bd
, config
->pcm_in
, config
->pcm_out
);
390 /* PDM Stream Capability */
391 pdm_cap
= intel_readw(shim
, SDW_SHIM_PDMSCAP(link_id
));
393 config
->pdm_bd
= (pdm_cap
& SDW_SHIM_PDMSCAP_BSS
) >>
394 SDW_REG_SHIFT(SDW_SHIM_PDMSCAP_BSS
);
395 config
->pdm_in
= (pdm_cap
& SDW_SHIM_PDMSCAP_ISS
) >>
396 SDW_REG_SHIFT(SDW_SHIM_PDMSCAP_ISS
);
397 config
->pdm_out
= (pdm_cap
& SDW_SHIM_PDMSCAP_OSS
) >>
398 SDW_REG_SHIFT(SDW_SHIM_PDMSCAP_OSS
);
400 dev_dbg(sdw
->cdns
.dev
, "PDM cap bd:%d in:%d out:%d\n",
401 config
->pdm_bd
, config
->pdm_in
, config
->pdm_out
);
405 intel_pdi_get_ch_cap(struct sdw_intel
*sdw
, unsigned int pdi_num
, bool pcm
)
407 void __iomem
*shim
= sdw
->link_res
->shim
;
408 unsigned int link_id
= sdw
->instance
;
412 count
= intel_readw(shim
, SDW_SHIM_PCMSYCHC(link_id
, pdi_num
));
415 * WORKAROUND: on all existing Intel controllers, pdi
416 * number 2 reports channel count as 1 even though it
417 * supports 8 channels. Performing hardcoding for pdi
424 count
= intel_readw(shim
, SDW_SHIM_PDMSCAP(link_id
));
425 count
= ((count
& SDW_SHIM_PDMSCAP_CPSS
) >>
426 SDW_REG_SHIFT(SDW_SHIM_PDMSCAP_CPSS
));
429 /* zero based values for channel count in register */
435 static int intel_pdi_get_ch_update(struct sdw_intel
*sdw
,
436 struct sdw_cdns_pdi
*pdi
,
437 unsigned int num_pdi
,
438 unsigned int *num_ch
, bool pcm
)
442 for (i
= 0; i
< num_pdi
; i
++) {
443 pdi
->ch_count
= intel_pdi_get_ch_cap(sdw
, pdi
->num
, pcm
);
444 ch_count
+= pdi
->ch_count
;
452 static int intel_pdi_stream_ch_update(struct sdw_intel
*sdw
,
453 struct sdw_cdns_streams
*stream
, bool pcm
)
455 intel_pdi_get_ch_update(sdw
, stream
->bd
, stream
->num_bd
,
456 &stream
->num_ch_bd
, pcm
);
458 intel_pdi_get_ch_update(sdw
, stream
->in
, stream
->num_in
,
459 &stream
->num_ch_in
, pcm
);
461 intel_pdi_get_ch_update(sdw
, stream
->out
, stream
->num_out
,
462 &stream
->num_ch_out
, pcm
);
467 static int intel_pdi_ch_update(struct sdw_intel
*sdw
)
469 /* First update PCM streams followed by PDM streams */
470 intel_pdi_stream_ch_update(sdw
, &sdw
->cdns
.pcm
, true);
471 intel_pdi_stream_ch_update(sdw
, &sdw
->cdns
.pdm
, false);
477 intel_pdi_shim_configure(struct sdw_intel
*sdw
, struct sdw_cdns_pdi
*pdi
)
479 void __iomem
*shim
= sdw
->link_res
->shim
;
480 unsigned int link_id
= sdw
->instance
;
483 /* the Bulk and PCM streams are not contiguous */
484 pdi
->intel_alh_id
= (link_id
* 16) + pdi
->num
+ 3;
486 pdi
->intel_alh_id
+= 2;
489 * Program stream parameters to stream SHIM register
490 * This is applicable for PCM stream only.
492 if (pdi
->type
!= SDW_STREAM_PCM
)
495 if (pdi
->dir
== SDW_DATA_DIR_RX
)
496 pdi_conf
|= SDW_SHIM_PCMSYCM_DIR
;
498 pdi_conf
&= ~(SDW_SHIM_PCMSYCM_DIR
);
500 pdi_conf
|= (pdi
->intel_alh_id
<<
501 SDW_REG_SHIFT(SDW_SHIM_PCMSYCM_STREAM
));
502 pdi_conf
|= (pdi
->l_ch_num
<< SDW_REG_SHIFT(SDW_SHIM_PCMSYCM_LCHN
));
503 pdi_conf
|= (pdi
->h_ch_num
<< SDW_REG_SHIFT(SDW_SHIM_PCMSYCM_HCHN
));
505 intel_writew(shim
, SDW_SHIM_PCMSYCHM(link_id
, pdi
->num
), pdi_conf
);
509 intel_pdi_alh_configure(struct sdw_intel
*sdw
, struct sdw_cdns_pdi
*pdi
)
511 void __iomem
*alh
= sdw
->link_res
->alh
;
512 unsigned int link_id
= sdw
->instance
;
515 /* the Bulk and PCM streams are not contiguous */
516 pdi
->intel_alh_id
= (link_id
* 16) + pdi
->num
+ 3;
518 pdi
->intel_alh_id
+= 2;
520 /* Program Stream config ALH register */
521 conf
= intel_readl(alh
, SDW_ALH_STRMZCFG(pdi
->intel_alh_id
));
523 conf
|= (SDW_ALH_STRMZCFG_DMAT_VAL
<<
524 SDW_REG_SHIFT(SDW_ALH_STRMZCFG_DMAT
));
526 conf
|= ((pdi
->ch_count
- 1) <<
527 SDW_REG_SHIFT(SDW_ALH_STRMZCFG_CHN
));
529 intel_writel(alh
, SDW_ALH_STRMZCFG(pdi
->intel_alh_id
), conf
);
532 static int intel_params_stream(struct sdw_intel
*sdw
,
533 struct snd_pcm_substream
*substream
,
534 struct snd_soc_dai
*dai
,
535 struct snd_pcm_hw_params
*hw_params
,
536 int link_id
, int alh_stream_id
)
538 struct sdw_intel_link_res
*res
= sdw
->link_res
;
539 struct sdw_intel_stream_params_data params_data
;
541 params_data
.substream
= substream
;
542 params_data
.dai
= dai
;
543 params_data
.hw_params
= hw_params
;
544 params_data
.link_id
= link_id
;
545 params_data
.alh_stream_id
= alh_stream_id
;
547 if (res
->ops
&& res
->ops
->params_stream
&& res
->dev
)
548 return res
->ops
->params_stream(res
->dev
,
553 static int intel_free_stream(struct sdw_intel
*sdw
,
554 struct snd_pcm_substream
*substream
,
555 struct snd_soc_dai
*dai
,
558 struct sdw_intel_link_res
*res
= sdw
->link_res
;
559 struct sdw_intel_stream_free_data free_data
;
561 free_data
.substream
= substream
;
563 free_data
.link_id
= link_id
;
565 if (res
->ops
&& res
->ops
->free_stream
&& res
->dev
)
566 return res
->ops
->free_stream(res
->dev
,
573 * bank switch routines
576 static int intel_pre_bank_switch(struct sdw_bus
*bus
)
578 struct sdw_cdns
*cdns
= bus_to_cdns(bus
);
579 struct sdw_intel
*sdw
= cdns_to_intel(cdns
);
580 void __iomem
*shim
= sdw
->link_res
->shim
;
583 /* Write to register only for multi-link */
584 if (!bus
->multi_link
)
587 /* Read SYNC register */
588 sync_reg
= intel_readl(shim
, SDW_SHIM_SYNC
);
589 sync_reg
|= SDW_SHIM_SYNC_CMDSYNC
<< sdw
->instance
;
590 intel_writel(shim
, SDW_SHIM_SYNC
, sync_reg
);
595 static int intel_post_bank_switch(struct sdw_bus
*bus
)
597 struct sdw_cdns
*cdns
= bus_to_cdns(bus
);
598 struct sdw_intel
*sdw
= cdns_to_intel(cdns
);
599 void __iomem
*shim
= sdw
->link_res
->shim
;
602 /* Write to register only for multi-link */
603 if (!bus
->multi_link
)
606 /* Read SYNC register */
607 sync_reg
= intel_readl(shim
, SDW_SHIM_SYNC
);
610 * post_bank_switch() ops is called from the bus in loop for
611 * all the Masters in the steam with the expectation that
612 * we trigger the bankswitch for the only first Master in the list
613 * and do nothing for the other Masters
615 * So, set the SYNCGO bit only if CMDSYNC bit is set for any Master.
617 if (!(sync_reg
& SDW_SHIM_SYNC_CMDSYNC_MASK
))
621 * Set SyncGO bit to synchronously trigger a bank switch for
622 * all the masters. A write to SYNCGO bit clears CMDSYNC bit for all
625 sync_reg
|= SDW_SHIM_SYNC_SYNCGO
;
627 ret
= intel_clear_bit(shim
, SDW_SHIM_SYNC
, sync_reg
,
628 SDW_SHIM_SYNC_SYNCGO
);
630 dev_err(sdw
->cdns
.dev
, "Post bank switch failed: %d\n", ret
);
639 static int sdw_stream_setup(struct snd_pcm_substream
*substream
,
640 struct snd_soc_dai
*dai
)
642 struct snd_soc_pcm_runtime
*rtd
= substream
->private_data
;
643 struct sdw_stream_runtime
*sdw_stream
= NULL
;
647 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
)
648 name
= kasprintf(GFP_KERNEL
, "%s-Playback", dai
->name
);
650 name
= kasprintf(GFP_KERNEL
, "%s-Capture", dai
->name
);
655 sdw_stream
= sdw_alloc_stream(name
);
657 dev_err(dai
->dev
, "alloc stream failed for DAI %s", dai
->name
);
662 /* Set stream pointer on CPU DAI */
663 ret
= snd_soc_dai_set_sdw_stream(dai
, sdw_stream
, substream
->stream
);
665 dev_err(dai
->dev
, "failed to set stream pointer on cpu dai %s",
670 /* Set stream pointer on all CODEC DAIs */
671 for (i
= 0; i
< rtd
->num_codecs
; i
++) {
672 ret
= snd_soc_dai_set_sdw_stream(rtd
->codec_dais
[i
], sdw_stream
,
675 dev_err(dai
->dev
, "failed to set stream pointer on codec dai %s",
676 rtd
->codec_dais
[i
]->name
);
684 sdw_release_stream(sdw_stream
);
690 static int intel_startup(struct snd_pcm_substream
*substream
,
691 struct snd_soc_dai
*dai
)
694 * TODO: add pm_runtime support here, the startup callback
695 * will make sure the IP is 'active'
698 return sdw_stream_setup(substream
, dai
);
701 static int intel_hw_params(struct snd_pcm_substream
*substream
,
702 struct snd_pcm_hw_params
*params
,
703 struct snd_soc_dai
*dai
)
705 struct sdw_cdns
*cdns
= snd_soc_dai_get_drvdata(dai
);
706 struct sdw_intel
*sdw
= cdns_to_intel(cdns
);
707 struct sdw_cdns_dma_data
*dma
;
708 struct sdw_cdns_pdi
*pdi
;
709 struct sdw_stream_config sconfig
;
710 struct sdw_port_config
*pconfig
;
715 dma
= snd_soc_dai_get_dma_data(dai
, substream
);
719 ch
= params_channels(params
);
720 if (substream
->stream
== SNDRV_PCM_STREAM_CAPTURE
)
721 dir
= SDW_DATA_DIR_RX
;
723 dir
= SDW_DATA_DIR_TX
;
725 if (dma
->stream_type
== SDW_STREAM_PDM
)
729 pdi
= sdw_cdns_alloc_pdi(cdns
, &cdns
->pcm
, ch
, dir
, dai
->id
);
731 pdi
= sdw_cdns_alloc_pdi(cdns
, &cdns
->pdm
, ch
, dir
, dai
->id
);
738 /* do run-time configurations for SHIM, ALH and PDI/PORT */
739 intel_pdi_shim_configure(sdw
, pdi
);
740 intel_pdi_alh_configure(sdw
, pdi
);
741 sdw_cdns_config_stream(cdns
, ch
, dir
, pdi
);
744 /* Inform DSP about PDI stream number */
745 ret
= intel_params_stream(sdw
, substream
, dai
, params
,
751 sconfig
.direction
= dir
;
752 sconfig
.ch_count
= ch
;
753 sconfig
.frame_rate
= params_rate(params
);
754 sconfig
.type
= dma
->stream_type
;
756 if (dma
->stream_type
== SDW_STREAM_PDM
) {
757 sconfig
.frame_rate
*= 50;
760 sconfig
.bps
= snd_pcm_format_width(params_format(params
));
763 /* Port configuration */
764 pconfig
= kcalloc(1, sizeof(*pconfig
), GFP_KERNEL
);
770 pconfig
->num
= pdi
->num
;
771 pconfig
->ch_mask
= (1 << ch
) - 1;
773 ret
= sdw_stream_add_master(&cdns
->bus
, &sconfig
,
774 pconfig
, 1, dma
->stream
);
776 dev_err(cdns
->dev
, "add master to stream failed:%d\n", ret
);
783 static int intel_prepare(struct snd_pcm_substream
*substream
,
784 struct snd_soc_dai
*dai
)
786 struct sdw_cdns_dma_data
*dma
;
788 dma
= snd_soc_dai_get_dma_data(dai
, substream
);
790 dev_err(dai
->dev
, "failed to get dma data in %s",
795 return sdw_prepare_stream(dma
->stream
);
798 static int intel_trigger(struct snd_pcm_substream
*substream
, int cmd
,
799 struct snd_soc_dai
*dai
)
801 struct sdw_cdns_dma_data
*dma
;
804 dma
= snd_soc_dai_get_dma_data(dai
, substream
);
806 dev_err(dai
->dev
, "failed to get dma data in %s", __func__
);
811 case SNDRV_PCM_TRIGGER_START
:
812 case SNDRV_PCM_TRIGGER_PAUSE_RELEASE
:
813 case SNDRV_PCM_TRIGGER_RESUME
:
814 ret
= sdw_enable_stream(dma
->stream
);
817 case SNDRV_PCM_TRIGGER_PAUSE_PUSH
:
818 case SNDRV_PCM_TRIGGER_SUSPEND
:
819 case SNDRV_PCM_TRIGGER_STOP
:
820 ret
= sdw_disable_stream(dma
->stream
);
830 "%s trigger %d failed: %d",
836 intel_hw_free(struct snd_pcm_substream
*substream
, struct snd_soc_dai
*dai
)
838 struct sdw_cdns
*cdns
= snd_soc_dai_get_drvdata(dai
);
839 struct sdw_intel
*sdw
= cdns_to_intel(cdns
);
840 struct sdw_cdns_dma_data
*dma
;
843 dma
= snd_soc_dai_get_dma_data(dai
, substream
);
847 ret
= sdw_deprepare_stream(dma
->stream
);
849 dev_err(dai
->dev
, "sdw_deprepare_stream: failed %d", ret
);
853 ret
= sdw_stream_remove_master(&cdns
->bus
, dma
->stream
);
855 dev_err(dai
->dev
, "remove master from stream %s failed: %d\n",
856 dma
->stream
->name
, ret
);
860 ret
= intel_free_stream(sdw
, substream
, dai
, sdw
->instance
);
862 dev_err(dai
->dev
, "intel_free_stream: failed %d", ret
);
866 kfree(dma
->stream
->name
);
867 sdw_release_stream(dma
->stream
);
872 static void intel_shutdown(struct snd_pcm_substream
*substream
,
873 struct snd_soc_dai
*dai
)
875 struct sdw_cdns_dma_data
*dma
;
877 dma
= snd_soc_dai_get_dma_data(dai
, substream
);
881 snd_soc_dai_set_dma_data(dai
, substream
, NULL
);
885 static int intel_pcm_set_sdw_stream(struct snd_soc_dai
*dai
,
886 void *stream
, int direction
)
888 return cdns_set_sdw_stream(dai
, stream
, true, direction
);
891 static int intel_pdm_set_sdw_stream(struct snd_soc_dai
*dai
,
892 void *stream
, int direction
)
894 return cdns_set_sdw_stream(dai
, stream
, false, direction
);
897 static const struct snd_soc_dai_ops intel_pcm_dai_ops
= {
898 .startup
= intel_startup
,
899 .hw_params
= intel_hw_params
,
900 .prepare
= intel_prepare
,
901 .trigger
= intel_trigger
,
902 .hw_free
= intel_hw_free
,
903 .shutdown
= intel_shutdown
,
904 .set_sdw_stream
= intel_pcm_set_sdw_stream
,
907 static const struct snd_soc_dai_ops intel_pdm_dai_ops
= {
908 .startup
= intel_startup
,
909 .hw_params
= intel_hw_params
,
910 .prepare
= intel_prepare
,
911 .trigger
= intel_trigger
,
912 .hw_free
= intel_hw_free
,
913 .shutdown
= intel_shutdown
,
914 .set_sdw_stream
= intel_pdm_set_sdw_stream
,
917 static const struct snd_soc_component_driver dai_component
= {
921 static int intel_create_dai(struct sdw_cdns
*cdns
,
922 struct snd_soc_dai_driver
*dais
,
923 enum intel_pdi_type type
,
924 u32 num
, u32 off
, u32 max_ch
, bool pcm
)
931 /* TODO: Read supported rates/formats from hardware */
932 for (i
= off
; i
< (off
+ num
); i
++) {
933 dais
[i
].name
= kasprintf(GFP_KERNEL
, "SDW%d Pin%d",
938 if (type
== INTEL_PDI_BD
|| type
== INTEL_PDI_OUT
) {
939 dais
[i
].playback
.channels_min
= 1;
940 dais
[i
].playback
.channels_max
= max_ch
;
941 dais
[i
].playback
.rates
= SNDRV_PCM_RATE_48000
;
942 dais
[i
].playback
.formats
= SNDRV_PCM_FMTBIT_S16_LE
;
945 if (type
== INTEL_PDI_BD
|| type
== INTEL_PDI_IN
) {
946 dais
[i
].capture
.channels_min
= 1;
947 dais
[i
].capture
.channels_max
= max_ch
;
948 dais
[i
].capture
.rates
= SNDRV_PCM_RATE_48000
;
949 dais
[i
].capture
.formats
= SNDRV_PCM_FMTBIT_S16_LE
;
953 dais
[i
].ops
= &intel_pcm_dai_ops
;
955 dais
[i
].ops
= &intel_pdm_dai_ops
;
961 static int intel_register_dai(struct sdw_intel
*sdw
)
963 struct sdw_cdns
*cdns
= &sdw
->cdns
;
964 struct sdw_cdns_streams
*stream
;
965 struct snd_soc_dai_driver
*dais
;
966 int num_dai
, ret
, off
= 0;
968 /* DAIs are created based on total number of PDIs supported */
969 num_dai
= cdns
->pcm
.num_pdi
+ cdns
->pdm
.num_pdi
;
971 dais
= devm_kcalloc(cdns
->dev
, num_dai
, sizeof(*dais
), GFP_KERNEL
);
975 /* Create PCM DAIs */
978 ret
= intel_create_dai(cdns
, dais
, INTEL_PDI_IN
, cdns
->pcm
.num_in
,
979 off
, stream
->num_ch_in
, true);
983 off
+= cdns
->pcm
.num_in
;
984 ret
= intel_create_dai(cdns
, dais
, INTEL_PDI_OUT
, cdns
->pcm
.num_out
,
985 off
, stream
->num_ch_out
, true);
989 off
+= cdns
->pcm
.num_out
;
990 ret
= intel_create_dai(cdns
, dais
, INTEL_PDI_BD
, cdns
->pcm
.num_bd
,
991 off
, stream
->num_ch_bd
, true);
995 /* Create PDM DAIs */
997 off
+= cdns
->pcm
.num_bd
;
998 ret
= intel_create_dai(cdns
, dais
, INTEL_PDI_IN
, cdns
->pdm
.num_in
,
999 off
, stream
->num_ch_in
, false);
1003 off
+= cdns
->pdm
.num_in
;
1004 ret
= intel_create_dai(cdns
, dais
, INTEL_PDI_OUT
, cdns
->pdm
.num_out
,
1005 off
, stream
->num_ch_out
, false);
1009 off
+= cdns
->pdm
.num_out
;
1010 ret
= intel_create_dai(cdns
, dais
, INTEL_PDI_BD
, cdns
->pdm
.num_bd
,
1011 off
, stream
->num_ch_bd
, false);
1015 return snd_soc_register_component(cdns
->dev
, &dai_component
,
1019 static int sdw_master_read_intel_prop(struct sdw_bus
*bus
)
1021 struct sdw_master_prop
*prop
= &bus
->prop
;
1022 struct fwnode_handle
*link
;
1026 /* Find master handle */
1027 snprintf(name
, sizeof(name
),
1028 "mipi-sdw-link-%d-subproperties", bus
->link_id
);
1030 link
= device_get_named_child_node(bus
->dev
, name
);
1032 dev_err(bus
->dev
, "Master node %s not found\n", name
);
1036 fwnode_property_read_u32(link
,
1037 "intel-sdw-ip-clock",
1040 /* the values reported by BIOS are the 2x clock, not the bus clock */
1041 prop
->mclk_freq
/= 2;
1043 fwnode_property_read_u32(link
,
1047 if (quirk_mask
& SDW_INTEL_QUIRK_MASK_BUS_DISABLE
)
1048 prop
->hw_disabled
= true;
1053 static int intel_prop_read(struct sdw_bus
*bus
)
1055 /* Initialize with default handler to read all DisCo properties */
1056 sdw_master_read_prop(bus
);
1058 /* read Intel-specific properties */
1059 sdw_master_read_intel_prop(bus
);
1064 static struct sdw_master_ops sdw_intel_ops
= {
1065 .read_prop
= sdw_master_read_prop
,
1066 .xfer_msg
= cdns_xfer_msg
,
1067 .xfer_msg_defer
= cdns_xfer_msg_defer
,
1068 .reset_page_addr
= cdns_reset_page_addr
,
1069 .set_bus_conf
= cdns_bus_conf
,
1070 .pre_bank_switch
= intel_pre_bank_switch
,
1071 .post_bank_switch
= intel_post_bank_switch
,
1074 static int intel_init(struct sdw_intel
*sdw
)
1076 /* Initialize shim and controller */
1077 intel_link_power_up(sdw
);
1078 intel_shim_init(sdw
);
1080 return sdw_cdns_init(&sdw
->cdns
);
1086 static int intel_probe(struct platform_device
*pdev
)
1088 struct sdw_cdns_stream_config config
;
1089 struct sdw_intel
*sdw
;
1092 sdw
= devm_kzalloc(&pdev
->dev
, sizeof(*sdw
), GFP_KERNEL
);
1096 sdw
->instance
= pdev
->id
;
1097 sdw
->link_res
= dev_get_platdata(&pdev
->dev
);
1098 sdw
->cdns
.dev
= &pdev
->dev
;
1099 sdw
->cdns
.registers
= sdw
->link_res
->registers
;
1100 sdw
->cdns
.instance
= sdw
->instance
;
1101 sdw
->cdns
.msg_count
= 0;
1102 sdw
->cdns
.bus
.dev
= &pdev
->dev
;
1103 sdw
->cdns
.bus
.link_id
= pdev
->id
;
1105 sdw_cdns_probe(&sdw
->cdns
);
1107 /* Set property read ops */
1108 sdw_intel_ops
.read_prop
= intel_prop_read
;
1109 sdw
->cdns
.bus
.ops
= &sdw_intel_ops
;
1111 platform_set_drvdata(pdev
, sdw
);
1113 ret
= sdw_add_bus_master(&sdw
->cdns
.bus
);
1115 dev_err(&pdev
->dev
, "sdw_add_bus_master fail: %d\n", ret
);
1119 if (sdw
->cdns
.bus
.prop
.hw_disabled
) {
1120 dev_info(&pdev
->dev
, "SoundWire master %d is disabled, ignoring\n",
1121 sdw
->cdns
.bus
.link_id
);
1125 /* Initialize shim, controller and Cadence IP */
1126 ret
= intel_init(sdw
);
1130 /* Read the PDI config and initialize cadence PDI */
1131 intel_pdi_init(sdw
, &config
);
1132 ret
= sdw_cdns_pdi_init(&sdw
->cdns
, config
);
1136 intel_pdi_ch_update(sdw
);
1139 ret
= request_threaded_irq(sdw
->link_res
->irq
,
1140 sdw_cdns_irq
, sdw_cdns_thread
,
1141 IRQF_SHARED
, KBUILD_MODNAME
, &sdw
->cdns
);
1143 dev_err(sdw
->cdns
.dev
, "unable to grab IRQ %d, disabling device\n",
1144 sdw
->link_res
->irq
);
1148 ret
= sdw_cdns_enable_interrupt(&sdw
->cdns
, true);
1150 dev_err(sdw
->cdns
.dev
, "cannot enable interrupts\n");
1154 ret
= sdw_cdns_exit_reset(&sdw
->cdns
);
1156 dev_err(sdw
->cdns
.dev
, "unable to exit bus reset sequence\n");
1161 ret
= intel_register_dai(sdw
);
1163 dev_err(sdw
->cdns
.dev
, "DAI registration failed: %d\n", ret
);
1164 snd_soc_unregister_component(sdw
->cdns
.dev
);
1168 intel_debugfs_init(sdw
);
1173 sdw_cdns_enable_interrupt(&sdw
->cdns
, false);
1174 free_irq(sdw
->link_res
->irq
, sdw
);
1176 sdw_delete_bus_master(&sdw
->cdns
.bus
);
1180 static int intel_remove(struct platform_device
*pdev
)
1182 struct sdw_intel
*sdw
;
1184 sdw
= platform_get_drvdata(pdev
);
1186 if (!sdw
->cdns
.bus
.prop
.hw_disabled
) {
1187 intel_debugfs_exit(sdw
);
1188 sdw_cdns_enable_interrupt(&sdw
->cdns
, false);
1189 free_irq(sdw
->link_res
->irq
, sdw
);
1190 snd_soc_unregister_component(sdw
->cdns
.dev
);
1192 sdw_delete_bus_master(&sdw
->cdns
.bus
);
1197 static struct platform_driver sdw_intel_drv
= {
1198 .probe
= intel_probe
,
1199 .remove
= intel_remove
,
1206 module_platform_driver(sdw_intel_drv
);
1208 MODULE_LICENSE("Dual BSD/GPL");
1209 MODULE_ALIAS("platform:int-sdw");
1210 MODULE_DESCRIPTION("Intel Soundwire Master Driver");