Skip to content
Snippets Groups Projects
Commit 5b10c8e4 authored by Russell King's avatar Russell King Committed by Russell King
Browse files

[ARM] Fix stacktrace FP range checking


Fix an oops in the stacktrace code, caused by improper range checking.
We subtract 12 off 'fp' before testing to see if it's below the low
bound.  However, if 'fp' were zero before, it becomes a very large
positive number, causing this test to succeed where it should fail.

Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent b91d8a12
No related branches found
No related tags found
Loading
...@@ -13,7 +13,7 @@ int walk_stackframe(unsigned long fp, unsigned long low, unsigned long high, ...@@ -13,7 +13,7 @@ int walk_stackframe(unsigned long fp, unsigned long low, unsigned long high,
/* /*
* Check current frame pointer is within bounds * Check current frame pointer is within bounds
*/ */
if ((fp - 12) < low || fp + 4 >= high) if (fp < (low + 12) || fp + 4 >= high)
break; break;
frame = (struct stackframe *)(fp - 12); frame = (struct stackframe *)(fp - 12);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment