Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp647410ybl; Thu, 12 Dec 2019 02:37:02 -0800 (PST) X-Google-Smtp-Source: APXvYqybrUv8h4bq2t0pCX0GKqjwBHGjV3sQ4LBIDZu3wZ5amQwphdVvBA9hI37+QAbPb77oxxcG X-Received: by 2002:a05:6830:158d:: with SMTP id i13mr7604368otr.33.1576147022642; Thu, 12 Dec 2019 02:37:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576147022; cv=none; d=google.com; s=arc-20160816; b=mL13f3DRH+FtAJv5PNWDSeKYHEE9tRpkpCdWEX/UflRYh7Iey+6K8wgVC7FXGumg0o q6ymVXLtPZWLl3OF8XtoFubbLaLJ5qFBLJHNUk8orfzCJ8t2dEhCi8swcOIyP4Raf3Jn XukeyEeNVkQsUunqrKplVtmk4ZdsYnj6ncGapVs3rUcy1TJTYchmTzeHSqYeEjSrmQNS ZNoib+RJwKHlwVgsAq4vGYPOLc78ypzM6GOK7NpvUtcsCQtXlo3KG8UcJkiTGzoqfFlF y9PQiepVc9RsHQ/Cwktrm2NNvETDEkE8QsyOs4wuTh+uxoY3D2qD+uyzg1n40gTkdVvP wt+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=FQ5JLhG8qZ8T3mkxQUPU4Ck7VGjLcd1a95VEkmQByV8=; b=DZAVMOVcRCHZaFyxoG7SHqoXrpb+ZLr3sUlW5ZoJ0qMANVGFFfGQiEy8I1oG7Iarkw 4ig7wQmyJ78sUy3/SV6o5WYDnOF/7uJ9D7aF2RmbNjVGbR46L8u8bhZ8W6pd0PS70vc0 IE3aFLsEftxQnQy1nOZZpELroZ/3yiccITOijiwbupZpDLpsyvbtlBxc1+p3s04yhVZF sbnfOxTri3qULLR77HWBrMbRoHm+QXObO7BC1xAekk2qXFkvcK71ZAlT8MVFlHgvumzf nCyzUncGKKmVnCyVekG/Kk+4IfHncpsuOuyVnlhqciOt/y30tnSPLPnfgdf1qiwB1spA Fiog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=kHteG1hM; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n14si3015260otk.179.2019.12.12.02.36.50; Thu, 12 Dec 2019 02:37:02 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=kHteG1hM; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728643AbfLLKgS (ORCPT + 99 others); Thu, 12 Dec 2019 05:36:18 -0500 Received: from mail.kernel.org ([198.145.29.99]:39904 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728345AbfLLKgS (ORCPT ); Thu, 12 Dec 2019 05:36:18 -0500 Received: from linux-8ccs (nat.nue.novell.com [195.135.221.2]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9D7052067C; Thu, 12 Dec 2019 10:36:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1576146976; bh=8gJlthrB9wNvx1qqkg4/aM6N9zYfqxV5c+8oFCWUbZw=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=kHteG1hMCF1IwwD4k1rHtu7GpEyf5IOjgbMyLsCm1FMsjcMKofuDGrAgruXi3o/93 ESPYtpg5/gQVboXmDa71oVTXkPfSWNYd2cCtSi5+8+SdFSLIBnLyzOSC12IqVw0dlq r8jeXMiSOsRxgjRXhAxZimrsVwDrvK8gcr6axRnc= Date: Thu, 12 Dec 2019 11:36:07 +0100 From: Jessica Yu To: Masahiro Yamada Cc: Linux Kernel Mailing List , Matthias Maennich , Rasmus Villemoes , Arnd Bergmann , Greg Kroah-Hartman Subject: Re: [PATCH v3] export.h: reduce __ksymtab_strings string duplication by using "MS" section flags Message-ID: <20191212103606.GA11780@linux-8ccs> References: <20191125154217.18640-1-jeyu@kernel.org> <20191206124102.12334-1-jeyu@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii; format=flowed Content-Disposition: inline In-Reply-To: X-OS: Linux linux-8ccs 4.12.14-lp150.12.61-default x86_64 User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org +++ Masahiro Yamada [12/12/19 15:22 +0900]: >On Fri, Dec 6, 2019 at 9:41 PM Jessica Yu wrote: >> >> Commit c3a6cf19e695 ("export: avoid code duplication in >> include/linux/export.h") refactors export.h quite nicely, but introduces >> a slight increase in memory usage due to using the empty string "" >> instead of NULL to indicate that an exported symbol has no namespace. As >> mentioned in that commit, this meant an increase of 1 byte per exported >> symbol without a namespace. For example, if a kernel configuration has >> about 10k exported symbols, this would mean that the size of >> __ksymtab_strings would increase by roughly 10kB. >> >> We can alleviate this situation by utilizing the SHF_MERGE and >> SHF_STRING section flags. SHF_MERGE|SHF_STRING indicate to the linker >> that the data in the section are null-terminated strings that can be >> merged to eliminate duplication. More specifically, from the binutils >> documentation - "for sections with both M and S, a string which is a >> suffix of a larger string is considered a duplicate. Thus "def" will be >> merged with "abcdef"; A reference to the first "def" will be changed to >> a reference to "abcdef"+3". Thus, all the empty strings would be merged >> as well as any strings that can be merged according to the cited method >> above. For example, "memset" and "__memset" would be merged to just >> "__memset" in __ksymtab_strings. >> >> As of v5.4-rc5, the following statistics were gathered with x86 >> defconfig with approximately 10.7k exported symbols. >> >> Size of __ksymtab_strings in vmlinux: >> ------------------------------------- >> v5.4-rc5: 213834 bytes >> v5.4-rc5 with commit c3a6cf19e695: 224455 bytes >> v5.4-rc5 with this patch: 205759 bytes >> >> So, we already see memory savings of ~8kB compared to vanilla -rc5 and >> savings of nearly 18.7kB compared to -rc5 with commit c3a6cf19e695 on top. >> >> Unfortunately, as of this writing, strings will not get deduplicated for >> kernel modules, as ld does not do the deduplication for >> SHF_MERGE|SHF_STRINGS sections for relocatable files (ld -r), which >> kernel modules are. A patch for ld is currently being worked on to >> hopefully allow for string deduplication in relocatable files in the >> future. >> >> Suggested-by: Rasmus Villemoes >> Signed-off-by: Jessica Yu >> --- >> v3: >> - remove __KSTRTAB_ENTRY macros in favor of just putting the asm directly >> in ___EXPORT_SYMBOL >> - Document more clearly what the ___EXPORT_SYMBOL macro does >> >> include/asm-generic/export.h | 8 +++++--- >> include/linux/export.h | 27 ++++++++++++++++++++------- >> 2 files changed, 25 insertions(+), 10 deletions(-) >> >> diff --git a/include/asm-generic/export.h b/include/asm-generic/export.h >> index fa577978fbbd..23bc98e97a66 100644 >> --- a/include/asm-generic/export.h >> +++ b/include/asm-generic/export.h >> @@ -26,9 +26,11 @@ >> .endm >> >> /* >> - * note on .section use: @progbits vs %progbits nastiness doesn't matter, >> - * since we immediately emit into those sections anyway. >> + * note on .section use: we specify progbits since usage of the "M" (SHF_MERGE) >> + * section flag requires it. Use '%progbits' instead of '@progbits' since the >> + * former apparently works on all arches according to the binutils source. >> */ >> + >> .macro ___EXPORT_SYMBOL name,val,sec >> #ifdef CONFIG_MODULES >> .globl __ksymtab_\name >> @@ -37,7 +39,7 @@ >> __ksymtab_\name: >> __put \val, __kstrtab_\name >> .previous >> - .section __ksymtab_strings,"a" >> + .section __ksymtab_strings,"aMS",%progbits,1 >> __kstrtab_\name: >> .asciz "\name" >> .previous >> diff --git a/include/linux/export.h b/include/linux/export.h >> index 201262793369..18dcdcd118e7 100644 >> --- a/include/linux/export.h >> +++ b/include/linux/export.h >> @@ -81,16 +81,29 @@ struct kernel_symbol { >> >> #else >> >> -/* For every exported symbol, place a struct in the __ksymtab section */ >> +/* >> + * For every exported symbol, do the following: > >Just a nit. > >You mention "an entry" twice >to talk about different classes of structures. > >It might be better to be explicit about "which entry". > > >> + * >> + * - If applicable, place an entry in the __kcrctab section. > > "place a CRC entry in the __kcrctab section" >might be clearer ? > > >> + * - Put the name of the symbol and namespace (empty string "" for none) in >> + * __ksymtab_strings. >> + * - Place an entry in the __ksymtab section. > > "Place a struct kernel_symbol entry in __ksymtab section" ? >might be clearer ? > > >Other than that: >Reviewed-by: Masahiro Yamada Yeah, that is much clearer, will resend. Thanks! Jessica