From patchwork Thu Aug 24 20:24:14 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mahmoud Matook X-Patchwork-Id: 13364658 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 4777CC3DA6F for ; Thu, 24 Aug 2023 20:26:39 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243426AbjHXU0I (ORCPT ); Thu, 24 Aug 2023 16:26:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42224 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243470AbjHXUZh (ORCPT ); Thu, 24 Aug 2023 16:25:37 -0400 Received: from mail-wr1-x435.google.com (mail-wr1-x435.google.com [IPv6:2a00:1450:4864:20::435]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E471D1FCE; Thu, 24 Aug 2023 13:25:16 -0700 (PDT) Received: by mail-wr1-x435.google.com with SMTP id ffacd0b85a97d-31c6d17aec4so159111f8f.1; Thu, 24 Aug 2023 13:25:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1692908715; x=1693513515; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=CT70rySUmSO2bksh3FYToT/efZgAxO1OuH/DvcX6pRY=; b=WUSRCgZ5zI1H+MXDszraZ+zjwXXxwh0GZZ0r5TZLdWKZY7ihpxk4c2mSlYd7nz35Wc 3AGz3QmxoZVe2FsaqxnFxL6rAy10Yoonxp60VYKhLdOTw62NyFmSg6UODsOMMpP+A4Cm 1v/eK0pHF/UsIuzflUVWa1N8mr/DYTMcAzBFnhRX2Ay2lMgjmdVt1vN2SjInjGz0bhZ0 7wsSD+C0XbMR51TAwDvZcv8EePYLirQhPA2OiRo4wCYE9Jt3F77gRFMlIJMwuu9EKog9 8BDVN+tMlUUcxH0+hML4Q94ul6PvaqRkHW/5RHK1RjsSPlAlsGU5T7IvXO9X9lX9FDeR UJfA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1692908715; x=1693513515; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=CT70rySUmSO2bksh3FYToT/efZgAxO1OuH/DvcX6pRY=; b=mDprYmcQgvTlIBcCYDw+Fmid2w8oRATRWSBxQyWMsXZsXn1Ogk4Q2BkaDD/InCGMzJ 4qDdcqSm3Pjd2FBcTG7iTsJdPMEIP+PNyucFUUxRoobTF4rWZ8QmGrVRENrxA2TW1SbY n1VZA/8Txq652ghAeoyV1DIPqfAT4WsBMNeAAJbCPHXhJAognPnbv7iqozE5yafEYhPM 17Gr4Fjor4j35xrExFN5+zAL2hIbt5XqI5w8JWzTdzhpkVuXKeJI8cLbhWeWWg3F+I78 1vf0qQasWvi9VYYwiVGxG0FCTwbXRbjGvoIKtwKDZ+ycOpTyKuOUwjxu7sA1dDV12ecQ X7zA== X-Gm-Message-State: AOJu0YxxzYwTzzWsYSwa4QPUDcn3aOpCALWLzK2cuYHaVNYBr3CEiFBz gXW80pcTmHQilrwJKN2mhlM= X-Google-Smtp-Source: AGHT+IFVggixjRKv+k1PsUsi/3yPBGxoC4sdW7AW7aYjPdoFyMRrFWA/l3xDWvG7qGe41ZHVQn5tSw== X-Received: by 2002:a5d:630e:0:b0:314:1ca4:dbd9 with SMTP id i14-20020a5d630e000000b003141ca4dbd9mr12062013wru.27.1692908715030; Thu, 24 Aug 2023 13:25:15 -0700 (PDT) Received: from mmaatuq-HP-Laptop-15-dy2xxx.. ([2001:8f8:1163:806e:f960:7197:6afd:b6ed]) by smtp.gmail.com with ESMTPSA id g5-20020a5d5405000000b0031435731dfasm150416wrv.35.2023.08.24.13.25.10 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 24 Aug 2023 13:25:14 -0700 (PDT) From: Mahmoud Maatuq To: keescook@chromium.org, edumazet@google.com, willemdebruijn.kernel@gmail.com, wad@chromium.org, luto@amacapital.net, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, kuba@kernel.org, shuah@kernel.org, pabeni@redhat.com, linux-kselftest@vger.kernel.org, davem@davemloft.net Cc: linux-kernel-mentees@lists.linuxfoundation.org, Mahmoud Maatuq , David Laight Subject: [PATCH v2 1/2] selftests: Provide local define of min() and max() Date: Fri, 25 Aug 2023 00:24:14 +0400 Message-Id: <20230824202415.131824-1-mahmoudmatook.mm@gmail.com> X-Mailer: git-send-email 2.34.1 MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-kselftest@vger.kernel.org to avoid manual calculation of min and max values and fix coccinelle warnings such WARNING opportunity for min()/max() adding one common definition that could be used in multiple files under selftests. there are also some defines for min/max scattered locally inside sources under selftests. this also prepares for cleaning up those redundant defines and include kselftest.h instead. Signed-off-by: Mahmoud Maatuq Suggested-by: David Laight --- changes in v2: redefine min/max in a more strict way to avoid signedness mismatch and multiple evaluation. is_signed_type() moved from selftests/kselftest_harness.h to selftests/kselftest.h. --- tools/testing/selftests/kselftest.h | 24 +++++++++++++++++++++ tools/testing/selftests/kselftest_harness.h | 2 -- 2 files changed, 24 insertions(+), 2 deletions(-) diff --git a/tools/testing/selftests/kselftest.h b/tools/testing/selftests/kselftest.h index 829be379545a..93d029471cc9 100644 --- a/tools/testing/selftests/kselftest.h +++ b/tools/testing/selftests/kselftest.h @@ -55,6 +55,30 @@ #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0])) #endif +#ifndef is_signed_type +#define is_signed_type(var) (!!(((__typeof__(var))(-1)) < (__typeof__(var))1)) +#endif + +#ifndef min +#define min(x, y) ({ \ + _Static_assert(is_signed_type(typeof(x)) == is_signed_type(typeof(y)), \ + "min: signedness mismatch"); \ + typeof(x) _x = (x); \ + typeof(y) _y = (y); \ + _x < _y ? _x : _y; \ +}) +#endif + +#ifndef max +#define max(x, y) ({ \ + _Static_assert(is_signed_type(typeof(x)) == is_signed_type(typeof(y)), \ + "max: signedness mismatch"); \ + typeof(x) _x = (x); \ + typeof(y) _y = (y); \ + _x > _y ? _x : _y; \ +}) +#endif + /* * gcc cpuid.h provides __cpuid_count() since v4.4. * Clang/LLVM cpuid.h provides __cpuid_count() since v3.4.0. diff --git a/tools/testing/selftests/kselftest_harness.h b/tools/testing/selftests/kselftest_harness.h index 5fd49ad0c696..e4e310815226 100644 --- a/tools/testing/selftests/kselftest_harness.h +++ b/tools/testing/selftests/kselftest_harness.h @@ -699,8 +699,6 @@ if (_metadata->passed && _metadata->step < 253) \ _metadata->step++; -#define is_signed_type(var) (!!(((__typeof__(var))(-1)) < (__typeof__(var))1)) - #define __EXPECT(_expected, _expected_str, _seen, _seen_str, _t, _assert) do { \ /* Avoid multiple evaluation of the cases */ \ __typeof__(_expected) __exp = (_expected); \ From patchwork Thu Aug 24 20:24:15 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Mahmoud Matook X-Patchwork-Id: 13364665 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 99E3FC7EE43 for ; Thu, 24 Aug 2023 20:27:11 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234271AbjHXU0k (ORCPT ); Thu, 24 Aug 2023 16:26:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56012 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243518AbjHXU0M (ORCPT ); Thu, 24 Aug 2023 16:26:12 -0400 Received: from mail-wr1-x42c.google.com (mail-wr1-x42c.google.com [IPv6:2a00:1450:4864:20::42c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 36ACF1BF0; Thu, 24 Aug 2023 13:25:55 -0700 (PDT) Received: by mail-wr1-x42c.google.com with SMTP id ffacd0b85a97d-307d20548adso156939f8f.0; Thu, 24 Aug 2023 13:25:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1692908753; x=1693513553; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=BSwlyHxagWvlq7wv+/QmpMx6Hn8ySgsLpysR6zi7jgU=; b=p9ESrZp7gQV0drD3U0uv6540fluT+uTtEKOLuzZW37x+BJli6WA43KW9KzIwZTUNbp TGlr+FWzSUhr7C3YWxo5HV2HuTopulboabEfjqXBJW1ZsjSb1xWPffdhh9KFT7HiI/9E ACTRhKnlCflwhb+fsKXE39pkUT/UOR6AvNhVfV4pVc5a5LCa/mgquazXvIBFu91yQXlc +pBs/El/RnNjFb5+rIvFIdgcLjRj6p4iKxaHmTOk/WOwzMuyATNqkF9vxDO0JOuN8Xsu CdSPSt0YA9W1Pcqwpuf9SZxKgd8CZPJ3CGJiCUmVEWvqoNj4mHp0CjzWhJ/5IoC2Ehdg D/yA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1692908753; x=1693513553; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=BSwlyHxagWvlq7wv+/QmpMx6Hn8ySgsLpysR6zi7jgU=; b=cdve7f0uB5c+1GhvjtNjoHbQdFbL3t89IyPkmWSzqKDvwR2PKHHn1aNiN2QRnq/cxZ 1uROJYH+3vLg9KpuCXY8MmQhpBMG0jYS+obAllUEHBBc/ZRyq9m8RKePr1n6ZPRXFeKS 58s3wSWbH8x8pVazBOmpsOxACH76Tx2YvAEtGa9inTlAW/3qPg5un/wAgS1qS+S45lov j+27i2YkNW4SMSS5qjbDgLPrOpYztgedHgZv9mcZSqxNjNcxIbgYOPLPpVOHn5MJL2v5 KaOUghmX3306AfXPoTabbvu5aKlx07Zb/hBFOhF4UHgDxo+ayCNVqhMQF1t2J9WwaBJx utLQ== X-Gm-Message-State: AOJu0YzzRnnyKng31CdzVQQwTkGkZlIlMb8aFmYtIDrxjStJQ+vdteA2 zAsjBnrfvrDW8BMyAQB5f90= X-Google-Smtp-Source: AGHT+IGkwDoDovxr7bTL5Guk5NyoCW+s1SVG8bTybEhihMR7S1bmwaDgeg3Kd3ld0agb8d6I40PJfQ== X-Received: by 2002:adf:dcce:0:b0:317:5b76:826 with SMTP id x14-20020adfdcce000000b003175b760826mr12597431wrm.0.1692908753624; Thu, 24 Aug 2023 13:25:53 -0700 (PDT) Received: from mmaatuq-HP-Laptop-15-dy2xxx.. ([2001:8f8:1163:806e:f960:7197:6afd:b6ed]) by smtp.gmail.com with ESMTPSA id g5-20020a5d5405000000b0031435731dfasm150416wrv.35.2023.08.24.13.25.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 24 Aug 2023 13:25:53 -0700 (PDT) From: Mahmoud Maatuq To: keescook@chromium.org, edumazet@google.com, willemdebruijn.kernel@gmail.com, wad@chromium.org, luto@amacapital.net, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, kuba@kernel.org, shuah@kernel.org, pabeni@redhat.com, linux-kselftest@vger.kernel.org, davem@davemloft.net Cc: linux-kernel-mentees@lists.linuxfoundation.org, Mahmoud Maatuq Subject: [PATCH v2 2/2] selftests/net: replace ternary operator with min()/max() Date: Fri, 25 Aug 2023 00:24:15 +0400 Message-Id: <20230824202415.131824-2-mahmoudmatook.mm@gmail.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230824202415.131824-1-mahmoudmatook.mm@gmail.com> References: <20230824202415.131824-1-mahmoudmatook.mm@gmail.com> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-kselftest@vger.kernel.org Fix the following coccicheck warning: tools/testing/selftests/net/udpgso_bench_tx.c:297:18-19: WARNING opportunity for min() tools/testing/selftests/net/udpgso_bench_tx.c:354:27-28: WARNING opportunity for min() tools/testing/selftests/net/so_txtime.c:129:24-26: WARNING opportunity for max() tools/testing/selftests/net/so_txtime.c:96:30-31: WARNING opportunity for max() Signed-off-by: Mahmoud Maatuq Suggested-by: Willem de Bruijn --- changes in v2: cast var cfg_mss to int to avoid static assertion after providing a stricter version of min() that does signedness checking. --- tools/testing/selftests/net/Makefile | 2 ++ tools/testing/selftests/net/so_txtime.c | 7 ++++--- tools/testing/selftests/net/udpgso_bench_tx.c | 6 +++--- 3 files changed, 9 insertions(+), 6 deletions(-) diff --git a/tools/testing/selftests/net/Makefile b/tools/testing/selftests/net/Makefile index 7f3ab2a93ed6..a06cc25489f9 100644 --- a/tools/testing/selftests/net/Makefile +++ b/tools/testing/selftests/net/Makefile @@ -3,6 +3,8 @@ CFLAGS = -Wall -Wl,--no-as-needed -O2 -g CFLAGS += -I../../../../usr/include/ $(KHDR_INCLUDES) +# Additional include paths needed by kselftest.h +CFLAGS += -I../ TEST_PROGS := run_netsocktests run_afpackettests test_bpf.sh netdevice.sh \ rtnetlink.sh xfrm_policy.sh test_blackhole_dev.sh diff --git a/tools/testing/selftests/net/so_txtime.c b/tools/testing/selftests/net/so_txtime.c index 2672ac0b6d1f..2936174e7de4 100644 --- a/tools/testing/selftests/net/so_txtime.c +++ b/tools/testing/selftests/net/so_txtime.c @@ -33,6 +33,8 @@ #include #include +#include "kselftest.h" + static int cfg_clockid = CLOCK_TAI; static uint16_t cfg_port = 8000; static int cfg_variance_us = 4000; @@ -93,8 +95,7 @@ static void do_send_one(int fdt, struct timed_send *ts) msg.msg_controllen = sizeof(control); tdeliver = glob_tstart + ts->delay_us * 1000; - tdeliver_max = tdeliver_max > tdeliver ? - tdeliver_max : tdeliver; + tdeliver_max = max(tdeliver_max, tdeliver); cm = CMSG_FIRSTHDR(&msg); cm->cmsg_level = SOL_SOCKET; @@ -126,7 +127,7 @@ static void do_recv_one(int fdr, struct timed_send *ts) error(1, 0, "read: %dB", ret); tstop = (gettime_ns(cfg_clockid) - glob_tstart) / 1000; - texpect = ts->delay_us >= 0 ? ts->delay_us : 0; + texpect = max(ts->delay_us, 0); fprintf(stderr, "payload:%c delay:%lld expected:%lld (us)\n", rbuf[0], (long long)tstop, (long long)texpect); diff --git a/tools/testing/selftests/net/udpgso_bench_tx.c b/tools/testing/selftests/net/udpgso_bench_tx.c index 477392715a9a..6bd32a312901 100644 --- a/tools/testing/selftests/net/udpgso_bench_tx.c +++ b/tools/testing/selftests/net/udpgso_bench_tx.c @@ -25,7 +25,7 @@ #include #include -#include "../kselftest.h" +#include "kselftest.h" #ifndef ETH_MAX_MTU #define ETH_MAX_MTU 0xFFFFU @@ -294,7 +294,7 @@ static int send_udp(int fd, char *data) total_len = cfg_payload_len; while (total_len) { - len = total_len < cfg_mss ? total_len : cfg_mss; + len = min(total_len, (int)cfg_mss); ret = sendto(fd, data, len, cfg_zerocopy ? MSG_ZEROCOPY : 0, cfg_connected ? NULL : (void *)&cfg_dst_addr, @@ -351,7 +351,7 @@ static int send_udp_sendmmsg(int fd, char *data) error(1, 0, "sendmmsg: exceeds max_nr_msg"); iov[i].iov_base = data + off; - iov[i].iov_len = cfg_mss < left ? cfg_mss : left; + iov[i].iov_len = min(cfg_mss, left); mmsgs[i].msg_hdr.msg_iov = iov + i; mmsgs[i].msg_hdr.msg_iovlen = 1;