Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753447AbbGJGGL (ORCPT ); Fri, 10 Jul 2015 02:06:11 -0400 Received: from mga03.intel.com ([134.134.136.65]:11997 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752744AbbGJGGE (ORCPT ); Fri, 10 Jul 2015 02:06:04 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.15,445,1432623600"; d="scan'208";a="603511379" Message-ID: <559F6031.9010505@intel.com> Date: Fri, 10 Jul 2015 14:03:29 +0800 From: Pan Xinhui User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.5.0 MIME-Version: 1.0 To: Andrew Morton CC: linux-kernel@vger.kernel.org, linux@rasmusvillemoes.dk, tj@kernel.org, mnipxh@163.com, Chris Metcalf Subject: Re: [PATCH] lib/bitmap.c: add some check to correct the parse result References: <558E4462.7060600@intel.com> <20150709155701.3e3fe2cf5e7527d9aeb72338@linux-foundation.org> In-Reply-To: <20150709155701.3e3fe2cf5e7527d9aeb72338@linux-foundation.org> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4503 Lines: 135 hi, Andrew thanks for you kind reply :) On 2015年07月10日 06:57, Andrew Morton wrote: > On Sat, 27 Jun 2015 14:36:18 +0800 Pan Xinhui wrote: > >> Sometimes the input from user may cause an unexpected result. >> >> for example, echo "1-3," > /proc/irq//smp_affinity_list. >> The correct result should be 1-3, however we got 0-4. >> >> To avoid this issue, we check if there is a ready digit. >> If no valid digit is set, we just continue to the next parse. >> >> Signed-off-by: Pan Xinhui >> --- >> lib/bitmap.c | 2 ++ >> 1 file changed, 2 insertions(+) >> >> diff --git a/lib/bitmap.c b/lib/bitmap.c >> index 64c0926..3c489c1 100644 >> --- a/lib/bitmap.c >> +++ b/lib/bitmap.c >> @@ -561,6 +561,8 @@ static int __bitmap_parselist(const char *buf, unsigned int buflen, >> return -EINVAL; >> if (b >= nmaskbits) >> return -ERANGE; >> + if (unlikely(exp_digit)) >> + continue; >> while (a <= b) { >> set_bit(a, maskp); >> a++; > > This bug might have been fixed by 2528a8b8f457d7 ("__bitmap_parselist: > fix bug in empty string handling"), below. Please check? > > Yes, I noticed it after I sent this patch out. Sorry for not syncing the upstream codes. I am very happy that you reviewed my patch :) I send out other three patches to make current codes stronger :) they are [PATCH 1/3] lib/bitmap.c: correct a code style and do some optimization in __bitmap_parse [PATCH 2/3] lib/bitmap.c: fix a special string handling bug in __bitmap_parselist [PATCH 3/3] lib/bitmap.c: bitmap_parselist can accept string with whitespaces on head or tail Of course I have verified/test them :) They have minor codes change. thanks xinhui > commit 2528a8b8f457d7432552d0e2b6f0f4046bb702f4 > Author: Chris Metcalf > AuthorDate: Thu Jun 25 15:02:08 2015 -0700 > Commit: Linus Torvalds > CommitDate: Thu Jun 25 17:00:40 2015 -0700 > > __bitmap_parselist: fix bug in empty string handling > > bitmap_parselist("", &mask, nmaskbits) will erroneously set bit zero in > the mask. The same bug is visible in cpumask_parselist() since it is > layered on top of the bitmask code, e.g. if you boot with "isolcpus=", > you will actually end up with cpu zero isolated. > > The bug was introduced in commit 4b060420a596 ("bitmap, irq: add > smp_affinity_list interface to /proc/irq") when bitmap_parselist() was > generalized to support userspace as well as kernelspace. > > Fixes: 4b060420a596 ("bitmap, irq: add smp_affinity_list interface to /proc/irq") > Signed-off-by: Chris Metcalf > Cc: Rasmus Villemoes > Signed-off-by: Andrew Morton > Signed-off-by: Linus Torvalds > > diff --git a/lib/bitmap.c b/lib/bitmap.c > index 64c0926..40162f8 100644 > --- a/lib/bitmap.c > +++ b/lib/bitmap.c > @@ -506,12 +506,12 @@ static int __bitmap_parselist(const char *buf, unsigned int buflen, > unsigned a, b; > int c, old_c, totaldigits; > const char __user __force *ubuf = (const char __user __force *)buf; > - int exp_digit, in_range; > + int at_start, in_range; > > totaldigits = c = 0; > bitmap_zero(maskp, nmaskbits); > do { > - exp_digit = 1; > + at_start = 1; > in_range = 0; > a = b = 0; > > @@ -540,11 +540,10 @@ static int __bitmap_parselist(const char *buf, unsigned int buflen, > break; > > if (c == '-') { > - if (exp_digit || in_range) > + if (at_start || in_range) > return -EINVAL; > b = 0; > in_range = 1; > - exp_digit = 1; > continue; > } > > @@ -554,16 +553,18 @@ static int __bitmap_parselist(const char *buf, unsigned int buflen, > b = b * 10 + (c - '0'); > if (!in_range) > a = b; > - exp_digit = 0; > + at_start = 0; > totaldigits++; > } > if (!(a <= b)) > return -EINVAL; > if (b >= nmaskbits) > return -ERANGE; > - while (a <= b) { > - set_bit(a, maskp); > - a++; > + if (!at_start) { > + while (a <= b) { > + set_bit(a, maskp); > + a++; > + } > } > } while (buflen && c == ','); > return 0; > -- 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/