The problem is that strnlen() here may return invalid value with 32bit icc.
(actually it returns it’s second parameter,e.g: sysconf(_SC_ARG_MAX)).
It starts to manifest hwen max_len parameter is > 2M and using icc –m32 –O2 (or above).
Suggested-by: Konstantin Ananyev <konstantin.ananyev@intel.com>
Signed-off-by: Cunming Liang <cunming.liang@intel.com>
Acked-by: Olivier Matz <olivier.matz@6wind.com>
Acked-by: Konstantin Ananyev <konstantin.ananyev@intel.com>
if (coremask[0] == '0' && ((coremask[1] == 'x')
|| (coremask[1] == 'X')))
coremask += 2;
- i = strnlen(coremask, PATH_MAX);
+ i = strlen(coremask);
while ((i > 0) && isblank(coremask[i - 1]))
i--;
if (i == 0)
/* Remove all blank characters ahead and after */
while (isblank(*corelist))
corelist++;
- i = strnlen(corelist, sysconf(_SC_ARG_MAX));
+ i = strlen(corelist);
while ((i > 0) && isblank(corelist[i - 1]))
i--;
/* Remove all blank characters ahead and after */
while (isblank(*lcores))
lcores++;
- i = strnlen(lcores, sysconf(_SC_ARG_MAX));
+ i = strlen(lcores);
while ((i > 0) && isblank(lcores[i - 1]))
i--;