Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp253290rwb; Wed, 18 Jan 2023 17:14:35 -0800 (PST) X-Google-Smtp-Source: AMrXdXtEP9+eJQeu9G/KQd2N2cW6aifEuGuV+o+PB/wO5zwi6sPEgYp6+hiyS8hlhCPmdhBlFiNR X-Received: by 2002:a17:90b:234d:b0:225:a8f2:fa38 with SMTP id ms13-20020a17090b234d00b00225a8f2fa38mr9527099pjb.21.1674090874851; Wed, 18 Jan 2023 17:14:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1674090874; cv=none; d=google.com; s=arc-20160816; b=KiEuXnsxvwyLzA02WZ8iWFrqn6LtXYxnakQpYYQuq0CU2G8ERw98xJcUp/EHyR0+Mi +hNcgfiPn+pASRM5uFV4nSpp0yHrAN8Rs0FSDz+Hae6AnIDgWWB1B+k3zkUA3PBelQLR q6Spypzm1p8sH3XEtrthIoN8wwgVg57tqnoIMMbM383LxKOhwaetR2bb2s1uJ/18IJFW El1vC1oJP5luBiTJGSthlqLWIB5c4+Kn8cVwiEvdEIyLi4pSag48vtQYqeu04coiabr2 TKxp3FM44BrQWU6+43D/LJtZxO5ASCkUODfWubZB3i1Lgg47K/Ja+RKN3h1KChgSojJs zbrA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:references:to:from:subject:cc :message-id:date:content-transfer-encoding:mime-version :dkim-signature; bh=bzC0sU/N12ncEGDzD9fPcibOi5DmMLZMi0fdgF9XEqw=; b=wIsjEEFMoko7gR9Y6sNoZKXBZdo3+fs0zHRNToHTAaW0SpHUBZ1d+7Wp+wRTxr1OZ1 SFSWE7J9IOK3G/HueFWrhgNlodMrbEt7/cy8TYDPLhyI8Er3djIxMXCojiumtfdxVh0f b/Z+ltPE4BBeN4OnEjKPXbjdpwHmDpeP2FxSl1oJsBZcfhb5glJZVh9BiD0LYsOSEu2b Eosgy/prs3XSbfdsSWB9xou/MupW7eo8dwSYkyuMw0gh6j/jYqSUHjVo+anXv0l24D3u 2jOPkTQxwB0uAxP1g0B6dis39jwyIioUa2Nh7v1nkncvHqoUQs+RAIlb2eLX86O+GyiJ IavA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="AYtPSQ8/"; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id j63-20020a638b42000000b004bec17d1700si7232140pge.725.2023.01.18.17.14.28; Wed, 18 Jan 2023 17:14:34 -0800 (PST) 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; dkim=pass header.i=@gmail.com header.s=20210112 header.b="AYtPSQ8/"; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229570AbjASBCr (ORCPT + 44 others); Wed, 18 Jan 2023 20:02:47 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33880 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229483AbjASBCp (ORCPT ); Wed, 18 Jan 2023 20:02:45 -0500 Received: from mail-pj1-x1029.google.com (mail-pj1-x1029.google.com [IPv6:2607:f8b0:4864:20::1029]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6B44C59552; Wed, 18 Jan 2023 17:02:44 -0800 (PST) Received: by mail-pj1-x1029.google.com with SMTP id u1-20020a17090a450100b0022936a63a21so4285720pjg.4; Wed, 18 Jan 2023 17:02:44 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=in-reply-to:references:to:from:subject:cc:message-id:date :content-transfer-encoding:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=bzC0sU/N12ncEGDzD9fPcibOi5DmMLZMi0fdgF9XEqw=; b=AYtPSQ8/l89DagqqXtQI6yiVXSzsTcUBaQiMk2f1jiZyJ5ELiIGB0pZLTJnp8amdI2 E9USP8ckmgFNAtbnEoOYYEmnUi5knwgQiQIsu+XBK87SrVt3G4Z7NEK00vhQjdlc4uAe cUWuQ9+EIWNEUEecO15jMDjh7K8C3W/p/vLOToGoVZwCyALXyYsxihbAnAW9nkojB1jD W4PyN1pMYXFeHmI2ySiO/3SOQnFtrWf3y7kddaOhygH3d8MNWuA//hY+i/Lb0SZ6YloL AS9FQBWer3V6rNXX0e0CrLQATvoZgKgHf3OyQiHAf0umnVjJScE+CMG+PuftHWcDfxSI KSeQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:references:to:from:subject:cc:message-id:date :content-transfer-encoding:mime-version:x-gm-message-state:from:to :cc:subject:date:message-id:reply-to; bh=bzC0sU/N12ncEGDzD9fPcibOi5DmMLZMi0fdgF9XEqw=; b=DhtYQrVP7/6ydcAhzZh4GzL046UxGqzzP7Nx9dgmIEmU3b1dUS+sJIqoG+PKwylhxL ha1pxTBqFPFYQzwT7dvEF7goVqYWfXGHuBwLyRs2zxO01KxyCKqCFvWKqil16GJBdihy XvTsS+dXrMYsSa1SYpRR9ffR55HM3wMe0+xK9oczOL2qNfDC/IEC3nrOya5wK6mmQvGd 1m/dbiEa8xcV1WTDvCBqdXPpTmYENnkKaZTYN7z4wpOti8H3W//XgqHvB9cFxEoyg56L o3Ox74GpxSYOlMCpc62rlmwKtEMB7ucy3bur3lcwgQXIap9f3gMjKDPeN6PYXjaaE2GB XrnQ== X-Gm-Message-State: AFqh2krBdcYV4CugroocLyjefY8pTsdwM8YMR71qVwgzdLv0/pgheZ9o XRMo9vGZALst+b+BAiyZwpU= X-Received: by 2002:a05:6a20:ba87:b0:af:8e92:3eeb with SMTP id fb7-20020a056a20ba8700b000af8e923eebmr9175136pzb.9.1674090163920; Wed, 18 Jan 2023 17:02:43 -0800 (PST) Received: from localhost (193-116-102-45.tpgi.com.au. [193.116.102.45]) by smtp.gmail.com with ESMTPSA id e3-20020a63f543000000b004cd2eebc551sm5414418pgk.62.2023.01.18.17.02.39 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 18 Jan 2023 17:02:43 -0800 (PST) Mime-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset=UTF-8 Date: Thu, 19 Jan 2023 11:02:36 +1000 Message-Id: Cc: , , , , , , , , Subject: Re: [PATCH v3 04/24] powerpc/secvar: Handle format string in the consumer From: "Nicholas Piggin" To: "Andrew Donnellan" , , X-Mailer: aerc 0.13.0 References: <20230118061049.1006141-1-ajd@linux.ibm.com> <20230118061049.1006141-5-ajd@linux.ibm.com> In-Reply-To: <20230118061049.1006141-5-ajd@linux.ibm.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS 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 Wed Jan 18, 2023 at 4:10 PM AEST, Andrew Donnellan wrote: > From: Russell Currey > > The code that handles the format string in secvar-sysfs.c is entirely > OPAL specific, so create a new "format" op in secvar_operations to make > the secvar code more generic. No functional change. > > Signed-off-by: Russell Currey > Signed-off-by: Andrew Donnellan > > --- > > v2: Use sysfs_emit() instead of sprintf() (gregkh) > > v3: Enforce format string size limit (ruscur) > --- > arch/powerpc/include/asm/secvar.h | 3 +++ > arch/powerpc/kernel/secvar-sysfs.c | 23 ++++-------------- > arch/powerpc/platforms/powernv/opal-secvar.c | 25 ++++++++++++++++++++ > 3 files changed, 33 insertions(+), 18 deletions(-) > > diff --git a/arch/powerpc/include/asm/secvar.h b/arch/powerpc/include/asm= /secvar.h > index 07ba36f868a7..8b6475589120 100644 > --- a/arch/powerpc/include/asm/secvar.h > +++ b/arch/powerpc/include/asm/secvar.h > @@ -11,12 +11,15 @@ > #include > #include > =20 > +#define SECVAR_MAX_FORMAT_LEN 30 // max length of string returned by ->f= ormat() > + > extern const struct secvar_operations *secvar_ops; > =20 > struct secvar_operations { > int (*get)(const char *key, u64 key_len, u8 *data, u64 *data_size); > int (*get_next)(const char *key, u64 *key_len, u64 keybufsize); > int (*set)(const char *key, u64 key_len, u8 *data, u64 data_size); > + ssize_t (*format)(char *buf); Maybe pass the buf size as an argument here? Which is a bit less error prone and more flexible than finding the right #define for it. Thanks, Nick