X-Git-Url: https://git.karo-electronics.de/?a=blobdiff_plain;f=lib%2Fcmdline.c;h=4c0888c4a68d9621717f9012d3ca4cc0b72df20b;hb=096bf6b7f4fcc2fe486f61526b888034a7059342;hp=3c6432df7e63466a24d41dead807c7ef14c0ab86;hpb=b5a53b61a2890ec08f404f524c1c42aa86f09be4;p=karo-tx-linux.git diff --git a/lib/cmdline.c b/lib/cmdline.c index 3c6432df7e63..4c0888c4a68d 100644 --- a/lib/cmdline.c +++ b/lib/cmdline.c @@ -23,14 +23,14 @@ * the values[M, M+1, ..., N] into the ints array in get_options. */ -static int get_range(char **str, int *pint) +static int get_range(char **str, int *pint, int n) { int x, inc_counter, upper_range; (*str)++; upper_range = simple_strtol((*str), NULL, 0); inc_counter = upper_range - *pint; - for (x = *pint; x < upper_range; x++) + for (x = *pint; n && x < upper_range; x++, n--) *pint++ = x; return inc_counter; } @@ -97,7 +97,7 @@ char *get_options(const char *str, int nints, int *ints) break; if (res == 3) { int range_nums; - range_nums = get_range((char **)&str, ints + i); + range_nums = get_range((char **)&str, ints + i, nints - i); if (range_nums < 0) break; /*