On Wed, 2014-01-29 at 19:41 -0800, Sebastian Capella wrote: > Quoting Joe Perches (2014-01-29 17:24:28) > > Why not minimize the malloc length too? > >
> I figured it would be mostly for small trimming, but it seems like > it could be and advantage and used more generally this way. > > I have a couple of small changes to return NULL in empty string/all ws > cases and fix a buffer underrun. > > How does this look? [] > char *kstrimdup(const char *s, gfp_t gfp) > { > > char *buf; > > const char *begin = skip_spaces(s); > > size_t len = strlen(begin); > removing begin and just using s would work > if (len == 0) > > return NULL; > > > > while (len > 1 && isspace(begin[len - 1])) > > len--; > > > > buf = kmalloc_track_caller(len + 1, gfp); > > if (!buf) > > return NULL; > > > > memcpy(buf, begin, len); > > buf[len] = '\0'; > > > > return buf; > > } What should the return be to this string? " " Should it be "" or " " or NULL? I don't think it should be NULL. I don't think it should be " ". cheers, Joe -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/