clang-tidy: Enable the bugprone-macro-parentheses check

We globally disabled this, with a justification lumped together with
several checks about braces.  They don't really go together, the others
are essentially a stylistic choice which doesn't match our style.  Omitting
brackets on macro parameters can lead to real and hard to track down bugs
if an expression is ever passed to the macro instead of a plain identifier.

We've only gotten away with the macros which trigger the warning, because
of other conventions its been unlikely to invoke them with anything other
than a simple identifier.  Fix the macros, and enable the warning for the
future.

Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
This commit is contained in:
David Gibson 2024-06-06 20:09:45 +10:00 committed by Stefano Brivio
parent 7094b91d10
commit 0e36fe1a43
4 changed files with 25 additions and 26 deletions

View file

@ -192,7 +192,6 @@ docs: README.md
# - llvmlibc-restrict-system-libc-headers # - llvmlibc-restrict-system-libc-headers
# TODO: this is Linux-only for the moment, nice to fix eventually # TODO: this is Linux-only for the moment, nice to fix eventually
# #
# - bugprone-macro-parentheses
# - google-readability-braces-around-statements # - google-readability-braces-around-statements
# - hicpp-braces-around-statements # - hicpp-braces-around-statements
# - readability-braces-around-statements # - readability-braces-around-statements
@ -269,7 +268,6 @@ clang-tidy: $(SRCS) $(HEADERS)
-clang-analyzer-valist.Uninitialized,\ -clang-analyzer-valist.Uninitialized,\
-cppcoreguidelines-init-variables,\ -cppcoreguidelines-init-variables,\
-bugprone-assignment-in-if-condition,\ -bugprone-assignment-in-if-condition,\
-bugprone-macro-parentheses,\
-google-readability-braces-around-statements,\ -google-readability-braces-around-statements,\
-hicpp-braces-around-statements,\ -hicpp-braces-around-statements,\
-readability-braces-around-statements,\ -readability-braces-around-statements,\

37
tap.c
View file

