Module Name: src Committed By: rillig Date: Fri Jun 24 20:32:12 UTC 2022
Modified Files: src/tests/usr.bin/xlint/lint1: msg_247.c Log Message: tests/lint: demonstrate warning for cast between compatible structs To generate a diff of this commit: cvs rdiff -u -r1.22 -r1.23 src/tests/usr.bin/xlint/lint1/msg_247.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/msg_247.c diff -u src/tests/usr.bin/xlint/lint1/msg_247.c:1.22 src/tests/usr.bin/xlint/lint1/msg_247.c:1.23 --- src/tests/usr.bin/xlint/lint1/msg_247.c:1.22 Fri Jun 24 20:16:21 2022 +++ src/tests/usr.bin/xlint/lint1/msg_247.c Fri Jun 24 20:32:12 2022 @@ -1,4 +1,4 @@ -/* $NetBSD: msg_247.c,v 1.22 2022/06/24 20:16:21 rillig Exp $ */ +/* $NetBSD: msg_247.c,v 1.23 2022/06/24 20:32:12 rillig Exp $ */ # 3 "msg_247.c" // Test for message: pointer cast from '%s' to '%s' may be troublesome [247] @@ -103,7 +103,7 @@ struct counter_impl { void *allocate(void); struct counter * -counter_new(void) +counter_new_typesafe(void) { struct counter_impl *impl = allocate(); impl->public_part.count = 12345; @@ -111,6 +111,16 @@ counter_new(void) return &impl->public_part; } +struct counter * +counter_new_cast(void) +{ + struct counter_impl *impl = allocate(); + impl->public_part.count = 12345; + impl->saved_count = 12346; + /* expect+1: warning: pointer cast from 'pointer to struct counter_impl' to 'pointer to struct counter' may be troublesome [247] */ + return (struct counter *)impl; +} + void counter_increment(struct counter *counter) { @@ -156,7 +166,7 @@ lh_OPENSSL_STRING_new(void) */ return (struct lhash_st_OPENSSL_STRING *)OPENSSL_LH_new(); } -# 160 "msg_247.c" 2 +# 170 "msg_247.c" 2 void sink(const void *); @@ -272,3 +282,26 @@ cast_between_sockaddr_variants(void *ptr return t6; } + + +// From jemalloc. + +typedef struct ctl_node_s { + _Bool named; +} ctl_node_t; + +typedef struct ctl_named_node_s { + ctl_node_t node; + const char *name; +} ctl_named_node_t; + +void * +cast_between_initial_struct(void *ptr) +{ + /* expect+1: warning: pointer cast from 'pointer to struct ctl_named_node_s' to 'pointer to struct ctl_node_s' may be troublesome [247] */ + void *t1 = (ctl_node_t *)(ctl_named_node_t *)ptr; + + void *t2 = (ctl_named_node_t *)(ctl_node_t *)ptr; + + return t2; +}