[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4A665442.1010006@caviumnetworks.com>
Date:	Tue, 21 Jul 2009 16:50:26 -0700
From:	David Daney <ddaney@...iumnetworks.com>
To:	Joe Perches <joe@...ches.com>
CC:	Matt Mackall <mpm@...enic.com>, linux-embedded@...r.kernel.org,
	linux-kernel@...r.kernel.org,
	Paul Gortmaker <paul.gortmaker@...driver.com>,
	David Woodhouse <dwmw2@...radead.org>,
	Tim Bird <tim.bird@...sony.com>
Subject: Re: [RFC] move __devinit or __init printk constant format strings
 to __devinitconst or __initdata?
Joe Perches wrote:
> On Tue, 2009-07-21 at 17:57 -0500, Matt Mackall wrote:
>> On Tue, 2009-07-21 at 14:56 -0700, Joe Perches wrote:
>>> On Tue, 2009-07-21 at 16:48 -0500, Matt Mackall wrote:
>>>> On Tue, 2009-07-21 at 14:20 -0700, Joe Perches wrote:
>>>>> Is moving constant string formats to __devinitconst or __initdata
>>>>> useful for embedded environments?
>>>> Interesting notion, but not worth the trouble in my mind. I think it's
>>>> more worthwhile to look into automatic such stuff in the build somehow.
>>> I think it's not possible today to get gcc to mark
>>> the format strings without source modification.
>> Yep, that's why I specifically said 'build'. It can probably be done in
>> a post-processing step with some ELF wizardry. 
> 
> Know any elven wizards?
> 
It would be tricky, the string data from the entire compilation unit is 
intermingled.  You would have to separate out only those strings 
referenced from __init sections into their own section and fix up all 
symbols and relocations that were affected.
Probably easier would be to use the plug-in feature that will be part of 
GCC-4.5 (or will that be called GCC-5.0??), and create a special Linux 
kernel GCC plug-in that just emits the __init literal strings to the 
proper section to begin with.  This wouldn't be unprecedented, the 
Mozilla people already use their own extensions to GCC, and will 
probably migrate to GCC plug-ins.  We don't want the kernel to get left 
behind in the GCC plug-in race.
David Daney
--
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
 
