summaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python/Perf-Trace-Util/lib
diff options
context:
space:
mode:
authorGuenter Roeck <linux@roeck-us.net>2024-02-27 23:33:51 +0300
committerHelge Deller <deller@gmx.de>2024-02-28 00:51:45 +0300
commit0568b6f0d863643db2edcc7be31165740c89fa82 (patch)
tree4a836971c14f9aaf9bef34dfd3f494e916b1e98a /tools/perf/scripts/python/Perf-Trace-Util/lib
parent4b75b12d70506e31fc02356bbca60f8d5ca012d0 (diff)
downloadlinux-0568b6f0d863643db2edcc7be31165740c89fa82.tar.xz
parisc: Strip upper 32 bit of sum in csum_ipv6_magic for 64-bit builds
IPv6 checksum tests with unaligned addresses on 64-bit builds result in unexpected failures. Expected expected == csum_result, but expected == 46591 (0xb5ff) csum_result == 46381 (0xb52d) with alignment offset 1 Oddly enough, the problem disappeared after adding test code into the beginning of csum_ipv6_magic(). As it turns out, the 'sum' parameter of csum_ipv6_magic() is declared as __wsum, which is a 32-bit variable. However, it is treated as 64-bit variable in the 64-bit assembler code. Tests showed that the upper 32 bit of the register used to pass the variable are _not_ cleared when entering the function. This can result in checksum calculation errors. Clearing the upper 32 bit of 'sum' as first operation in the assembler code fixes the problem. Acked-by: Helge Deller <deller@gmx.de> Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") Cc: stable@vger.kernel.org Signed-off-by: Guenter Roeck <linux@roeck-us.net> Signed-off-by: Helge Deller <deller@gmx.de>
Diffstat (limited to 'tools/perf/scripts/python/Perf-Trace-Util/lib')
0 files changed, 0 insertions, 0 deletions