perf: Fix read buffer overflow
Check whether index is within bounds before testing the element. Signed-off-by: Roel Kluin <roel.kluin@gmail.com> Cc: a.p.zijlstra@chello.nl Cc: Andrew Morton <akpm@linux-foundation.org> LKML-Reference: <4A757BCF.40101@gmail.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
59b9005692
commit
7e030655dd
@ -253,7 +253,7 @@ static int strcommon(const char *pathname)
|
|||||||
{
|
{
|
||||||
int n = 0;
|
int n = 0;
|
||||||
|
|
||||||
while (pathname[n] == cwd[n] && n < cwdlen)
|
while (n < cwdlen && pathname[n] == cwd[n])
|
||||||
++n;
|
++n;
|
||||||
|
|
||||||
return n;
|
return n;
|
||||||
|
@ -318,7 +318,7 @@ char *quote_path_relative(const char *in, int len,
|
|||||||
strbuf_addch(out, '"');
|
strbuf_addch(out, '"');
|
||||||
if (prefix) {
|
if (prefix) {
|
||||||
int off = 0;
|
int off = 0;
|
||||||
while (prefix[off] && off < len && prefix[off] == in[off])
|
while (off < len && prefix[off] && prefix[off] == in[off])
|
||||||
if (prefix[off] == '/') {
|
if (prefix[off] == '/') {
|
||||||
prefix += off + 1;
|
prefix += off + 1;
|
||||||
in += off + 1;
|
in += off + 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user