From patchwork Sun Mar 21 13:43:56 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Menglong Dong X-Patchwork-Id: 406574 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-15.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 60FE9C433E1 for ; Sun, 21 Mar 2021 13:49:57 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 3393261947 for ; Sun, 21 Mar 2021 13:49:57 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229941AbhCUNpE (ORCPT ); Sun, 21 Mar 2021 09:45:04 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39572 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229784AbhCUNob (ORCPT ); Sun, 21 Mar 2021 09:44:31 -0400 Received: from mail-pj1-x1044.google.com (mail-pj1-x1044.google.com [IPv6:2607:f8b0:4864:20::1044]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A906AC061574; Sun, 21 Mar 2021 06:44:30 -0700 (PDT) Received: by mail-pj1-x1044.google.com with SMTP id ot17-20020a17090b3b51b0290109c9ac3c34so6769115pjb.4; Sun, 21 Mar 2021 06:44:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=g+tW1sbTAqpwuW52zUYbzaaee2q2ruShFJBcwucBx5E=; b=jKjONsL9CzBYsFkD7TUUdFD/PHDEngI8wNvENRUG2xaBZbAo+5cfB19g7vCvOJcmnq C6c7qQxJ+rUXwa4bQMmd2k+g4YglAeN2ENKj57mX0btpThCK/q12mu0kucwY5J7aTngd AAiOslv5BmAXDZD8wjXZSSRGQxuWR8qA3rDkG1PACe+pOSXEstIZYIS4HcZue6mgPOGI ObksWofQnn54FmPxNrC13tSm8FVH6q4U3wz55B5vAb60Vu+hB5029ePvHYEKop6EPqHO RD71DPeSm404temG5u0nZqins+OcnksiI4+XzqsbU9Y6G5bciH0AM0t87TEMBMXQg4GJ SsEQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=g+tW1sbTAqpwuW52zUYbzaaee2q2ruShFJBcwucBx5E=; b=WQabYBTIGZoBeYrw4pKNaUyKtHaFPwgzuzNZ5dS/phxvPj/B/DMvv1VPtw8la4qsn1 7vDTsnlRcBJNcvBCzA4QcAlHD/7VU8Aug5ss+/qNVdqdjAsuvapcNdxH7YbvkCIqArYh f+KQgH4GZzwMVB1AIY8gMhRelKLW1UGNlZObGVc9J0ozIowi2fd2WV+4eHUmRwPDpVzm WZ+EHYSsGuJiGzfHVToN5W3/yIelYu2lrPTnH0a57Ck+Y/Gj/KWPWyR/k3PlQ/LFsK4w T7shg/JVBzubNvxxG4uRHOoFHyOtcr0q3Cj23sHpoIpdq/KFZh1u67BnkaNjWRiAetfz MyrA== X-Gm-Message-State: AOAM5316X0V/Vlxc0NMLSCPb1Ywpg3GSPa7NZvPOrGafb4bPkZ5Z05DF GfnUZMN38Yz4L0Z3UQVJheM= X-Google-Smtp-Source: ABdhPJy3asG16JABejQfwIMMYL444isnq7G3FcVHdYqZQeAHAHAwGorDzmfzNJJH5aHq39JH419m/A== X-Received: by 2002:a17:902:dac2:b029:e6:30a6:4c06 with SMTP id q2-20020a170902dac2b02900e630a64c06mr23161529plx.65.1616334270262; Sun, 21 Mar 2021 06:44:30 -0700 (PDT) Received: from localhost ([178.236.46.205]) by smtp.gmail.com with ESMTPSA id d22sm10759477pjx.24.2021.03.21.06.44.29 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 21 Mar 2021 06:44:29 -0700 (PDT) From: menglong8.dong@gmail.com X-Google-Original-From: dong.menglong@zte.com.cn To: herbert@gondor.apana.org.au, andy.shevchenko@gmail.com, kuba@kernel.org, linux@roeck-us.net, David.Laight@aculab.com Cc: davem@davemloft.net, dong.menglong@zte.com.cn, viro@zeniv.linux.org.uk, axboe@kernel.dk, linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: [PATCH v2 net-next 1/2] net: socket: use BIT() for MSG_* Date: Sun, 21 Mar 2021 21:43:56 +0800 Message-Id: <20210321134357.148323-2-dong.menglong@zte.com.cn> X-Mailer: git-send-email 2.31.0 In-Reply-To: <20210321134357.148323-1-dong.menglong@zte.com.cn> References: <20210321134357.148323-1-dong.menglong@zte.com.cn> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org From: Menglong Dong The bit mask for MSG_* seems a little confused here. Replace it with BIT() to make it clear to understand. Signed-off-by: Menglong Dong --- include/linux/socket.h | 71 ++++++++++++++++++++++-------------------- 1 file changed, 37 insertions(+), 34 deletions(-) diff --git a/include/linux/socket.h b/include/linux/socket.h index 385894b4a8bb..d5ebfe30d96b 100644 --- a/include/linux/socket.h +++ b/include/linux/socket.h @@ -283,42 +283,45 @@ struct ucred { Added those for 1003.1g not all are supported yet */ -#define MSG_OOB 1 -#define MSG_PEEK 2 -#define MSG_DONTROUTE 4 -#define MSG_TRYHARD 4 /* Synonym for MSG_DONTROUTE for DECnet */ -#define MSG_CTRUNC 8 -#define MSG_PROBE 0x10 /* Do not send. Only probe path f.e. for MTU */ -#define MSG_TRUNC 0x20 -#define MSG_DONTWAIT 0x40 /* Nonblocking io */ -#define MSG_EOR 0x80 /* End of record */ -#define MSG_WAITALL 0x100 /* Wait for a full request */ -#define MSG_FIN 0x200 -#define MSG_SYN 0x400 -#define MSG_CONFIRM 0x800 /* Confirm path validity */ -#define MSG_RST 0x1000 -#define MSG_ERRQUEUE 0x2000 /* Fetch message from error queue */ -#define MSG_NOSIGNAL 0x4000 /* Do not generate SIGPIPE */ -#define MSG_MORE 0x8000 /* Sender will send more */ -#define MSG_WAITFORONE 0x10000 /* recvmmsg(): block until 1+ packets avail */ -#define MSG_SENDPAGE_NOPOLICY 0x10000 /* sendpage() internal : do no apply policy */ -#define MSG_SENDPAGE_NOTLAST 0x20000 /* sendpage() internal : not the last page */ -#define MSG_BATCH 0x40000 /* sendmmsg(): more messages coming */ -#define MSG_EOF MSG_FIN -#define MSG_NO_SHARED_FRAGS 0x80000 /* sendpage() internal : page frags are not shared */ -#define MSG_SENDPAGE_DECRYPTED 0x100000 /* sendpage() internal : page may carry - * plain text and require encryption - */ - -#define MSG_ZEROCOPY 0x4000000 /* Use user data in kernel path */ -#define MSG_FASTOPEN 0x20000000 /* Send data in TCP SYN */ -#define MSG_CMSG_CLOEXEC 0x40000000 /* Set close_on_exec for file - descriptor received through - SCM_RIGHTS */ +#define MSG_OOB BIT(0) +#define MSG_PEEK BIT(1) +#define MSG_DONTROUTE BIT(2) +#define MSG_TRYHARD BIT(2) /* Synonym for MSG_DONTROUTE for DECnet */ +#define MSG_CTRUNC BIT(3) +#define MSG_PROBE BIT(4) /* Do not send. Only probe path f.e. for MTU */ +#define MSG_TRUNC BIT(5) +#define MSG_DONTWAIT BIT(6) /* Nonblocking io */ +#define MSG_EOR BIT(7) /* End of record */ +#define MSG_WAITALL BIT(8) /* Wait for a full request */ +#define MSG_FIN BIT(9) +#define MSG_SYN BIT(10) +#define MSG_CONFIRM BIT(11) /* Confirm path validity */ +#define MSG_RST BIT(12) +#define MSG_ERRQUEUE BIT(13) /* Fetch message from error queue */ +#define MSG_NOSIGNAL BIT(14) /* Do not generate SIGPIPE */ +#define MSG_MORE BIT(15) /* Sender will send more */ +#define MSG_WAITFORONE BIT(16) /* recvmmsg(): block until 1+ packets avail */ +#define MSG_SENDPAGE_NOPOLICY BIT(16) /* sendpage() internal : do no apply policy */ +#define MSG_SENDPAGE_NOTLAST BIT(17) /* sendpage() internal : not the last page */ +#define MSG_BATCH BIT(18) /* sendmmsg(): more messages coming */ +#define MSG_EOF MSG_FIN +#define MSG_NO_SHARED_FRAGS BIT(19) /* sendpage() internal : page frags + * are not shared + */ +#define MSG_SENDPAGE_DECRYPTED BIT(20) /* sendpage() internal : page may carry + * plain text and require encryption + */ + +#define MSG_ZEROCOPY BIT(26) /* Use user data in kernel path */ +#define MSG_FASTOPEN BIT(29) /* Send data in TCP SYN */ +#define MSG_CMSG_CLOEXEC BIT(30) /* Set close_on_exec for file + * descriptor received through + * SCM_RIGHTS + */ #if defined(CONFIG_COMPAT) -#define MSG_CMSG_COMPAT 0x80000000 /* This message needs 32 bit fixups */ +#define MSG_CMSG_COMPAT BIT(31) /* This message needs 32 bit fixups */ #else -#define MSG_CMSG_COMPAT 0 /* We never have 32 bit fixups */ +#define MSG_CMSG_COMPAT 0 /* We never have 32 bit fixups */ #endif From patchwork Sun Mar 21 13:43:57 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Menglong Dong X-Patchwork-Id: 406035 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-15.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI, SPF_HELO_NONE, SPF_PASS, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 771EFC433E3 for ; Sun, 21 Mar 2021 13:49:57 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 48EDF61943 for ; Sun, 21 Mar 2021 13:49:57 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229972AbhCUNpG (ORCPT ); Sun, 21 Mar 2021 09:45:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39600 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229901AbhCUNoi (ORCPT ); Sun, 21 Mar 2021 09:44:38 -0400 Received: from mail-pj1-x1042.google.com (mail-pj1-x1042.google.com [IPv6:2607:f8b0:4864:20::1042]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EBC07C061574; Sun, 21 Mar 2021 06:44:37 -0700 (PDT) Received: by mail-pj1-x1042.google.com with SMTP id nh23-20020a17090b3657b02900c0d5e235a8so7185166pjb.0; Sun, 21 Mar 2021 06:44:37 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Ipls7LAfXxAOeZq1Ni1c39go/J4X9iGxp02joKQsB6o=; b=Ah2UkPHCJRXJYXlogGVbdx9FvFYPUKx3aFyY8G/23fMxNeYaTqfAfk00y69yfEGu2p WRdSsG7VQQyxTMk3jKTlY4e+xAtTNJStjcrY6JL5UKZ4SnZf2XGGyTGx5uzIn+wLRSv9 E8IgVT9/UpIp6kHMyeoTgHz8NRydffqllgLCR541ZjOrg9zkGq4fL7K1J6t+75qLhp5R vTNLtrAWtanm3EpB7U8OUqzAybM3aOnTbsayWWgWQoQ8AlfYvp9ONkp1MNjrwsF7ClUO BcTCFJoqJCV4Mt0Dfabyswd5Iu9jOcZL2po4WUlxzsMyGMoKFsVNO5MlNDntVgNvxr9A 1KSQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Ipls7LAfXxAOeZq1Ni1c39go/J4X9iGxp02joKQsB6o=; b=o/gP5u28CB43lYBWsIP0Uxy+g0R5QkXRfVbb1KPTwX4LFKtyzenr6BxaHWEJ7k1lzX 3JmpXABvWaAbo7BN26mr5L2eKC7dmq3P/LMPs+yYwkMKQQnYBAmiBFLBsTTeFgjjY6c1 1i3GvNhUVwYrqPXB1IwkTSL0sOPdn6TypphO3VPEUQTs/y3qRUp1to2YzBaB/HKjQR1O kYfxlU6qiirqbw+IoR+NGi3/nfuMd/mIaZ1MI8QiLQT1Z4ssz0rB9A7L4wCVm2y9b7Lv PWZ+KCQjiImxjv7lIjlfvI5JC80hW8BN/Gsko4GG341ZtglqldsX1oMwA4L/WeAFlu8F Bxrw== X-Gm-Message-State: AOAM532ISRk6Q7dvBzBimILhLzSbHaygJMRyycZ0IbX6PvVNZDyA7Bhy 4N7XAYb8wwWC+cOjF8o2sgM= X-Google-Smtp-Source: ABdhPJzXXo9pH6ZezmUiqw94ZhsE+iTXPhGhTWE64xD2o3z3hlg8JCAU8B5JP34VGW/g8E1/RXjsSA== X-Received: by 2002:a17:90a:a898:: with SMTP id h24mr8382989pjq.9.1616334277526; Sun, 21 Mar 2021 06:44:37 -0700 (PDT) Received: from localhost ([178.236.46.205]) by smtp.gmail.com with ESMTPSA id 202sm10617024pfu.46.2021.03.21.06.44.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 21 Mar 2021 06:44:37 -0700 (PDT) From: menglong8.dong@gmail.com X-Google-Original-From: dong.menglong@zte.com.cn To: herbert@gondor.apana.org.au, andy.shevchenko@gmail.com, kuba@kernel.org, linux@roeck-us.net, David.Laight@aculab.com Cc: davem@davemloft.net, dong.menglong@zte.com.cn, viro@zeniv.linux.org.uk, axboe@kernel.dk, linux-kernel@vger.kernel.org, netdev@vger.kernel.org Subject: [PATCH v2 net-next 2/2] net: socket: change MSG_CMSG_COMPAT to BIT(21) Date: Sun, 21 Mar 2021 21:43:57 +0800 Message-Id: <20210321134357.148323-3-dong.menglong@zte.com.cn> X-Mailer: git-send-email 2.31.0 In-Reply-To: <20210321134357.148323-1-dong.menglong@zte.com.cn> References: <20210321134357.148323-1-dong.menglong@zte.com.cn> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org From: Menglong Dong Currently, MSG_CMSG_COMPAT is defined as '1 << 31'. However, 'msg_flags' is defined with type of 'int' somewhere, such as 'packet_recvmsg' and other recvmsg functions: static int packet_recvmsg(struct socket *sock, struct msghdr *msg, size_t len, int flags) If MSG_CMSG_COMPAT is set in 'flags', it's value will be negative. Once it perform bit operations with MSG_*, the upper 32 bits of the result will be set, just like what Guenter Roeck explained here: https://lore.kernel.org/netdev/20210317013758.GA134033@roeck-us.net As David Laight suggested, fix this by change MSG_CMSG_COMPAT to some value else. MSG_CMSG_COMPAT is an internal value, which is't used in userspace, so this change works. Reported-by: Guenter Roeck Signed-off-by: Menglong Dong --- v2: - add comment to stop people from trying to use BIT(31) --- include/linux/socket.h | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/include/linux/socket.h b/include/linux/socket.h index d5ebfe30d96b..61b2694d68dd 100644 --- a/include/linux/socket.h +++ b/include/linux/socket.h @@ -312,17 +312,21 @@ struct ucred { * plain text and require encryption */ +#if defined(CONFIG_COMPAT) +#define MSG_CMSG_COMPAT BIT(21) /* This message needs 32 bit fixups */ +#else +#define MSG_CMSG_COMPAT 0 /* We never have 32 bit fixups */ +#endif + #define MSG_ZEROCOPY BIT(26) /* Use user data in kernel path */ #define MSG_FASTOPEN BIT(29) /* Send data in TCP SYN */ #define MSG_CMSG_CLOEXEC BIT(30) /* Set close_on_exec for file * descriptor received through * SCM_RIGHTS */ -#if defined(CONFIG_COMPAT) -#define MSG_CMSG_COMPAT BIT(31) /* This message needs 32 bit fixups */ -#else -#define MSG_CMSG_COMPAT 0 /* We never have 32 bit fixups */ -#endif +/* Attention: Don't use BIT(31) for MSG_*, as 'msg_flags' is defined + * as 'int' somewhere and BIT(31) will make it become negative. + */ /* Setsockoptions(2) level. Thanks to BSD these must match IPPROTO_xxx */