Received: by 2002:a05:7412:2a8a:b0:fc:a2b0:25d7 with SMTP id u10csp157458rdh; Wed, 7 Feb 2024 00:13:09 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCXahtwB2pPLovBV1pCNh/BsZt81vC+GcXaMmvKKtp+ypyZBvD+OdMTlW7qNWdN+EVDyUMM2DaM3lo/Z/btN+SGGwFvBb2y77RBowM0W9g== X-Google-Smtp-Source: AGHT+IHAdg/r/TxKsQ6pEBN//blZ0nXYcSXMSv2U2oAgEBzCcv1biz2f2VemTCVlxvciE6MRjILq X-Received: by 2002:a05:6808:298b:b0:3bd:59da:57ba with SMTP id ex11-20020a056808298b00b003bd59da57bamr4044783oib.59.1707293588888; Wed, 07 Feb 2024 00:13:08 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1707293588; cv=pass; d=google.com; s=arc-20160816; b=au9L109AtwIM0+RXfPXr3wqPkwo3fjh47OVR/5RonCWg3Fe+JXIOtVoSIrgoQ0sEhj x66NZ+CpbqZE/CTL5d2FCOPv51NBR+ji/GrqNA7TvY8do78w4eR7GtOioUj0ibeOlIBU +9tkwN4gf6UobuOg6PSSeooYkrRxxPGm03bHk09MYdJZBVA0Z9rGq1Ouo39DoOnlcE8u 4g96wHLwOSQVfJ6dW7Ywwbs3wDVZodveV3TRwhys9sNYwozm3dgzdyOW3R8kd5vn/ln6 DtX5dlEoOwEEHR7oZ549SY8ex0fiM5ufEpure6wnF9eyO9AW8RG9Of+g4siyKFKww6R4 i/pg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:organization:from:references :cc:to:content-language:subject:user-agent:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:date:message-id :dkim-signature; bh=gPzY/qhLPoIustbM4iMvx00lVmpmt6lRPpcak+/jFBE=; fh=RIjQtw0iQSG3swYMq3vTrWPsQ2y2RbFyrzFvJbgOvf8=; b=LZQXT5va+zpL/hHORu5vLvUJP7DbVUjR1HlmNwTvsRWsCCDiPL6yOdm9DybyIhxnmS XTJ7iGkWFD+0X0CKTTJda71W+uH3Vj0xnQ733fZ4hZYkusjEz6kKYu6h9qjrlwScyIwn Ut3Q/Ac/OieWTicLMlx5ERIgfcWvEoTvCkteNdBwMaTl8HRWKCkj065jV2weEWOjyAtT t593kIgvAUfErs8dRoMmfpTF4RwHt7AAlDsFd2G+n9qDZWkMnNNC0+YCcPm+ozDREjfu DxqJgZlq4KXXAXK355OFoityJxswazsG9oOjWvrZjJ521JNEBif8TCquugjvg22m+aWt /vdQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=neznKzr5; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-56107-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-56107-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com X-Forwarded-Encrypted: i=2; AJvYcCWSERfjlcGU87zKVh9gAeQxpzSbU9cABQYwGzfEpJ+fEgUFd4VnLpGfMNcigWG2Ch0br/kBdApDKf9udIGdQ6LzoxRdvMJ1c6WlIdJ8bw== Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id u11-20020a62d44b000000b006dde16e7e1bsi985059pfl.235.2024.02.07.00.13.08 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 07 Feb 2024 00:13:08 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-56107-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=neznKzr5; arc=pass (i=1 spf=pass spfdomain=intel.com dkim=pass dkdomain=intel.com dmarc=pass fromdomain=intel.com); spf=pass (google.com: domain of linux-kernel+bounces-56107-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-56107-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 sy.mirrors.kernel.org (Postfix) with ESMTPS id 5E46FB26CEC for ; Wed, 7 Feb 2024 08:11:22 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 785172030F; Wed, 7 Feb 2024 08:11:02 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b="neznKzr5" 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 67EA0200AD; Wed, 7 Feb 2024 08:10:59 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=198.175.65.9 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707293461; cv=none; b=VopBhpiPnm0h6FNoXqhHVujjsJ96wSD1I80twHI1QE/g9ZeNqgQ7y4yIMoR8FuO8YcaJmgQOizwpwa66iopF3+lOEF4a/VcxZSS4LMrd9ZMg2hpUpTaspYT5b9xHMI3cLqYh4QaDsDN/eq6UuDidsSp61GMQqQuPj3zjSP8rc8k= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707293461; c=relaxed/simple; bh=WWW+c5tu4S/MBXxMtlC14ZlKqLEhduiv8dwYZ1sxo7Y=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=XtndNjj8+n8LLWiWOg5bxWBHYDR4HnTU4b6cbjjpInjHMcGaXZGaB/26iuZVKs2BCwG7puzYLyIb2Pkg6+ZQ/8GItH9lVX1/JAoelnG5G8jF4W8MT9h7w1qKZfgrmBnGLcLKrE530Gbh2bCHrL7S2rE1/vtbm6BsVjMf1C2QhYg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=intel.com; spf=pass smtp.mailfrom=intel.com; dkim=pass (2048-bit key) header.d=intel.com header.i=@intel.com header.b=neznKzr5; arc=none smtp.client-ip=198.175.65.9 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=1707293460; x=1738829460; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=WWW+c5tu4S/MBXxMtlC14ZlKqLEhduiv8dwYZ1sxo7Y=; b=neznKzr5cA8MUDSqErgu2OVeK+9RmP/Cfno09IdEPerugUq4J/BTDv3B YVwmGNXSxt3gVAm2XLt5s6IXnYee91gYWs8G9O47Bt7JVT1SDxNtbAtiq gecjUSRiSjQtdkJH+o5zyhe/3ZEFunNOSnpmKq5WtsqlEz2C6vnSV8CEz szF5KzEoXf9tD2mM255SxNkrC+7lhwJjvdUIw7oi2wq/OGUw9IX540IHG LeYtaeC54GQApAA0TQQK15cJZHcv/P04Nt6Wpkk9Yx+OTBYYChXTmSkfC NE/BWnUhFGW+Xck0c3ZdHCF0x78dLPvbUmSC6UDmaECJ7wfjM23/JCWWV A==; X-IronPort-AV: E=McAfee;i="6600,9927,10976"; a="23413966" X-IronPort-AV: E=Sophos;i="6.05,250,1701158400"; d="scan'208";a="23413966" Received: from fmviesa002.fm.intel.com ([10.60.135.142]) by orvoesa101.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 Feb 2024 00:10:59 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.05,250,1701158400"; d="scan'208";a="24486370" Received: from ahunter6-mobl1.ger.corp.intel.com (HELO [10.0.2.15]) ([10.252.42.151]) by fmviesa002-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 Feb 2024 00:10:53 -0800 Message-ID: <1b1a8514-e74f-439f-a3ab-ad19dda49c22@intel.com> Date: Wed, 7 Feb 2024 10:10:50 +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 v2 2/4] arch/x86/events/core: Convert sprintf/snprintf to sysfs_emit Content-Language: en-US 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: <20240126061319.245901-1-lizhijian@fujitsu.com> <20240126061319.245901-2-lizhijian@fujitsu.com> From: Adrian Hunter Organization: Intel Finland Oy, Registered Address: PL 281, 00181 Helsinki, Business Identity Code: 0357606 - 4, Domiciled in Helsinki In-Reply-To: <20240126061319.245901-2-lizhijian@fujitsu.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit On 26/01/24 08:13, 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 > ^^^^^ this one cannot convert to sysfs_emit > where it intends to print a sub-string. > >> ./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 > > Most of this patch is generated by: > $ make coccicheck MODE=patch COCCI=scripts/coccinelle/api/device_attr_show.cocci M=arch/x86/events/core.c | sed -n '6,$p' | patch -p1 > > 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 Reviewed-by: Adrian Hunter > --- > V2: > - Address Adrian's comment: > leave "snprintf(page, next_str - str + 1, "%s", str)" alone, it > intends to print a sub-string, that cannot covert to sysfs_emit simply. > - > V2: extract patch from the patch set[1] so that maintainer accept it separately. > [1] https://lore.kernel.org/lkml/20240116041129.3937800-1-lizhijian@fujitsu.com/ > Signed-off-by: Li Zhijian > --- > arch/x86/events/core.c | 12 ++++++------ > 1 file changed, 6 insertions(+), 6 deletions(-) > > diff --git a/arch/x86/events/core.c b/arch/x86/events/core.c > index 09050641ce5d..20d963196e4c 100644 > --- a/arch/x86/events/core.c > +++ b/arch/x86/events/core.c > @@ -1832,7 +1832,7 @@ ssize_t events_sysfs_show(struct device *dev, struct device_attribute *attr, cha > > /* string trumps id */ > if (pmu_attr->event_str) > - return sprintf(page, "%s\n", pmu_attr->event_str); > + return sysfs_emit(page, "%s\n", pmu_attr->event_str); > > return x86_pmu.events_sysfs_show(page, config); > } > @@ -1855,7 +1855,7 @@ ssize_t events_ht_sysfs_show(struct device *dev, struct device_attribute *attr, > * if they are owned by some other guest. The user tool > * has to re-read when a thread sibling gets onlined later. > */ > - return sprintf(page, "%s", > + return sysfs_emit(page, "%s", > topology_max_smt_threads() > 1 ? > pmu_attr->event_str_ht : > pmu_attr->event_str_noht); > @@ -1872,7 +1872,7 @@ ssize_t events_hybrid_sysfs_show(struct device *dev, > int i; > > if (hweight64(pmu_attr->pmu_type) == 1) > - return sprintf(page, "%s", pmu_attr->event_str); > + return sysfs_emit(page, "%s", pmu_attr->event_str); > > /* > * Hybrid PMUs may support the same event name, but with different > @@ -1894,7 +1894,7 @@ ssize_t events_hybrid_sysfs_show(struct device *dev, > if (next_str) > return snprintf(page, next_str - str + 1, "%s", str); > else > - return sprintf(page, "%s", str); > + return sysfs_emit(page, "%s", str); > } > str = strchr(str, ';'); > 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);