Commit dadc01b
committed
Audio: Volume: Fix a possible overflow in S24_LE format volume
The AE_SRAI32R() right shift with round could cause the value to
go over S24_LE range by one if the gain would be over one or 0 dB
(only possible in IPC3). The rounding shift is unnecessary because
the gain product is already rounded in the multiply instruction.
The SRAI32() instruction does just the shift.
Fixes: f3e3403 ("Audio: Volume: Add IPC4 native Q1.31 mode
and optimize")
Signed-off-by: Seppo Ingalsuo <seppo.ingalsuo@linux.intel.com>1 parent d677107 commit dadc01b
File tree
4 files changed
+8
-8
lines changed- src/audio/volume
4 files changed
+8
-8
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
122 | 122 | | |
123 | 123 | | |
124 | 124 | | |
125 | | - | |
126 | | - | |
| 125 | + | |
| 126 | + | |
127 | 127 | | |
128 | 128 | | |
129 | 129 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
91 | 91 | | |
92 | 92 | | |
93 | 93 | | |
94 | | - | |
95 | | - | |
| 94 | + | |
| 95 | + | |
96 | 96 | | |
97 | 97 | | |
98 | 98 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
122 | 122 | | |
123 | 123 | | |
124 | 124 | | |
125 | | - | |
126 | | - | |
| 125 | + | |
| 126 | + | |
127 | 127 | | |
128 | 128 | | |
129 | 129 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
120 | 120 | | |
121 | 121 | | |
122 | 122 | | |
123 | | - | |
124 | | - | |
| 123 | + | |
| 124 | + | |
125 | 125 | | |
126 | 126 | | |
127 | 127 | | |
| |||
0 commit comments