summaryrefslogtreecommitdiff
path: root/sound
diff options
context:
space:
mode:
authorPiotr Krysiuk <piotras@gmail.com>2021-04-06 00:52:15 +0300
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2021-04-10 14:04:45 +0300
commitd4b234e44aa7108aeadc7b84b162c6f882597005 (patch)
treee409160d97ac97471d995982ca800f22a2123bd6 /sound
parent0709c90e4ee9eb5b7d238422b98712aaec4c817b (diff)
downloadlinux-d4b234e44aa7108aeadc7b84b162c6f882597005.tar.xz
bpf, x86: Validate computation of branch displacements for x86-64
commit e4d4d456436bfb2fe412ee2cd489f7658449b098 upstream. The branch displacement logic in the BPF JIT compilers for x86 assumes that, for any generated branch instruction, the distance cannot increase between optimization passes. But this assumption can be violated due to how the distances are computed. Specifically, whenever a backward branch is processed in do_jit(), the distance is computed by subtracting the positions in the machine code from different optimization passes. This is because part of addrs[] is already updated for the current optimization pass, before the branch instruction is visited. And so the optimizer can expand blocks of machine code in some cases. This can confuse the optimizer logic, where it assumes that a fixed point has been reached for all machine code blocks once the total program size stops changing. And then the JIT compiler can output abnormal machine code containing incorrect branch displacements. To mitigate this issue, we assert that a fixed point is reached while populating the output image. This rejects any problematic programs. The issue affects both x86-32 and x86-64. We mitigate separately to ease backporting. Signed-off-by: Piotr Krysiuk <piotras@gmail.com> Reviewed-by: Daniel Borkmann <daniel@iogearbox.net> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'sound')
0 files changed, 0 insertions, 0 deletions