Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp2253417iof; Wed, 8 Jun 2022 00:34:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzxA2plkGqYtOVizol+2JepjBriX35s1UoNKz1zyPgKSs4Zc021YlSTLldFvAMCpD0Biser X-Received: by 2002:a17:90b:38c4:b0:1e6:89f9:73da with SMTP id nn4-20020a17090b38c400b001e689f973damr33682833pjb.220.1654673670648; Wed, 08 Jun 2022 00:34:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654673670; cv=none; d=google.com; s=arc-20160816; b=kp0G6YK02SsYGzi9oRk+tH735nHFOGo5hkukycQeYhvctMZP055/XeIvE7ACvzTM5Q QrUtrHrNFX9GykJT6K1weRtKe1S/wbf8IKDZeHKaRdVIj0fHJUPp/1K6RvfBM4yHYpSw DwWXHqhIyhZES8cBNoq29Tl7lgJo0kfABBaX5qCVeW3ySLUFMtzm5TCQvDIbmTxanInd 8KAmy0v0LCnK+4f/n4IJhqzQOMsXBoZMVuPSREyLCF2ut9W2hqcbOIEdmR0SqR6nXu2Z ocSg6WmWobmJUc3zuGPFV5XJjM8fkAYAohl3IaMZUwDcbMFSiqnus8eYW6lbgUZGL473 otVQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=UhYmoMA9VfntxTVlMtRwMvqfJ9p2Mh+kyrF7/5v6k7A=; b=Eb1tw4phFHxk7ZI9e07wJyea0MZGVFWjTF7rnNWim09C6IvBSp5UixagEKMo3IeV3p ZElk+79WeGIuuoEil+AdxfnrlfYp+R7k8jyph38Tct6ddupV8D+c4/mWqH0kaNyxTTG0 LjYuvKxLfcC85pb8WcoXnKyqyXNtTaCWlDOg93jy8eR5dqvhiKugpBHQ3j27efmTbfhA CfiDKVGL9gUBOxihzaoQCL3dkpcFGntHB9iY5lzkUsIfATk0gblzu81VwYIK+FS0uDtX xxKkW+83u1BorB0oTPkRGquW365eTHQ8Ci9B2TEFGigcXL+bFSWNzALlYYc5bsRdfT+k CxUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux-foundation.org header.s=korg header.b=CBxSOnoO; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id f10-20020a056a0022ca00b0051c4658b895si4672193pfj.210.2022.06.08.00.34.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 08 Jun 2022 00:34:30 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@linux-foundation.org header.s=korg header.b=CBxSOnoO; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id C7D6522AE54; Wed, 8 Jun 2022 00:06:54 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1392629AbiFHB6m (ORCPT + 99 others); Tue, 7 Jun 2022 21:58:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48964 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1835791AbiFGX5A (ORCPT ); Tue, 7 Jun 2022 19:57:00 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E61B5FC839 for ; Tue, 7 Jun 2022 16:21:31 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 8E951B8246D for ; Tue, 7 Jun 2022 23:21:30 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 180CBC3411C; Tue, 7 Jun 2022 23:21:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linux-foundation.org; s=korg; t=1654644089; bh=ymIo+kLBAAc0OcbtfNyqfVnFABqcw4XNx0p6uN0nCIg=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=CBxSOnoO0TAC1DtNHY8cqYCZ7pnePew9ByeYmSBHi3RynjaUzxzf0OdKKjT1iV23y I4yjFKLKiC8t1e/9qdw1EPVb2CihwC42WgtTFgrVtDoj23B3/UISgAP7XsZejFRvmo xhoIlR5qXfUYDXrIaRv2tanEGqC+A+xlRumFJDt0= Date: Tue, 7 Jun 2022 16:21:28 -0700 From: Andrew Morton To: Nick Desaulniers Cc: Justin Stitt , Nathan Chancellor , Tom Rix , linux-kernel@vger.kernel.org, llvm@lists.linux.dev, Richard Smith Subject: Re: [PATCH] include/uapi/linux/swab.h: add __u16 cast to __swab16 conditional Message-Id: <20220607162128.b5d4aa70f4a8a7610ce29250@linux-foundation.org> In-Reply-To: References: <20220607222006.22719-1-jstitt007@gmail.com> <20220607152744.d7c801d092529309500ac9a6@linux-foundation.org> X-Mailer: Sylpheed 3.7.0 (GTK+ 2.24.33; x86_64-redhat-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-3.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,RDNS_NONE,SPF_HELO_NONE, T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 7 Jun 2022 15:42:56 -0700 Nick Desaulniers wrote: > On Tue, Jun 7, 2022 at 3:27 PM Andrew Morton wrote: > > > > On Tue, 7 Jun 2022 15:20:06 -0700 Justin Stitt wrote: > > > > > if __HAVE_BUILTIN_BSWAP16__ is defined then __swab16 utilizes a __u16 cast. > > > This same cast should be used if __HAVE_BUILTIN_BSWAP16__ is not defined as > > > well. This should fix loads (at least a few) clang -Wformat warnings > > > specifically with `ntohs()` > > > > > > ... > > > > > > --- a/include/uapi/linux/swab.h > > > +++ b/include/uapi/linux/swab.h > > > @@ -102,7 +102,7 @@ static inline __attribute_const__ __u32 __fswahb32(__u32 val) > > > #define __swab16(x) (__u16)__builtin_bswap16((__u16)(x)) > > > #else > > > #define __swab16(x) \ > > > - (__builtin_constant_p((__u16)(x)) ? \ > > > + (__u16)(__builtin_constant_p((__u16)(x)) ? \ > > > ___constant_swab16(x) : \ > > > __fswab16(x)) > > > #endif > > > > More explanation, please? Both ___constant_swab16() and __fswab16() > > return __u16, so why does this patch have any effect? > > > > See this example: > https://godbolt.org/z/fzE73jn13 > And the ImplicitCastExpr nodes adding to the AST: > https://godbolt.org/z/oYeYxYdKW > > Both the second and third operand are promoted to int. > > C11: https://www.open-std.org/jtc1/sc22/wg14/www/docs/n1548.pdf > > 6.5.15/5 > >> If both the second and third operands have arithmetic type, the result type that would be determined by the usual arithmetic conversions, were they applied to those two operands, is the type of the result. > 6.3.1.8/1 > >> Otherwise, the integer promotions are performed on both operands. > 6.3.1.1/2 > >> If an int can represent all values of the original type (as restricted by the width, for a bit-field), the value is converted to an int; otherwise, it is converted to an unsigned int. These are called the integer promotions. Geeze. Can we please turn this into English and add it to the changelog? Is it saying that an expression int ? u16 : u16 has type int? Or something else? What did we do wrong here and is it possible to correct our types rather than adding a cast?