Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/xlint/lint1 lint: don't warn about cast between poin...



details:   https://anonhg.NetBSD.org/src/rev/29264918a355
branches:  trunk
changeset: 1020336:29264918a355
user:      rillig <rillig%NetBSD.org@localhost>
date:      Thu Apr 08 19:20:54 2021 +0000

description:
lint: don't warn about cast between pointers to compatible structs

diffstat:

 tests/usr.bin/xlint/lint1/msg_247.c   |   7 +++++--
 tests/usr.bin/xlint/lint1/msg_247.exp |   1 -
 usr.bin/xlint/lint1/tree.c            |  21 ++++++++++++++++-----
 3 files changed, 21 insertions(+), 8 deletions(-)

diffs (72 lines):

diff -r 5aee03452cd3 -r 29264918a355 tests/usr.bin/xlint/lint1/msg_247.c
--- a/tests/usr.bin/xlint/lint1/msg_247.c       Thu Apr 08 19:08:17 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_247.c       Thu Apr 08 19:20:54 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: msg_247.c,v 1.9 2021/04/08 19:08:17 rillig Exp $       */
+/*     $NetBSD: msg_247.c,v 1.10 2021/04/08 19:20:54 rillig Exp $      */
 # 3 "msg_247.c"
 
 // Test for message: pointer cast from '%s' to '%s' may be troublesome [247]
@@ -112,7 +112,10 @@
 void
 counter_increment(struct counter *counter)
 {
-       /* expect+1: 247 */
+       /*
+        * Before tree.c 1.272 from 2021-04-08, lint warned about the cast
+        * from 'struct counter' to 'struct counter_impl'.
+        */
        struct counter_impl *impl = (struct counter_impl *)counter;
        impl->saved_count = impl->public_part.count;
        impl->public_part.count++;
diff -r 5aee03452cd3 -r 29264918a355 tests/usr.bin/xlint/lint1/msg_247.exp
--- a/tests/usr.bin/xlint/lint1/msg_247.exp     Thu Apr 08 19:08:17 2021 +0000
+++ b/tests/usr.bin/xlint/lint1/msg_247.exp     Thu Apr 08 19:20:54 2021 +0000
@@ -1,3 +1,2 @@
 msg_247.c(31): warning: pointer cast from 'pointer to struct Other' to 'pointer to struct <unnamed>' may be troublesome [247]
 msg_247.c(70): warning: pointer cast from 'pointer to struct Other' to 'pointer to signed char' may be troublesome [247]
-msg_247.c(116): warning: pointer cast from 'pointer to struct counter' to 'pointer to struct counter_impl' may be troublesome [247]
diff -r 5aee03452cd3 -r 29264918a355 usr.bin/xlint/lint1/tree.c
--- a/usr.bin/xlint/lint1/tree.c        Thu Apr 08 19:08:17 2021 +0000
+++ b/usr.bin/xlint/lint1/tree.c        Thu Apr 08 19:20:54 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: tree.c,v 1.271 2021/04/06 21:59:58 rillig Exp $        */
+/*     $NetBSD: tree.c,v 1.272 2021/04/08 19:20:54 rillig Exp $        */
 
 /*
  * Copyright (c) 1994, 1995 Jochen Pohl
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: tree.c,v 1.271 2021/04/06 21:59:58 rillig Exp $");
+__RCSID("$NetBSD: tree.c,v 1.272 2021/04/08 19:20:54 rillig Exp $");
 #endif
 
 #include <float.h>
@@ -2023,11 +2023,22 @@
 }
 
 static bool
-should_warn_about_pointer_cast(const type_t *tp, tspec_t nst,
-                              const tnode_t *tn, tspec_t ost)
+should_warn_about_pointer_cast(const type_t *ntp, tspec_t nst,
+                              const tnode_t *otn, tspec_t ost)
 {
+       /*
+        * Casting a pointer to 'struct S' to a pointer to another struct that
+        * has 'struct S' as its first member is ok, see msg_247.c, 'struct
+        * counter'.
+        */
+       if (nst == STRUCT && ost == STRUCT &&
+           ntp->t_subt->t_str->sou_first_member != NULL &&
+           ntp->t_subt->t_str->sou_first_member->s_type ==
+           otn->tn_type->t_subt)
+               return false;
+
        if (nst == STRUCT || nst == UNION)
-               if (tp->t_subt->t_str != tn->tn_type->t_subt->t_str)
+               if (ntp->t_subt->t_str != otn->tn_type->t_subt->t_str)
                        return true;
 
        if (nst == CHAR || nst == UCHAR)



Home | Main Index | Thread Index | Old Index