mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-18 11:54:37 +08:00
dmaengine: PL08x: Fix reading the byte count in cctl
There are more fields than just SWIDTH in CH_CONTROL register, so read register value must be masked in addition to shifting. Signed-off-by: Alban Bedel <alban.bedel@avionic-design.de> Signed-off-by: Tomasz Figa <tomasz.figa@gmail.com> Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Vinod Koul <vinod.koul@intel.com>
This commit is contained in:
parent
5110e51d12
commit
f3287a5206
@ -480,6 +480,8 @@ static inline u32 get_bytes_in_cctl(u32 cctl)
|
||||
/* The source width defines the number of bytes */
|
||||
u32 bytes = cctl & PL080_CONTROL_TRANSFER_SIZE_MASK;
|
||||
|
||||
cctl &= PL080_CONTROL_SWIDTH_MASK;
|
||||
|
||||
switch (cctl >> PL080_CONTROL_SWIDTH_SHIFT) {
|
||||
case PL080_WIDTH_8BIT:
|
||||
break;
|
||||
@ -498,6 +500,8 @@ static inline u32 get_bytes_in_cctl_pl080s(u32 cctl, u32 cctl1)
|
||||
/* The source width defines the number of bytes */
|
||||
u32 bytes = cctl1 & PL080S_CONTROL_TRANSFER_SIZE_MASK;
|
||||
|
||||
cctl &= PL080_CONTROL_SWIDTH_MASK;
|
||||
|
||||
switch (cctl >> PL080_CONTROL_SWIDTH_SHIFT) {
|
||||
case PL080_WIDTH_8BIT:
|
||||
break;
|
||||
|
Loading…
Reference in New Issue
Block a user