Skip to content

Commit 167efc6

Browse files
bardliaovinodkoul
authored andcommitted
ASoC: SOF: Intel: export hda_sdw_bpt_get_buf_size_aligment
The dma buffer need to be a multiple of data block size and the fifo size. Export a function to return the LCM of data block size and the fifo size. Signed-off-by: Bard Liao <yung-chuan.liao@linux.intel.com> Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com> Link: https://patch.msgid.link/20251014031450.3781789-6-yung-chuan.liao@linux.intel.com Signed-off-by: Vinod Koul <vkoul@kernel.org>
1 parent 57b3a7b commit 167efc6

2 files changed

Lines changed: 20 additions & 0 deletions

File tree

include/sound/hda-sdw-bpt.h

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,8 @@ int hda_sdw_bpt_wait(struct device *dev, struct hdac_ext_stream *bpt_tx_stream,
3030
int hda_sdw_bpt_close(struct device *dev, struct hdac_ext_stream *bpt_tx_stream,
3131
struct snd_dma_buffer *dmab_tx_bdl, struct hdac_ext_stream *bpt_rx_stream,
3232
struct snd_dma_buffer *dmab_rx_bdl);
33+
34+
unsigned int hda_sdw_bpt_get_buf_size_alignment(unsigned int dma_bandwidth);
3335
#else
3436
static inline int hda_sdw_bpt_open(struct device *dev, int link_id,
3537
struct hdac_ext_stream **bpt_tx_stream,
@@ -64,6 +66,11 @@ static inline int hda_sdw_bpt_close(struct device *dev, struct hdac_ext_stream *
6466
WARN_ONCE(1, "SoundWire BPT is disabled");
6567
return -EOPNOTSUPP;
6668
}
69+
70+
static inline unsigned int hda_sdw_bpt_get_buf_size_alignment(unsigned int dma_bandwidth)
71+
{
72+
return 0;
73+
}
6774
#endif
6875

6976
#endif /* __HDA_SDW_BPT_H */

sound/soc/sof/intel/hda-sdw-bpt.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,7 @@
1010
* Hardware interface for SoundWire BPT support with HDA DMA
1111
*/
1212

13+
#include <linux/lcm.h>
1314
#include <sound/hdaudio_ext.h>
1415
#include <sound/hda-mlink.h>
1516
#include <sound/hda-sdw-bpt.h>
@@ -236,6 +237,18 @@ static int hda_sdw_bpt_dma_disable(struct device *dev, struct hdac_ext_stream *s
236237
return ret;
237238
}
238239

240+
#define FIFO_ALIGNMENT 64
241+
242+
unsigned int hda_sdw_bpt_get_buf_size_alignment(unsigned int dma_bandwidth)
243+
{
244+
unsigned int num_channels = DIV_ROUND_UP(dma_bandwidth, BPT_FREQUENCY * 32);
245+
unsigned int data_block = num_channels * 4;
246+
unsigned int alignment = lcm(data_block, FIFO_ALIGNMENT);
247+
248+
return alignment;
249+
}
250+
EXPORT_SYMBOL_NS(hda_sdw_bpt_get_buf_size_alignment, "SND_SOC_SOF_INTEL_HDA_SDW_BPT");
251+
239252
int hda_sdw_bpt_open(struct device *dev, int link_id, struct hdac_ext_stream **bpt_tx_stream,
240253
struct snd_dma_buffer *dmab_tx_bdl, u32 bpt_tx_num_bytes,
241254
u32 tx_dma_bandwidth, struct hdac_ext_stream **bpt_rx_stream,

0 commit comments

Comments
 (0)