mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 13:53:24 +00:00
ALSA: cs5535audio: Fix invalid endian conversion
One place in cs5535audio_build_dma_packets() does an extra conversion via cpu_to_le32(); namely jmpprd_addr is passed to setup_prd() ops, which writes the value via cs_writel(). That is, the callback does the conversion by itself, and we don't need to convert beforehand. This patch fixes that bogus conversion. Cc: <stable@vger.kernel.org> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
3acd3e3bab
commit
69756930f2
@ -67,9 +67,9 @@ struct cs5535audio_dma_ops {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct cs5535audio_dma_desc {
|
struct cs5535audio_dma_desc {
|
||||||
u32 addr;
|
__le32 addr;
|
||||||
u16 size;
|
__le16 size;
|
||||||
u16 ctlreserved;
|
__le16 ctlreserved;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct cs5535audio_dma {
|
struct cs5535audio_dma {
|
||||||
|
@ -158,8 +158,8 @@ static int cs5535audio_build_dma_packets(struct cs5535audio *cs5535au,
|
|||||||
lastdesc->addr = cpu_to_le32((u32) dma->desc_buf.addr);
|
lastdesc->addr = cpu_to_le32((u32) dma->desc_buf.addr);
|
||||||
lastdesc->size = 0;
|
lastdesc->size = 0;
|
||||||
lastdesc->ctlreserved = cpu_to_le16(PRD_JMP);
|
lastdesc->ctlreserved = cpu_to_le16(PRD_JMP);
|
||||||
jmpprd_addr = cpu_to_le32(lastdesc->addr +
|
jmpprd_addr = (u32)dma->desc_buf.addr +
|
||||||
(sizeof(struct cs5535audio_dma_desc)*periods));
|
sizeof(struct cs5535audio_dma_desc) * periods;
|
||||||
|
|
||||||
dma->substream = substream;
|
dma->substream = substream;
|
||||||
dma->period_bytes = period_bytes;
|
dma->period_bytes = period_bytes;
|
||||||
|
Loading…
Reference in New Issue
Block a user