Like GCC, we don't want to touch shifts with a negative count. Add testcases covering this at expansion and simplification time. Signed-off-by: Luc Van Oostenryck <luc.vanoostenryck@xxxxxxxxx> --- validation/shift-negative.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) create mode 100644 validation/shift-negative.c diff --git a/validation/shift-negative.c b/validation/shift-negative.c new file mode 100644 index 000000000..533fc68a4 --- /dev/null +++ b/validation/shift-negative.c @@ -0,0 +1,18 @@ +unsigned int fn1(unsigned int a) { return a >> -1; } +unsigned int fn2(unsigned int a) { return a >> ~0; } + +unsigned int fo1(unsigned int a) { return a >> ((a & 0) | -1); } +unsigned int fo2(unsigned int a) { return a >> ((a & 0) ^ ~0); } + +/* + * check-name: shift-negative + * check-command: sparse -Wno-decl $file + * check-known-to-fail + * + * check-error-start +shift-negative.c:1:45: warning: shift count is negative (-1) +shift-negative.c:2:45: warning: shift count is negative (-1) +shift-negative.c:4:59: warning: shift count is negative (-1) +shift-negative.c:5:59: warning: shift count is negative (-1) + * check-error-end + */ -- 2.18.0 -- To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html