diff options
| author | Dorian Rudolph <[email protected]> | 2022-05-14 17:23:40 +0200 | 
|---|---|---|
| committer | Sebastian Reichel <[email protected]> | 2022-06-09 21:08:38 +0200 | 
| commit | 093d27bb6f2d1963f927ef59c9a2d37059175426 (patch) | |
| tree | 7f1611046063d6f1d356acbd5200681e15851c1f /tools/perf/scripts/python/arm-cs-trace-disasm.py | |
| parent | 80192eff64eee9b3bc0594a47381937b94b9d65a (diff) | |
power: supply: core: Fix boundary conditions in interpolation
The functions power_supply_temp2resist_simple and power_supply_ocv2cap_simple
handle boundary conditions incorrectly.
The change was introduced in a4585ba2050f460f749bbaf2b67bd56c41e30283
("power: supply: core: Use library interpolation").
There are two issues: First, the lines "high = i - 1" and "high = i" in ocv2cap
have the wrong order compared to temp2resist. As a consequence, ocv2cap
sets high=-1 if ocv>table[0].ocv, which causes an out-of-bounds read.
Second, the logic of temp2resist is also not correct.
Consider the case table[] = {{20, 100}, {10, 80}, {0, 60}}.
For temp=5, we expect a resistance of 70% by interpolation.
However, temp2resist sets high=low=2 and returns 60.
Cc: [email protected]
Signed-off-by: Dorian Rudolph <[email protected]>
Reviewed-by: Linus Walleij <[email protected]>
Fixes: a4585ba2050f ("power: supply: core: Use library interpolation")
Signed-off-by: Sebastian Reichel <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/arm-cs-trace-disasm.py')
0 files changed, 0 insertions, 0 deletions