Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751076AbaLOWXs (ORCPT ); Mon, 15 Dec 2014 17:23:48 -0500 Received: from mail-la0-f47.google.com ([209.85.215.47]:34031 "EHLO mail-la0-f47.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750745AbaLOWXr (ORCPT ); Mon, 15 Dec 2014 17:23:47 -0500 MIME-Version: 1.0 In-Reply-To: <1418608297.2674.4.camel@perches.com> References: <1418597547-25086-1-git-send-email-rickard_strandqvist@spectrumdigital.se> <1418608297.2674.4.camel@perches.com> From: Rickard Strandqvist Date: Mon, 15 Dec 2014 23:23:25 +0100 Message-ID: Subject: Re: [PATCH] staging: lustre: lustre: obdclass: lprocfs_status.c: Fix for possible null pointer dereference To: Joe Perches Cc: Oleg Drokin , Andreas Dilger , Greg Kroah-Hartman , Julia Lawall , Greg Donald , "John L. Hammond" , Andriy Skulysh , Fabian Frederick , James Simmons , HPDD-discuss@ml01.01.org, devel@driverdev.osuosl.org, "linux-kernel@vger.kernel.org" Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Joe No, it does not look like end can be NULL then. Then remove the end != NULL instead? ... if (end != NULL && *end == '.') { However, I am hesitant to the tolower() I think double case is faster...? Kind regards Rickard Strandqvist 2014-12-15 2:51 GMT+01:00 Joe Perches : > On Sun, 2014-12-14 at 23:52 +0100, Rickard Strandqvist wrote: >> There is otherwise a risk of a possible null pointer dereference. >> >> Was largely found by using a static code analysis program called cppcheck. > > Perhaps the tool could use a little work. > It's not possible for end to be NULL no? > > unsigned long long simple_strtoull(const char *cp, char **endp, unsigned int base) > { > unsigned long long result; > unsigned int rv; > > cp = _parse_integer_fixup_radix(cp, &base); > rv = _parse_integer(cp, base, &result); > /* FIXME */ > cp += (rv & ~KSTRTOX_OVERFLOW); > > if (endp) > *endp = (char *)cp; > > return result; > } > EXPORT_SYMBOL(simple_strtoull); > > >> diff --git a/drivers/staging/lustre/lustre/obdclass/lprocfs_status.c b/drivers/staging/lustre/lustre/obdclass/lprocfs_status.c > [] > > Above this: > > whole = simple_strtoull(pbuf, &end, 10); > >> +++ b/drivers/staging/lustre/lustre/obdclass/lprocfs_status.c >> @@ -1897,17 +1897,19 @@ int lprocfs_write_frac_u64_helper(const char *buffer, unsigned long count, >> } >> >> units = 1; >> - switch (*end) { >> - case 'p': case 'P': >> - units <<= 10; >> - case 't': case 'T': >> - units <<= 10; >> - case 'g': case 'G': >> - units <<= 10; >> - case 'm': case 'M': >> - units <<= 10; >> - case 'k': case 'K': >> - units <<= 10; >> + if (end) { >> + switch (*end) { >> + case 'p': case 'P': >> + units <<= 10; >> + case 't': case 'T': >> + units <<= 10; >> + case 'g': case 'G': >> + units <<= 10; >> + case 'm': case 'M': >> + units <<= 10; >> + case 'k': case 'K': >> + units <<= 10; >> + } > > The only thing I might do is > > switch (tolower(*end)) { > > and remove the second case entry for each line > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/