Received: by 2002:a05:6358:700f:b0:131:369:b2a3 with SMTP id 15csp3258222rwo; Fri, 4 Aug 2023 01:49:22 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGEalFPXccCn+FdmX+CrwLdiq/+jab+iyo6PkcwDaHrjv41OAE0OPcBGzzvsME6i0vA0RMI X-Received: by 2002:aa7:d715:0:b0:522:2dc0:1354 with SMTP id t21-20020aa7d715000000b005222dc01354mr1013992edq.23.1691138962380; Fri, 04 Aug 2023 01:49:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691138962; cv=none; d=google.com; s=arc-20160816; b=nKcNirHsUm8i5kwiFxAphGvpqk1jcdc79efx+ShQN7c6FGo4cszJvdPxX2ZRc/rNnF kwRZOVEW5u3/ZskNvCWN+PvDZUcH/+R3DH7EBFXeeQtPCQicHu8uInjAvEthVQ+D677k yBdVTeFPSRvNcKEosALoswjcaIKkCMqFCiXWc/qf3d3vYz1X7IDKkqnSo3UdHNfjwZZb yLKR6lSX3LkDOzucrqSx7CmEL1+mnsA0OdeqqXgUP5DjDidKGRzZA50a+jUVW8DiewOA WPf24COHDm/ucd5LVvte6n4B5BtN7mt4mmmJKT83d7NLL0Sv25UCcryeUAvWEPwR9L7L wNBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=xN1TF/cqSYy8egconCIVN+MATNViZmMKhKgDRHlEMBE=; fh=ubSGe9Pf/KxTId9rGYzy0xYsiY5Gj5OI3uWYUzuWZkk=; b=1JGuRt1HiRVf5SACYkyYlbidGd9h7tw74GD93sqtUsp/jPSZ+zobPeTYG65MvKJbqU a3Np177I0Y/qeI+PdmwVUmFcFxmpNohxP3SSccjwgk/WEdO466pbqfh9Oy/lDKS8lmBq OFY/L0XWhRnbwCBvCWJix3BR5+RXwgR4RnfIBobGoXEWzkMnI1FPGAYO3mdj8nHUbw7t 3c/N6BoRNZavoxRJFH1/5QvkCLLX2FtUTF6PmtVGmy6nzd3w6pSCa7+elDrxIiVAwJoL yFC10v87dU3s6zVkZi8ZTStoxOFOWnknRYCS8ZhVlBfiUVVXsTn58ww5U5LavV2MtFbB rt3w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=ResE7mYA; 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=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id j19-20020aa7ca53000000b005231f5437fcsi302273edt.520.2023.08.04.01.48.57; Fri, 04 Aug 2023 01:49:22 -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; dkim=pass header.i=@intel.com header.s=Intel header.b=ResE7mYA; 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=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234617AbjHDI0l (ORCPT + 99 others); Fri, 4 Aug 2023 04:26:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59330 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234558AbjHDI00 (ORCPT ); Fri, 4 Aug 2023 04:26:26 -0400 Received: from mgamail.intel.com (mgamail.intel.com [192.55.52.115]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8695730E0 for ; Fri, 4 Aug 2023 01:26:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1691137585; x=1722673585; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=oOKhR2UGvbPRHxNgYwLaRfSIwQ0Gyd6LYZcMKMFhKWQ=; b=ResE7mYAXbqhbH0c3BBb9SaOuQIeXhH9h3nAgnc/kpTMlgkIgOJ1OeBe N6x3p6yscqtG+Tm6K6DLlkH0/Wnfn3puSUJld+6p/NBECV+tzOte3A1CU /TGBbeVNELxROIDrQK8eRX9qczFA4D0ozhX1D8lvgLDY4sueuw+SDi4uu WE2F1K5An4IQGoFOrx2hd0bgMv07UA0ZDj7/M2inj9hQLGJaHV6Jq3YP1 QaTv1CqK9SAcieZBvOSRzX/93lfJPsPZPkkRMQdqKdoQbLhy3gkN9BaGu IeKWf3762c0juWNkivmehS30w/k4HKPO26C+m+oC4D60M6fz4JlMkJ1pu A==; X-IronPort-AV: E=McAfee;i="6600,9927,10791"; a="370090212" X-IronPort-AV: E=Sophos;i="6.01,254,1684825200"; d="scan'208";a="370090212" Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 04 Aug 2023 01:26:24 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10791"; a="733132237" X-IronPort-AV: E=Sophos;i="6.01,254,1684825200"; d="scan'208";a="733132237" Received: from black.fi.intel.com ([10.237.72.28]) by fmsmga007.fm.intel.com with ESMTP; 04 Aug 2023 01:26:21 -0700 Received: by black.fi.intel.com (Postfix, from userid 1003) id 99899F12; Fri, 4 Aug 2023 11:26:32 +0300 (EEST) From: Andy Shevchenko To: Andy Shevchenko , Marco Elver , linux-kernel@vger.kernel.org, kasan-dev@googlegroups.com, linux-mm@kvack.org Cc: Petr Mladek , Steven Rostedt , Rasmus Villemoes , Sergey Senozhatsky , Alexander Potapenko , Dmitry Vyukov , Andrew Morton Subject: [PATCH v1 4/4] lib/vsprintf: Split out sprintf() and friends Date: Fri, 4 Aug 2023 11:26:19 +0300 Message-Id: <20230804082619.61833-5-andriy.shevchenko@linux.intel.com> X-Mailer: git-send-email 2.40.0.1.gaa8946217a0b In-Reply-To: <20230804082619.61833-1-andriy.shevchenko@linux.intel.com> References: <20230804082619.61833-1-andriy.shevchenko@linux.intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_NONE,URIBL_BLOCKED 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 kernel.h is being used as a dump for all kinds of stuff for a long time. sprintf() and friends are used in many drivers without need of the full kernel.h dependency train with it. Here is the attempt on cleaning it up by splitting out sprintf() and friends. Signed-off-by: Andy Shevchenko --- include/linux/kernel.h | 30 +----------------------------- include/linux/sprintf.h | 24 ++++++++++++++++++++++++ lib/vsprintf.c | 1 + 3 files changed, 26 insertions(+), 29 deletions(-) create mode 100644 include/linux/sprintf.h diff --git a/include/linux/kernel.h b/include/linux/kernel.h index b9e76f717a7e..cee8fe87e9f4 100644 --- a/include/linux/kernel.h +++ b/include/linux/kernel.h @@ -29,6 +29,7 @@ #include #include #include +#include #include #include #include @@ -203,35 +204,6 @@ static inline void might_fault(void) { } void do_exit(long error_code) __noreturn; -extern int num_to_str(char *buf, int size, - unsigned long long num, unsigned int width); - -/* lib/printf utilities */ - -extern __printf(2, 3) int sprintf(char *buf, const char * fmt, ...); -extern __printf(2, 0) int vsprintf(char *buf, const char *, va_list); -extern __printf(3, 4) -int snprintf(char *buf, size_t size, const char *fmt, ...); -extern __printf(3, 0) -int vsnprintf(char *buf, size_t size, const char *fmt, va_list args); -extern __printf(3, 4) -int scnprintf(char *buf, size_t size, const char *fmt, ...); -extern __printf(3, 0) -int vscnprintf(char *buf, size_t size, const char *fmt, va_list args); -extern __printf(2, 3) __malloc -char *kasprintf(gfp_t gfp, const char *fmt, ...); -extern __printf(2, 0) __malloc -char *kvasprintf(gfp_t gfp, const char *fmt, va_list args); -extern __printf(2, 0) -const char *kvasprintf_const(gfp_t gfp, const char *fmt, va_list args); - -extern __scanf(2, 3) -int sscanf(const char *, const char *, ...); -extern __scanf(2, 0) -int vsscanf(const char *, const char *, va_list); - -extern int no_hash_pointers_enable(char *str); - extern int get_option(char **str, int *pint); extern char *get_options(const char *str, int nints, int *ints); extern unsigned long long memparse(const char *ptr, char **retptr); diff --git a/include/linux/sprintf.h b/include/linux/sprintf.h new file mode 100644 index 000000000000..00d1fdc70a3e --- /dev/null +++ b/include/linux/sprintf.h @@ -0,0 +1,24 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +#ifndef _LINUX_KERNEL_SPRINTF_H_ +#define _LINUX_KERNEL_SPRINTF_H_ + +#include + +int num_to_str(char *buf, int size, unsigned long long num, unsigned int width); + +__printf(2, 3) int sprintf(char *buf, const char * fmt, ...); +__printf(2, 0) int vsprintf(char *buf, const char *, va_list); +__printf(3, 4) int snprintf(char *buf, size_t size, const char *fmt, ...); +__printf(3, 0) int vsnprintf(char *buf, size_t size, const char *fmt, va_list args); +__printf(3, 4) int scnprintf(char *buf, size_t size, const char *fmt, ...); +__printf(3, 0) int vscnprintf(char *buf, size_t size, const char *fmt, va_list args); +__printf(2, 3) __malloc char *kasprintf(gfp_t gfp, const char *fmt, ...); +__printf(2, 0) __malloc char *kvasprintf(gfp_t gfp, const char *fmt, va_list args); +__printf(2, 0) const char *kvasprintf_const(gfp_t gfp, const char *fmt, va_list args); + +__scanf(2, 3) int sscanf(const char *, const char *, ...); +__scanf(2, 0) int vsscanf(const char *, const char *, va_list); + +int no_hash_pointers_enable(char *str); + +#endif /* _LINUX_KERNEL_SPRINTF_H */ diff --git a/lib/vsprintf.c b/lib/vsprintf.c index eb0934d02722..e553bc9e18f3 100644 --- a/lib/vsprintf.c +++ b/lib/vsprintf.c @@ -34,6 +34,7 @@ #include #include #include +#include #include #include #include -- 2.40.0.1.gaa8946217a0b