Module Name:    src
Committed By:   rillig
Date:           Fri May  3 15:32:37 UTC 2024

Modified Files:
        src/tests/usr.bin/xlint/lint1: expr_sizeof.c

Log Message:
tests/lint: skip test for sizeof struct on 32-bit platforms

Even though the test only uses fixed-size types, lint's computed size of
the resulting struct differs between i386 (80) and x86_64 (112).  Both
are wrong, probably due to the unrelated struct declaration above, as
already mentioned in the comments.


To generate a diff of this commit:
cvs rdiff -u -r1.16 -r1.17 src/tests/usr.bin/xlint/lint1/expr_sizeof.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tests/usr.bin/xlint/lint1/expr_sizeof.c
diff -u src/tests/usr.bin/xlint/lint1/expr_sizeof.c:1.16 src/tests/usr.bin/xlint/lint1/expr_sizeof.c:1.17
--- src/tests/usr.bin/xlint/lint1/expr_sizeof.c:1.16	Thu May  2 20:03:33 2024
+++ src/tests/usr.bin/xlint/lint1/expr_sizeof.c	Fri May  3 15:32:37 2024
@@ -1,4 +1,4 @@
-/*	$NetBSD: expr_sizeof.c,v 1.16 2024/05/02 20:03:33 rillig Exp $	*/
+/*	$NetBSD: expr_sizeof.c,v 1.17 2024/05/03 15:32:37 rillig Exp $	*/
 # 3 "expr_sizeof.c"
 
 /*
@@ -7,6 +7,8 @@
  */
 
 /* lint1-extra-flags: -X 351 */
+// TODO: Remove the lp64 restriction when sequence_of_structs has been fixed.
+/* lint1-only-if: lp64 */
 
 /*
  * A sizeof expression can either take a type name or an expression.
@@ -222,7 +224,6 @@ sequence_of_structs(void)
 	typedef short unsigned int uint16_t;
 	typedef unsigned int uint32_t;
 	typedef long unsigned int uint64_t;
-	typedef unsigned long size_t;
 
 	union fp_addr {
 		uint64_t fa_64;
@@ -255,10 +256,10 @@ sequence_of_structs(void)
 	};
 
 	/* expect+1: error: negative array dimension (-20) [20] */
-	typedef int o1[-(int)((size_t)(unsigned long)(&(((struct save87 *)0)->s87_dp)))];
+	typedef int o1[-(int)((unsigned long)(&(((struct save87 *)0)->s87_dp)))];
 	// FIXME: must be 28.
 	/* expect+1: error: negative array dimension (-32) [20] */
-	typedef int o2[-(int)((size_t)(unsigned long)(&(((struct save87 *)0)->s87_ac)))];
+	typedef int o2[-(int)((unsigned long)(&(((struct save87 *)0)->s87_ac)))];
 	// FIXME: must be 108.
 	/* expect+1: error: negative array dimension (-112) [20] */
 	typedef int reveal[-(int)sizeof(struct save87)];

Reply via email to