@ -674,18 +674,18 @@ resume:
continue; continue;
} }
#define L4_MATCH(iph, uh, seq) \ #define L4_MATCH(iph, uh, seq) \
(seq->protocol == iph->protocol && \ ((seq)->protocol == (iph)->protocol && \
seq->source == uh->source && seq->dest == uh->dest && \ (seq)->source == (uh)->source && (seq)->dest == (uh)->dest && \
seq->saddr.s_addr == iph->saddr && seq->daddr.s_addr == iph->daddr) (seq)->saddr.s_addr == (iph)->saddr && (seq)->daddr.s_addr == (iph)->daddr)
#define L4_SET(iph, uh, seq) \ #define L4_SET(iph, uh, seq) \
do { \ do { \
seq->protocol = iph->protocol; \ (seq)->protocol = (iph)->protocol; \
seq->source = uh->source; \ (seq)->source = (uh)->source; \
seq->dest = uh->dest; \ (seq)->dest = (uh)->dest; \
seq->saddr.s_addr = iph->saddr; \ (seq)->saddr.s_addr = (iph)->saddr; \
seq->daddr.s_addr = iph->daddr; \ (seq)->daddr.s_addr = (iph)->daddr; \
} while (0) } while (0)
if (seq && L4_MATCH(iph, uh, seq) && seq->p.count < UIO_MAXIOV) if (seq && L4_MATCH(iph, uh, seq) && seq->p.count < UIO_MAXIOV)
@ -848,18 +848,19 @@ resume:
} }
#define L4_MATCH(ip6h, proto, uh, seq) \ #define L4_MATCH(ip6h, proto, uh, seq) \
(seq->protocol == proto && \ ((seq)->protocol == (proto) && \
seq->source == uh->source && seq->dest == uh->dest && \ (seq)->source == (uh)->source && \
IN6_ARE_ADDR_EQUAL(&seq->saddr, saddr) && \ (seq)->dest == (uh)->dest && \
IN6_ARE_ADDR_EQUAL(&seq->daddr, daddr)) IN6_ARE_ADDR_EQUAL(&(seq)->saddr, saddr) && \
IN6_ARE_ADDR_EQUAL(&(seq)->daddr, daddr))
#define L4_SET(ip6h, proto, uh, seq) \ #define L4_SET(ip6h, proto, uh, seq) \
do { \ do { \
seq->protocol = proto; \ (seq)->protocol = (proto); \
seq->source = uh->source; \ (seq)->source = (uh)->source; \
seq->dest = uh->dest; \ (seq)->dest = (uh)->dest; \
seq->saddr = *saddr; \ (seq)->saddr = *saddr; \
seq->daddr = *daddr; \ (seq)->daddr = *daddr; \
} while (0) } while (0)
if (seq && L4_MATCH(ip6h, proto, uh, seq) && if (seq && L4_MATCH(ip6h, proto, uh, seq) &&

8
tcp.c
View file

@ -326,7 +326,7 @@
#define WINDOW_DEFAULT 14600 /* RFC 6928 */ #define WINDOW_DEFAULT 14600 /* RFC 6928 */
#ifdef HAS_SND_WND #ifdef HAS_SND_WND
# define KERNEL_REPORTS_SND_WND(c) (c->tcp.kernel_snd_wnd) # define KERNEL_REPORTS_SND_WND(c) ((c)->tcp.kernel_snd_wnd)
#else #else
# define KERNEL_REPORTS_SND_WND(c) (0 && (c)) # define KERNEL_REPORTS_SND_WND(c) (0 && (c))
#endif #endif
@ -373,9 +373,9 @@
#define CONN_V4(conn) (!!inany_v4(&(conn)->faddr)) #define CONN_V4(conn) (!!inany_v4(&(conn)->faddr))
#define CONN_V6(conn) (!CONN_V4(conn)) #define CONN_V6(conn) (!CONN_V4(conn))
#define CONN_IS_CLOSING(conn) \ #define CONN_IS_CLOSING(conn) \
((conn->events & ESTABLISHED) && \ (((conn)->events & ESTABLISHED) && \
(conn->events & (SOCK_FIN_RCVD | TAP_FIN_RCVD))) ((conn)->events & (SOCK_FIN_RCVD | TAP_FIN_RCVD)))
#define CONN_HAS(conn, set) ((conn->events & (set)) == (set)) #define CONN_HAS(conn, set) (((conn)->events & (set)) == (set))
static const char *tcp_event_str[] __attribute((__unused__)) = { static const char *tcp_event_str[] __attribute((__unused__)) = {
"SOCK_ACCEPTED", "TAP_SYN_RCVD", "ESTABLISHED", "TAP_SYN_ACK_SENT", "SOCK_ACCEPTED", "TAP_SYN_RCVD", "ESTABLISHED", "TAP_SYN_ACK_SENT",

View file

@ -73,9 +73,9 @@ static int ns_sock_pool6 [TCP_SOCK_POOL_SIZE];
/* Pool of pre-opened pipes */ /* Pool of pre-opened pipes */
static int splice_pipe_pool [TCP_SPLICE_PIPE_POOL_SIZE][2]; static int splice_pipe_pool [TCP_SPLICE_PIPE_POOL_SIZE][2];
#define CONN_V6(x) (x->flags & SPLICE_V6) #define CONN_V6(x) ((x)->flags & SPLICE_V6)
#define CONN_V4(x) (!CONN_V6(x)) #define CONN_V4(x) (!CONN_V6(x))
#define CONN_HAS(conn, set) ((conn->events & (set)) == (set)) #define CONN_HAS(conn, set) (((conn)->events & (set)) == (set))
#define CONN(idx) (&FLOW(idx)->tcp_splice) #define CONN(idx) (&FLOW(idx)->tcp_splice)
/* Display strings for connection events */ /* Display strings for connection events */