diff options
author | Vegard Nossum <vegard.nossum@gmail.com> | 2008-07-25 01:45:34 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-07-25 10:53:27 -0700 |
commit | 2fc9c4e18f94431e7eb77d97edb2a995b46fba55 (patch) | |
tree | 4d5f003ab52c9e50774c856a5cc2e53699b0b21e /kernel/kallsyms.c | |
parent | 58340a07c194e0aed7bc58b61ff24330bb2a409f (diff) | |
download | op-kernel-dev-2fc9c4e18f94431e7eb77d97edb2a995b46fba55.zip op-kernel-dev-2fc9c4e18f94431e7eb77d97edb2a995b46fba55.tar.gz |
kallsyms: fix potential overflow in binary search
This will probably never trigger... but it won't hurt to be careful.
http://googleresearch.blogspot.com/2006/06/extra-extra-read-all-about-it-nearly.html
Signed-off-by: Vegard Nossum <vegard.nossum@gmail.com>
Cc: Joshua Bloch <jjb@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel/kallsyms.c')
-rw-r--r-- | kernel/kallsyms.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/kernel/kallsyms.c b/kernel/kallsyms.c index 6fc0040..38fc10a 100644 --- a/kernel/kallsyms.c +++ b/kernel/kallsyms.c @@ -176,7 +176,7 @@ static unsigned long get_symbol_pos(unsigned long addr, high = kallsyms_num_syms; while (high - low > 1) { - mid = (low + high) / 2; + mid = low + (high - low) / 2; if (kallsyms_addresses[mid] <= addr) low = mid; else |