[<prev] [next>] [day] [month] [year] [list]
Message-ID: <Y/4fDlbIhTLNLFHz@p183>
Date: Tue, 28 Feb 2023 18:34:38 +0300
From: Alexey Dobriyan <adobriyan@...il.com>
To: akpm@...ux-foundation.org
Cc: linux-kernel@...r.kernel.org
Subject: [PATCH] mm: uninline kstrdup()
gcc inlines kstrdup into kstrdup_const() but it can very efficiently
tail call into it instead:
$ ./scripts/bloat-o-meter ../vmlinux-000 ../obj/vmlinux
add/remove: 0/0 grow/shrink: 0/1 up/down: 0/-84 (-84)
Function old new delta
kstrdup_const 119 35 -84
Signed-off-by: Alexey Dobriyan <adobriyan@...il.com>
---
mm/util.c | 1 +
1 file changed, 1 insertion(+)
--- a/mm/util.c
+++ b/mm/util.c
@@ -49,6 +49,7 @@ EXPORT_SYMBOL(kfree_const);
*
* Return: newly allocated copy of @s or %NULL in case of error
*/
+noinline
char *kstrdup(const char *s, gfp_t gfp)
{
size_t len;
Powered by blists - more mailing lists