Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp734809rwr; Thu, 27 Apr 2023 07:32:34 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5JBJpKcHqKrcQ++dlYNjSktV4By0iqeLucKSQa5/XwbbH4Tpjvw9Zji1alZiYNUmukgvxn X-Received: by 2002:a05:6a20:1616:b0:f0:38a7:dc71 with SMTP id l22-20020a056a20161600b000f038a7dc71mr2551344pzj.4.1682605953427; Thu, 27 Apr 2023 07:32:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1682605953; cv=none; d=google.com; s=arc-20160816; b=EfT+lR/NGHiymO6JWSnlgcenQ2SbcTs4u64mARLJVeocllODbndGidTHiuPoC540Cd S7bIWK7gnBGMFtPRtGgo4LfDSFQPFo1pZTjEbXUhcWxqwa2kL7x1DLSfYMGFOE6zZHsj sniQqVVF122QmsGlOa2XrIrJFEPEX6viMsBIkZqcX11Kmvwj0bQyq4qM/7rW0HpImEd+ iDPfp2+BQ+4wra6Dc+2RPDeb4tpuJJk6IzbyWd46j9+m+VEnVHThLaGkLnHm18pOw8mE q33WyUhSpaMzXVYNQd8ca0YgY6LfZNIDyDShKuraBp9aNTXMqV9Ot+Msf9aNmvM/VzfQ GN6g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :content-language:references:cc:to:subject:user-agent:mime-version :date:message-id; bh=PAvk4YXJUSeXR1xKjQNPeG7MYoNBBxHpa7hMkS8t510=; b=Vooso8qYH5yR/AAB5kivh7RR0VS+TA86ee4SxY0PL/j+Hpit4/f8mDCbdKP+Dt5RbA BgxOaITPEqUsjAp11J5B+fNFAmW/Xtyy3FB89tB9tUVQrI6liy/zZL6kZ/4CdMbRAlNy 1RZzyZEy/P0XbkGlFHYPNtwTRWsY8EKJOMk+jk8flg5zn95zhmTq/kS9D11pRu8/JO2Y 79+kNzuvyBZuTDFmUr8+NlTM5R3sN+VXF6zA3Q8UqAu4pmlbVXYuIj2VuLQRCEr50iHF n0mZKfQwTMMVO62WMsxHCKuhCsPEo/cB0mKw6OZ0tfF5xbgRamACLGxjN+vRBScvfWgL EDCA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id w30-20020a63475e000000b004fb8abdd188si19195058pgk.115.2023.04.27.07.32.17; Thu, 27 Apr 2023 07:32:33 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243211AbjD0O0Z (ORCPT + 99 others); Thu, 27 Apr 2023 10:26:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45366 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243662AbjD0O0X (ORCPT ); Thu, 27 Apr 2023 10:26:23 -0400 Received: from www484.your-server.de (www484.your-server.de [78.47.237.138]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 518BA83; Thu, 27 Apr 2023 07:26:11 -0700 (PDT) Received: from sslproxy03.your-server.de ([88.198.220.132]) by www484.your-server.de with esmtpsa (TLS1.3) tls TLS_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1ps2ZS-0008uX-8N; Thu, 27 Apr 2023 16:26:06 +0200 Received: from [2003:ca:6730:e8f8:a2c4:4e1c:f83c:db4b] by sslproxy03.your-server.de with esmtpsa (TLSv1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1ps2ZR-0009eG-Hz; Thu, 27 Apr 2023 16:26:05 +0200 Message-ID: Date: Thu, 27 Apr 2023 16:26:05 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.10.1 Subject: Re: [PATCH v3 1/2] vsprintf: Add %p[mM]U for uppercase MAC address To: Rasmus Villemoes , Quentin Schulz , Greg Kroah-Hartman , Petr Mladek , Steven Rostedt , Sergey Senozhatsky , Andy Shevchenko , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Kyungmin Park , Andrzej Pietrasiewicz , Felipe Balbi Cc: stable@vger.kernel.org References: <2023042625-rendition-distort-fe06@gregkh> <20230427115120.241954-1-k.graefe@gateware.de> Content-Language: en-US From: =?UTF-8?Q?Konrad_Gr=c3=a4fe?= In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Authenticated-Sender: k.graefe@gateware.de X-Virus-Scanned: Clear (ClamAV 0.103.8/26889/Thu Apr 27 09:25:48 2023) X-Spam-Status: No, score=-3.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, NO_DNS_FOR_FROM,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE,T_SPF_TEMPERROR autolearn=ham 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 27.04.23 14:35, Rasmus Villemoes wrote: > On 27/04/2023 13.51, Konrad Gräfe wrote: >> The CDC-ECM specification requires an USB gadget to send the host MAC >> address as uppercase hex string. This change adds the appropriate >> modifier. >> >> Cc: stable@vger.kernel.org > > Why cc stable? I believe the second patch matches the criteria but it uses this one. > >> Signed-off-by: Konrad Gräfe >> --- >> Added in v3 >> >> lib/vsprintf.c | 18 +++++++++++++++--- >> 1 file changed, 15 insertions(+), 3 deletions(-) > > The diffstat here, or for some other patch in the same series, > definitely ought to mention lib/test_printf.c. > >> diff --git a/lib/vsprintf.c b/lib/vsprintf.c >> index be71a03c936a..8aee1caabd9e 100644 >> --- a/lib/vsprintf.c >> +++ b/lib/vsprintf.c >> @@ -1269,9 +1269,10 @@ char *mac_address_string(char *buf, char *end, u8 *addr, >> { >> char mac_addr[sizeof("xx:xx:xx:xx:xx:xx")]; >> char *p = mac_addr; >> - int i; >> + int i, pos; >> char separator; >> bool reversed = false; >> + bool uppercase = false; >> >> if (check_pointer(&buf, end, addr, spec)) >> return buf; >> @@ -1281,6 +1282,10 @@ char *mac_address_string(char *buf, char *end, u8 *addr, >> separator = '-'; >> break; >> >> + case 'U': >> + uppercase = true; >> + break; >> + >> case 'R': >> reversed = true; >> fallthrough; > > This seems broken, and I'm surprised the compiler doesn't warn about > separator possibly being uninitialized further down. I'm also surprised > your testing hasn't caught this. For reference, the full switch > statement is currently > > switch (fmt[1]) { > case 'F': > separator = '-'; > break; > > case 'R': > reversed = true; > fallthrough; > > default: > separator = ':'; > break; > } > >> @@ -1292,9 +1297,14 @@ char *mac_address_string(char *buf, char *end, u8 *addr, >> >> for (i = 0; i < 6; i++) { >> if (reversed) >> - p = hex_byte_pack(p, addr[5 - i]); >> + pos = 5 - i; >> + else >> + pos = i; >> + >> + if (uppercase) >> + p = hex_byte_pack_upper(p, addr[pos]); >> else >> - p = hex_byte_pack(p, addr[i]); >> + p = hex_byte_pack(p, addr[pos]); > > I think this becomes quite hard to follow. We have string_upper() in > linux/string_helpers.h, so I'd rather just leave this loop alone and do > > if (uppercase) > string_upper(mac_addr, mac_addr); > > after the nul-termination. > > Rasmus >