Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp3282277rdb; Wed, 13 Sep 2023 07:38:09 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHT2q8QZInSxeyTtC1Ipl6naOs+w6xz6SBOpplGJL38R3stt9DPcgIwoGyNufiA8OlWSqSh X-Received: by 2002:a05:6a21:339f:b0:140:d536:d428 with SMTP id yy31-20020a056a21339f00b00140d536d428mr2772928pzb.51.1694615888910; Wed, 13 Sep 2023 07:38:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1694615888; cv=none; d=google.com; s=arc-20160816; b=PzNtwBNgFNvsL6SxdJmuk1mE8xR8Y7n6jCAwvaFYvjSTEFxi4buSfSFWzXYneNyvse p28QfWySrsTCjDp7gcddRS0ALYC/9jfFNrkls0gz7qsw/kV6oSgQw8s2HkF6Sd7OBGSc eT5XOK6X4QkIa74FVgl7owQw9qDW3F8ysLvBxteIU5oo39Jtq221SYXLkrcHFJhJjtol Vvn7bbiAGtZQpuz36Xp0j2KUe5hZdlSMQew3dORz7B0KPjFp/W1cmgYozMAOfezxtblD d341ExwFsiIss+XEsFqBE1YHTEJ8EB1ZhhRGgLG5kHxl2YuJ+1/9S6w6c5uPoGn1SvIn zFpg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:subject:cc:to:from:date:references:in-reply-to :message-id:mime-version:user-agent:feedback-id:dkim-signature :dkim-signature; bh=Wf4mOedLuFzgt+orK7feQF8ml3FkBn9opSNWlL/YSoE=; fh=Ghay9nrRNBYl71j//wkZ95TqN2ihhonZLr/rbC/YN6U=; b=IJYn/K0H2rZbaB0j/Oi1KPPYu/xeX4taBwfME5yEJM6m4MJHlj/7dQzPcIYu2oNcj1 UkyE3MiRuRRydDXftmpUQnHtXufMq9aoXOKz9bxMgcZPMvEqAZeWP3XSQ7gG7/l0POFA 16ua3etVu/i8PS7ktHaUBPTwjCepIFOS7YmCb9gISThTqJTADLIED2nSS/Qn/T4Py3QD 5r6taW4mjyZT+melMnGylQijrRF8QSpkkt0d0rop7QzBGriUQv8AL3Zkdo4PoIt0Sr+V lMpR/HM6kTfc2NRJNUHBOEdpUTXHfRTZLeE7weRr8rsBgPIuHlRhA5aE6DqXGvDhrl+K mJGg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@squebb.ca header.s=fm2 header.b=QoUaChKk; dkim=pass header.i=@messagingengine.com header.s=fm2 header.b=YIG3n+6R; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [23.128.96.33]) by mx.google.com with ESMTPS id q9-20020a170902a3c900b001b6aa82743esi6696076plb.271.2023.09.13.07.38.08 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 13 Sep 2023 07:38:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) client-ip=23.128.96.33; Authentication-Results: mx.google.com; dkim=pass header.i=@squebb.ca header.s=fm2 header.b=QoUaChKk; dkim=pass header.i=@messagingengine.com header.s=fm2 header.b=YIG3n+6R; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.33 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 77513822B8C1; Wed, 13 Sep 2023 06:17:43 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240873AbjIMNRl (ORCPT + 99 others); Wed, 13 Sep 2023 09:17:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34218 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240843AbjIMNRk (ORCPT ); Wed, 13 Sep 2023 09:17:40 -0400 Received: from wout2-smtp.messagingengine.com (wout2-smtp.messagingengine.com [64.147.123.25]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AEAE619B4; Wed, 13 Sep 2023 06:17:36 -0700 (PDT) Received: from compute5.internal (compute5.nyi.internal [10.202.2.45]) by mailout.west.internal (Postfix) with ESMTP id AD7C23200960; Wed, 13 Sep 2023 09:17:35 -0400 (EDT) Received: from imap52 ([10.202.2.102]) by compute5.internal (MEProxy); Wed, 13 Sep 2023 09:17:36 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=squebb.ca; h=cc :cc:content-type:content-type:date:date:from:from:in-reply-to :in-reply-to:message-id:mime-version:references:reply-to:sender :subject:subject:to:to; s=fm2; t=1694611055; x=1694697455; bh=Wf 4mOedLuFzgt+orK7feQF8ml3FkBn9opSNWlL/YSoE=; b=QoUaChKkBapjwsOC5f jzsx9CRXvwWnDYcStMmt5/2AHNcLsmw97bJwFHbVv1ZGHAJp2qi/XdL5yr6lQJ7d 1cdanEHJ79wvfeXN08pqUbyuBFZsb45unwiSOfnx6mxEo0Id3Xm1zz68QIdC7Y2V Xap6WBPZIaNY6J7zV1Pz3gJeUTf+b+3kvpgc2c6Z6Sh4iKV3rYpzV73UJpq4MBA5 IMDJdJbueV3yuRicMg2j7YQFaV/lqXgnlxl2djGDpRIQaU7juz+8NppxzRYmKIUG RDntuRfpHG7pTb/4W6tMxnDK9ImB/5WIVnIfwrLUqIDx54WyH6fHXXxCS1cGY1G/ Sohg== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:cc:content-type:content-type:date:date :feedback-id:feedback-id:from:from:in-reply-to:in-reply-to :message-id:mime-version:references:reply-to:sender:subject :subject:to:to:x-me-proxy:x-me-proxy:x-me-sender:x-me-sender :x-sasl-enc; s=fm2; t=1694611055; x=1694697455; bh=Wf4mOedLuFzgt +orK7feQF8ml3FkBn9opSNWlL/YSoE=; b=YIG3n+6R2FxqS/2Ha9ZPmTYx9Fyv+ Mov8VCSL5Jn8HZs1RE2We9ueyCfHNy19jD4gHkFBItfzDm7CHEzA6OEis77ad1tY HFXaB5gdv4IanjPbKXPcqjsnJzGy0NgUL9RUXrWSnq6MYj6D8JCiFewCGPTiTVnW GvlIYHUXy1mRmPv4O7vu3TuMbWN8qLCLKwgx94TXpqZqLPUKoaycdZ8u8bp+RJPC z28OSaDRGWFrX95Egl/z7qErDX5uS55LPd4YroEtc1q61xROOkLy5rlcXYm0d7W5 xpLgfvZ6HrYN4uxKCJJD+Btich2BBHWR42gYU3QoY38H12JJyY4pzSnLA== X-ME-Sender: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedviedrudeikedgieefucetufdoteggodetrfdotf fvucfrrhhofhhilhgvmecuhfgrshhtofgrihhlpdfqfgfvpdfurfetoffkrfgpnffqhgen uceurghilhhouhhtmecufedttdenucesvcftvggtihhpihgvnhhtshculddquddttddmne cujfgurhepofgfggfkjghffffhvfevufgtsehttdertderredtnecuhfhrohhmpedfofgr rhhkucfrvggrrhhsohhnfdcuoehmphgvrghrshhonhdqlhgvnhhovhhosehsqhhuvggssg drtggrqeenucggtffrrghtthgvrhhnpeeiueefjeeiveetuddvkeetfeeltdevffevudeh ffefjedufedvieejgedugeekhfenucevlhhushhtvghrufhiiigvpedunecurfgrrhgrmh epmhgrihhlfhhrohhmpehmphgvrghrshhonhdqlhgvnhhovhhosehsqhhuvggssgdrtggr X-ME-Proxy: Feedback-ID: ibe194615:Fastmail Received: by mailuser.nyi.internal (Postfix, from userid 501) id BB020C6008B; Wed, 13 Sep 2023 09:17:34 -0400 (EDT) X-Mailer: MessagingEngine.com Webmail Interface User-Agent: Cyrus-JMAP/3.9.0-alpha0-745-g95dd7bea33-fm-20230905.001-g95dd7bea Mime-Version: 1.0 Message-Id: <35e188a5-de18-4b32-98d3-e4f460c23c1f@app.fastmail.com> In-Reply-To: <20230913092701.440959-2-andriy.shevchenko@linux.intel.com> References: <20230913092701.440959-1-andriy.shevchenko@linux.intel.com> <20230913092701.440959-2-andriy.shevchenko@linux.intel.com> Date: Wed, 13 Sep 2023 09:17:14 -0400 From: "Mark Pearson" To: "Andy Shevchenko" , "Hans de Goede" , "platform-driver-x86@vger.kernel.org" , linux-kernel@vger.kernel.org Cc: "Mark Pearson" , "markgross@kernel.org" Subject: Re: [PATCH v1 2/2] platform/x86: think-lmi: Use strreplace() to replace a character by nul Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (lipwig.vger.email [0.0.0.0]); Wed, 13 Sep 2023 06:17:43 -0700 (PDT) X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.vger.email On Wed, Sep 13, 2023, at 5:27 AM, Andy Shevchenko wrote: > We can replace > p = strchrnul(str, '$OLD'); > *p = '\0'; > with > strreplace(str, '$OLD', '\0'); > that does the compatible modification without a need of the temporary variable. > > Signed-off-by: Andy Shevchenko > --- > drivers/platform/x86/think-lmi.c | 19 ++++--------------- > 1 file changed, 4 insertions(+), 15 deletions(-) > > diff --git a/drivers/platform/x86/think-lmi.c b/drivers/platform/x86/think-lmi.c > index 94a3c7a74bc4..2f20fafe7f55 100644 > --- a/drivers/platform/x86/think-lmi.c > +++ b/drivers/platform/x86/think-lmi.c > @@ -198,14 +198,6 @@ static struct think_lmi tlmi_priv; > static struct class *fw_attr_class; > static DEFINE_MUTEX(tlmi_mutex); > > -/* ------ Utility functions ------------*/ > -/* Strip out CR if one is present */ > -static void strip_cr(char *str) > -{ > - char *p = strchrnul(str, '\n'); > - *p = '\0'; > -} > - > /* Convert BIOS WMI error string to suitable error code */ > static int tlmi_errstr_to_err(const char *errstr) > { > @@ -411,7 +403,7 @@ static ssize_t current_password_store(struct kobject *kobj, > > strscpy(setting->password, buf, setting->maxlen); > /* Strip out CR if one is present, setting password won't work if it > is present */ > - strip_cr(setting->password); > + strreplace(setting->password, '\n', '\0'); > return count; > } > > @@ -921,7 +913,7 @@ static ssize_t display_name_show(struct kobject > *kobj, struct kobj_attribute *at > static ssize_t current_value_show(struct kobject *kobj, struct > kobj_attribute *attr, char *buf) > { > struct tlmi_attr_setting *setting = to_tlmi_attr_setting(kobj); > - char *item, *value, *p; > + char *item, *value; > int ret; > > ret = tlmi_setting(setting->index, &item, LENOVO_BIOS_SETTING_GUID); > @@ -934,8 +926,7 @@ static ssize_t current_value_show(struct kobject > *kobj, struct kobj_attribute *a > ret = -EINVAL; > else { > /* On Workstations remove the Options part after the value */ > - p = strchrnul(value, ';'); > - *p = '\0'; > + strreplace(value, ';', '\0'); > ret = sysfs_emit(buf, "%s\n", value + 1); > } > kfree(item); > @@ -1418,7 +1409,6 @@ static int tlmi_analyze(void) > for (i = 0; i < TLMI_SETTINGS_COUNT; ++i) { > struct tlmi_attr_setting *setting; > char *item = NULL; > - char *p; > > tlmi_priv.setting[i] = NULL; > ret = tlmi_setting(i, &item, LENOVO_BIOS_SETTING_GUID); > @@ -1435,8 +1425,7 @@ static int tlmi_analyze(void) > strreplace(item, '/', '\\'); > > /* Remove the value part */ > - p = strchrnul(item, ','); > - *p = '\0'; > + strreplace(item, ',', '\0'); > > /* Create a setting entry */ > setting = kzalloc(sizeof(*setting), GFP_KERNEL); > -- > 2.40.0.1.gaa8946217a0b Looks good to me. Will aim to test and confirm on some systems. Thanks for the cleanup! Mark