Received: by 2002:a05:7412:8d09:b0:fa:4c10:6cad with SMTP id bj9csp281647rdb; Mon, 15 Jan 2024 23:02:28 -0800 (PST) X-Google-Smtp-Source: AGHT+IGVfd6NOsItkJLJ8rDQlVwjcTI3MWog3i4Uf+dHjRgNYuBDD7pRY0naidPU3JKDnXdOrcrH X-Received: by 2002:a05:6402:f81:b0:553:7a3f:3d63 with SMTP id eh1-20020a0564020f8100b005537a3f3d63mr1961446edb.18.1705388547896; Mon, 15 Jan 2024 23:02:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1705388547; cv=none; d=google.com; s=arc-20160816; b=PlUcNFQr0+RPVliBQqH6sDHB4vYRRYH0RvUbS185Cdfpdp7c4kN092a/tplZknbIGC AcHZeo1Y9V152Yi/ZzwhjwcvMIRbjZnYsa58n5cWoMiCVqW1KQ+2vF4Lf7BGgRnFLMI/ Q2G4LQNdYY6m3MoczdQXuxiF0DqiojQTbwnF/vf1nYJYQX6/LmfXpolxUYRj/ivEJ3xl zMTJNxFukCkxcgKqD+wQ+PXiyyX4EPnmzrXXYd8Ta3/8elN8NOdi+gHPeWnmOop1ykU1 1UveCAAK+9AjMZV1u3VkrHERVcswKdIJeMcrBfB2s+r7q1PL2qLXMGRXPC/bpV7++K4f QAVw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:organization:from :content-language:references:cc:to:subject:user-agent:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:date:message-id :dkim-signature; bh=t/6HM9+3vFRwJ9/wWsiQyS+6kf+gU79EfJ29We1Xr40=; fh=RQWPkgyTALVBU7U4B67SPPei225mmtyyNvyneRPIruk=; b=PnRsmc110nZs26ecI3Fo1fMqfehbVz1e14yoi/hzjJV2x+Fj/mM2mmYcl9KphTGw4Z BcFzRJIlXDo4yhHz+3SU5NdzL/8xZPB4le0WS9NqF5yZJ0bRaohuvFmE2+lVsj+LeTYi RkZgLo3HyD9ciWg+BKyq1UBEaNvepKcb0SH2hQGcW4u1eGMBuocmIzZ5a/8adVfeZmMX f/8sDm78okytWIwLO8eHIhHpAoyLVw4nf0J2pGnU2q6hLBzqQeVkGHArA8F+mJomMQoq klYjJDXjOxL0y9W+LXDX9OM4B+uwxhrFkzWQR9IKq+4IXZILtcGkGjzsb71FSMzdWXjy X4+g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=gJAzYh9q; spf=pass (google.com: domain of linux-kernel+bounces-27051-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-27051-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id y13-20020a50e60d000000b00559476ecefdsi1597017edm.650.2024.01.15.23.02.27 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 15 Jan 2024 23:02:27 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-27051-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=gJAzYh9q; spf=pass (google.com: domain of linux-kernel+bounces-27051-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-27051-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 693AB1F23F74 for ; Tue, 16 Jan 2024 07:02:27 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 7B90210A25; Tue, 16 Jan 2024 07:02:17 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="gJAzYh9q" Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.9]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id E551D11181; Tue, 16 Jan 2024 07:02:14 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=intel.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1705388535; x=1736924535; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=l77E4YgBgyvd0pSOaDBIh2Qs/NWQYKT4yc/7wy9bI7c=; b=gJAzYh9qSERmpPg+fytFsTtkjqktopH3nsNSSNUwtFQ4q6/4J8ag7G9e HH/cVFnTw3muLotOCfpuVj9/XK0Ttl2XxNaSuznF3DUsZ36/azQQlf9gH yHgWIyOVVqhNFKzX5Bi7ypDC2cF99KjQ1E1Tp9vPpcXTzRr959q6Y7kcU 5DuOdjE2Z2IhfUainwNn6T/PuHX5MD/R2edfTZpUcubD50in3VrP6iTkI Sh/ia5ZJujcXOCM1wyE7JxtVJmrE1KWYg3l/J80rRv87hngRMetbYK7VX I3+FeFfOyI2ARUobUEL52EsCMmzZazlJE2uM1Ue/acr+g9ncFj2WXOqTL A==; X-IronPort-AV: E=McAfee;i="6600,9927,10954"; a="18370739" X-IronPort-AV: E=Sophos;i="6.04,198,1695711600"; d="scan'208";a="18370739" Received: from orsmga001.jf.intel.com ([10.7.209.18]) by orvoesa101.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jan 2024 23:02:15 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10954"; a="818067712" X-IronPort-AV: E=Sophos;i="6.04,198,1695711600"; d="scan'208";a="818067712" Received: from ahunter6-mobl1.ger.corp.intel.com (HELO [10.0.2.15]) ([10.249.38.159]) by orsmga001-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 15 Jan 2024 23:01:35 -0800 Message-ID: Date: Tue, 16 Jan 2024 09:01:29 +0200 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 04/42] arch/x86/events/core: Convert snprintf to sysfs_emit To: Li Zhijian , linux-kernel@vger.kernel.org Cc: Peter Zijlstra , Ingo Molnar , Arnaldo Carvalho de Melo , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Ian Rogers , Thomas Gleixner , Borislav Petkov , Dave Hansen , x86@kernel.org, "H. Peter Anvin" , linux-perf-users@vger.kernel.org References: <20240116041129.3937800-1-lizhijian@fujitsu.com> <20240116045151.3940401-1-lizhijian@fujitsu.com> <20240116045151.3940401-2-lizhijian@fujitsu.com> Content-Language: en-US From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki In-Reply-To: <20240116045151.3940401-2-lizhijian@fujitsu.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit On 16/01/24 06:51, Li Zhijian wrote: > Per filesystems/sysfs.rst, show() should only use sysfs_emit() > or sysfs_emit_at() when formatting the value to be returned to user space. > > coccinelle complains that there are still a couple of functions that use > snprintf(). Convert them to sysfs_emit(). > >> ./arch/x86/events/core.c:1895:11-19: WARNING: please use sysfs_emit >> ./arch/x86/events/core.c:2542:8-16: WARNING: please use sysfs_emit >> ./arch/x86/events/core.c:2600:8-16: WARNING: please use sysfs_emit > > No functional change intended > > CC: Peter Zijlstra > CC: Ingo Molnar > CC: Arnaldo Carvalho de Melo > CC: Mark Rutland > CC: Alexander Shishkin > CC: Jiri Olsa > CC: Namhyung Kim > CC: Ian Rogers > CC: Adrian Hunter > CC: Thomas Gleixner > CC: Borislav Petkov > CC: Dave Hansen > CC: x86@kernel.org > CC: "H. Peter Anvin" > CC: linux-perf-users@vger.kernel.org > Signed-off-by: Li Zhijian > --- > arch/x86/events/core.c | 6 +++--- > 1 file changed, 3 insertions(+), 3 deletions(-) > > diff --git a/arch/x86/events/core.c b/arch/x86/events/core.c > index 40ad1425ffa2..52e5707be03b 100644 > --- a/arch/x86/events/core.c > +++ b/arch/x86/events/core.c > @@ -1892,7 +1892,7 @@ ssize_t events_hybrid_sysfs_show(struct device *dev, > if (x86_pmu.hybrid_pmu[i].pmu_type & pmu->pmu_type) { > next_str = strchr(str, ';'); > if (next_str) > - return snprintf(page, next_str - str + 1, "%s", str); > + return sysfs_emit(page, "%s", str); The intention seems to be to print only up to, and not including, the next ';', but sysfs_emit() is not going to do that. > else > return sprintf(page, "%s", str); > } > @@ -2539,7 +2539,7 @@ static ssize_t get_attr_rdpmc(struct device *cdev, > struct device_attribute *attr, > char *buf) > { > - return snprintf(buf, 40, "%d\n", x86_pmu.attr_rdpmc); > + return sysfs_emit(buf, "%d\n", x86_pmu.attr_rdpmc); > } > > static ssize_t set_attr_rdpmc(struct device *cdev, > @@ -2597,7 +2597,7 @@ static ssize_t max_precise_show(struct device *cdev, > struct device_attribute *attr, > char *buf) > { > - return snprintf(buf, PAGE_SIZE, "%d\n", x86_pmu_max_precise()); > + return sysfs_emit(buf, "%d\n", x86_pmu_max_precise()); > } > > static DEVICE_ATTR_RO(max_precise);