Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/tests/usr.bin/xlint/lint1 tests/lint: add test for warning a...
details: https://anonhg.NetBSD.org/src/rev/a25b199c7dc9
branches: trunk
changeset: 983322:a25b199c7dc9
user: rillig <rillig%NetBSD.org@localhost>
date: Sun May 16 10:08:01 2021 +0000
description:
tests/lint: add test for warning about zero-bits in '&'
diffstat:
tests/usr.bin/xlint/lint1/msg_309.c | 38 ++++++++++++++++++++++++++++++++--
tests/usr.bin/xlint/lint1/msg_309.exp | 2 +-
2 files changed, 36 insertions(+), 4 deletions(-)
diffs (52 lines):
diff -r 3807e158f3e5 -r a25b199c7dc9 tests/usr.bin/xlint/lint1/msg_309.c
--- a/tests/usr.bin/xlint/lint1/msg_309.c Sun May 16 09:43:39 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_309.c Sun May 16 10:08:01 2021 +0000
@@ -1,7 +1,39 @@
-/* $NetBSD: msg_309.c,v 1.2 2021/02/21 09:07:58 rillig Exp $ */
+/* $NetBSD: msg_309.c,v 1.3 2021/05/16 10:08:01 rillig Exp $ */
# 3 "msg_309.c"
// Test for message: extra bits set to 0 in conversion of '%s' to '%s', op %s [309]
-TODO: "Add example code that triggers the above message." /* expect: 249 */
-TODO: "Add example code that almost triggers the above message."
+int
+scale(unsigned long long x) {
+
+ /*
+ * Both operands of '&' have the same type, therefore no conversion
+ * is necessary and no bits can get lost.
+ */
+ if ((x & 0xffffffff00000000ULL) != 0)
+ return 32;
+
+ /*
+ * The constant has type 'unsigned 32-bit'. The usual arithmetic
+ * conversions of '&' convert this constant to unsigned 64-bit.
+ * The programmer may or may not have intended to sign-extend the
+ * bit mask here. This situation may occur during migration from a
+ * 32-bit to a 64-bit platform.
+ */
+ if ((x & 0xffff0000) != 0) /* expect: 309 */
+ return 16;
+
+ /*
+ * In the remaining cases, the constant does not have its most
+ * significant bit set, therefore there is no ambiguity.
+ */
+ if ((x & 0xff00) != 0)
+ return 8;
+ if ((x & 0xf0) != 0)
+ return 4;
+ if ((x & 0xc) != 0)
+ return 2;
+ if ((x & 0x2) != 0)
+ return 1;
+ return (int)(x & 0x1);
+}
diff -r 3807e158f3e5 -r a25b199c7dc9 tests/usr.bin/xlint/lint1/msg_309.exp
--- a/tests/usr.bin/xlint/lint1/msg_309.exp Sun May 16 09:43:39 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_309.exp Sun May 16 10:08:01 2021 +0000
@@ -1,1 +1,1 @@
-msg_309.c(6): error: syntax error ':' [249]
+msg_309.c(23): warning: extra bits set to 0 in conversion of 'unsigned int' to 'unsigned long long', op & [309]
Home |
Main Index |
Thread Index |
Old Index