Re: [PATCH 44/64] cachefiles: Implement key to filename encoding

From: David Howells
Date: Wed Dec 01 2021 - 03:29:41 EST


JeffleXu <jefflexu@xxxxxxxxxxxxxxxxx> wrote:

> > + /* If the path is usable ASCII, then we render it directly */
> > + if (print) {
> > + len = 1 + keylen + 1;
> > + name = kmalloc(len, GFP_KERNEL);
> > + if (!name)
> > + return false;
> > +
> > + name[0] = 'D'; /* Data object type, string encoding */
> > + name[1 + keylen] = 0;
> > + memcpy(name + 1, key, keylen);
> > + goto success;
> ^
> If we goto success from here,
> ...
> > +
> > +success:
> > + name[len] = 0;
> ^
> then it seems that this will cause an out-of-boundary access.

You're right. I'll change that to:

len = 1 + keylen;
name = kmalloc(len + 1, GFP_KERNEL);

and I shouldn't need:

name[1 + keylen] = 0;

as that's also done after the success label.

David