[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <29168.1379504300@warthog.procyon.org.uk>
Date: Wed, 18 Sep 2013 12:38:20 +0100
From: David Howells <dhowells@...hat.com>
To: Daniel Santos <daniel.santos@...ox.com>
Cc: dhowells@...hat.com, linux-kbuild <linux-kbuild@...r.kernel.org>,
LKML <linux-kernel@...r.kernel.org>,
Michal Marek <mmarek@...e.cz>,
Andrew Morton <akpm@...ux-foundation.org>,
"Paul E. McKenney" <paulmck@...ux.vnet.ibm.com>,
Thomas Gleixner <tglx@...utronix.de>,
Michael Kerrisk <mtk.manpages@...il.com>,
Dave Hansen <dave.hansen@...ux.intel.com>,
George Spelvin <linux@...izon.com>
Subject: Re: [PATCH 1/5] scripts: Add mkstrerror.sh
danielfsantos@....net wrote:
> This is a simple bash script that parses our errno*.h files and formats
> them into the error_strings.h header that our strerror and strerror_name
> functions will use later.
I presume you haven't tried building with a "make O=foo" build directory? I
see:
/bin/sh: /data/fs/linux-2.6-fscache/include/generated/error_strings.h: No such file or directory
when I try it.
Looking in your generated error_strings.h file, I see:
static const struct error_strings {
const unsigned first;
const unsigned last;
const unsigned count;
const char * const desc[2];
} error_strings[2] = {
{
.first = 0,
.last = 133,
.count = 134,
.desc = {
#ifdef CONFIG_STRERROR_NAME
"\0" /* 0 */
"EPERM\0" /* 1 */
"ENOENT\0" /* 2 */
"ESRCH\0" /* 3 */
"EINTR\0" /* 4 */
...
"ERFKILL\0" /* 132 */
"EHWPOISON\0" /* 133 */,
#else
NULL,
#endif /* CONFIG_STRERROR_NAME */
#ifdef CONFIG_STRERROR
"\0" /* 0 */
"Operation not permitted\0" /* 1 */
"No such file or directory\0" /* 2 */
"No such process\0" /* 3 */
...
"State not recoverable\0" /* 131 */
"Operation not possible due to RF-kill\0" /* 132 */
"Memory page has hardware error\0" /* 133 */,
#else
NULL,
#endif /* CONFIG_STRERROR */
},
}, {
.first = 512,
.last = 529,
.count = 18,
.desc = {
#ifdef CONFIG_STRERROR_NAME
"ERESTARTSYS\0" /* 512 */
"ERESTARTNOINTR\0" /* 513 */
...
"Request initiated, but will not complete before timeout\0"/* 528 */
"iocb queued, will get completion event\0" /* 529 */,
#else
NULL,
#endif /* CONFIG_STRERROR */
},
}
};
Some thoughts for you:
(1) Why are you double-NUL'ing all your strings? (see the \0 in the strings)
(2) Storing the leading 'E' for each symbol is redundant as you can add that
later so you might want to discard it.
(3) You are storing a pointer to the symbolic name for each error. On a
64-bit machine, that's 8 bytes. If you drop the leading 'E' and the
trailing NUL, most symbols will fit into an 8 character slot saving you
the cost of a pointer.
Okay, you'll have to truncate some of the names (ERESTARTNOINTR ->
RESNOINT for example) but probably not that many. Run this:
grep '["]E[A-Z0-9]' include/generated/error_strings.h |
cut '-d\' -f1 | cut -dE -f2- | cut -c1-8
and you'll see what I mean. Most of them are still recognisable,
particularly once you stick the 'E' back on the front. Piping the output
of that through "wc -l", I get:
147
which means the entire string table could be squeezed into 8 * 147 or
1176 bytes with only one pointer and one count required for each segment
of the table (you generate two segments).
David
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists