diff options
| author | Max Filippov <[email protected]> | 2022-03-05 21:05:54 -0800 | 
|---|---|---|
| committer | Max Filippov <[email protected]> | 2022-03-07 12:02:54 -0800 | 
| commit | 5b835d4cade1723c5944a231cc685801f5a5cc6c (patch) | |
| tree | c744c4af85ce0ee3c6a83e328cf7b445b5170a88 /tools/testing/selftests/bpf/prog_tests/access_variable_array.c | |
| parent | 6fad9ddc7d9f6dfb8a53c192f746c26e0d72ee35 (diff) | |
xtensa: use XCHAL_NUM_AREGS as pt_regs::areg size
struct pt_regs is used to access both kernel and user exception frames.
User exception frames may contain up to XCHAL_NUM_AREG registers that
task creation and signal delivery code may access, but pt_regs::areg
array has only 16 entries that cover only the kernel exception frame.
This results in the following build error:
arch/xtensa/kernel/process.c: In function 'copy_thread':
arch/xtensa/kernel/process.c:262:52: error: array subscript 53 is above
           array bounds of 'long unsigned int[16]' [-Werror=array-bounds]
  262 |                                 put_user(regs->areg[caller_ars+1],
Change struct pt_regs::areg size to XCHAL_NUM_AREGS so that it covers
the whole user exception frame. Adjust task_pt_regs and drop additional
register copying code from copy_thread now that the whole user exception
stack frame is copied.
Reported-by: Kees Cook <[email protected]>
Signed-off-by: Max Filippov <[email protected]>
Reviewed-by: Kees Cook <[email protected]>
Diffstat (limited to 'tools/testing/selftests/bpf/prog_tests/access_variable_array.c')
0 files changed, 0 insertions, 0 deletions