
10 Feb
2017
10 Feb
'17
1:59 p.m.
From: Sebastien Colleur sebastienx.colleur@intel.com
itest shell command doesn't work correctly in long format when doing comparaison due to wrong mask value calculus that overflow on 32 bits values.
Signed-off-by: Sebastien Colleur sebastienx.colleur@intel.com --- cmd/itest.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/cmd/itest.c b/cmd/itest.c index 60626c7fe9..e1896d9f97 100644 --- a/cmd/itest.c +++ b/cmd/itest.c @@ -80,7 +80,8 @@ static long evalexp(char *s, int w) l = simple_strtoul(s, NULL, 16); }
- return l & ((1UL << (w * 8)) - 1); + /* avoid overflow on mask calculus */ + return (w >= sizeof(long)) ? l : (l & ((1UL << (w * 8)) - 1)); }
static char * evalstr(char *s)
--
2.11.0