* [uml-devel] [patch] module symbol fix
@ 2004-02-26 21:26 Gerd Knorr
2004-02-27 9:26 ` [uml-devel] " Gerd Knorr
0 siblings, 1 reply; 3+ messages in thread
From: Gerd Knorr @ 2004-02-26 21:26 UTC (permalink / raw)
To: Jeff Dike; +Cc: uml devel
Hi,
recent gcc versions need this one ...
Gerd
--- linux-um-2.6.3/arch/um/kernel/user_syms.c.uml 2004-02-26 21:20:51.202244050 +0100
+++ linux-um-2.6.3/arch/um/kernel/user_syms.c 2004-02-26 21:21:06.599701859 +0100
@@ -57,6 +57,7 @@
__attribute__((section("__ksymtab_strings"))) \
= MODULE_SYMBOL_PREFIX #sym; \
static const struct kernel_symbol __ksymtab_##sym \
+ __attribute_used__ \
__attribute__((section("__ksymtab" sec), unused)) \
= { (unsigned long)&sym, __kstrtab_##sym }
-------------------------------------------------------
SF.Net is sponsored by: Speed Start Your Linux Apps Now.
Build and deploy apps & Web services for Linux with
a free DVD software kit from IBM. Click Now!
http://ads.osdn.com/?ad_id=1356&alloc_id=3438&op=click
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 3+ messages in thread
* [uml-devel] Re: [patch] module symbol fix
2004-02-26 21:26 [uml-devel] [patch] module symbol fix Gerd Knorr
@ 2004-02-27 9:26 ` Gerd Knorr
2004-02-28 16:32 ` BlaisorBlade
0 siblings, 1 reply; 3+ messages in thread
From: Gerd Knorr @ 2004-02-27 9:26 UTC (permalink / raw)
To: Jeff Dike; +Cc: uml devel
On Thu, Feb 26, 2004 at 10:26:55PM +0100, Gerd Knorr wrote:
> Hi,
>
> recent gcc versions need this one ...
Another one of this kind (without this gcc may optimizes away the static
declared but unreferenced stuff, resulting in initrd= and --help options
not working any more for example ...).
Gerd
--- linux-um-2.6.3/arch/um/include/init.h.used 2004-02-27 09:34:57.874205081 +0100
+++ linux-um-2.6.3/arch/um/include/init.h 2004-02-27 09:44:32.415275725 +0100
@@ -40,9 +40,9 @@
typedef int (*initcall_t)(void);
typedef void (*exitcall_t)(void);
-#define __init __attribute__ ((__section__ (".text.init")))
+#define __init __attribute__ ((used,__section__ (".text.init")))
#define __exit __attribute__ ((unused, __section__(".text.exit")))
-#define __initdata __attribute__ ((__section__ (".data.init")))
+#define __initdata __attribute__ ((used,__section__ (".data.init")))
#endif
@@ -94,11 +94,11 @@
* Mark functions and data as being only used at initialization
* or exit time.
*/
-#define __uml_init_setup __attribute__ ((unused,__section__ (".uml.setup.init")))
-#define __uml_setup_help __attribute__ ((unused,__section__ (".uml.help.init")))
-#define __uml_init_call __attribute__ ((unused,__section__ (".uml.initcall.init")))
-#define __uml_postsetup_call __attribute__ ((unused,__section__ (".uml.postsetup.init")))
-#define __uml_exit_call __attribute__ ((unused,__section__ (".uml.exitcall.exit")))
+#define __uml_init_setup __attribute__ ((used,__section__ (".uml.setup.init")))
+#define __uml_setup_help __attribute__ ((used,__section__ (".uml.help.init")))
+#define __uml_init_call __attribute__ ((used,__section__ (".uml.initcall.init")))
+#define __uml_postsetup_call __attribute__ ((used,__section__ (".uml.postsetup.init")))
+#define __uml_exit_call __attribute__ ((used,__section__ (".uml.exitcall.exit")))
#endif /* _LINUX_UML_INIT_H */
-------------------------------------------------------
SF.Net is sponsored by: Speed Start Your Linux Apps Now.
Build and deploy apps & Web services for Linux with
a free DVD software kit from IBM. Click Now!
http://ads.osdn.com/?ad_id=1356&alloc_id=3438&op=click
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [uml-devel] Re: [patch] module symbol fix
2004-02-27 9:26 ` [uml-devel] " Gerd Knorr
@ 2004-02-28 16:32 ` BlaisorBlade
0 siblings, 0 replies; 3+ messages in thread
From: BlaisorBlade @ 2004-02-28 16:32 UTC (permalink / raw)
To: user-mode-linux-devel
Alle 10:26, venerdì 27 febbraio 2004, Gerd Knorr ha scritto:
> On Thu, Feb 26, 2004 at 10:26:55PM +0100, Gerd Knorr wrote:
> > Hi,
> >
> > recent gcc versions need this one ...
>
> Another one of this kind (without this gcc may optimizes away the static
> declared but unreferenced stuff, resulting in initrd= and --help options
> not working any more for example ...).
Yes, but it needs to be made work with older gcc, even 2.95.3 but also 3.2 -
and this means using __attribute__(__unused__) if needed - i.e. using
__attribute__used as in the first patch (using more than one attribute works,
as in include/linux/init.h).
The problem is that init.h is included even in userspace modules so it cannot
include kernel headers - also, it seems that user_syms.c does not include
<linux/compiler.h> and so __attribute_used cannot be expanded simply. If it
works on you, check if the define comes from /usr/include/linux/compiler.h.
Duplicating the version check from include/linux/compiler* will be needed to
avoid the problems you pointed out and possibly others, but not being able to
include linux/* in user-objs is increasingly sucking. Sadly there are reasons
for this and they are good (I discovered this while trying to remove this
limitation):
- user space headers include /usr/include/linux/*, so if you add -I<source
tree root>/include, those headers will include _other_ linux headers and
things will not work - especially, they will include <source tree
root>/include/asm-um/* instead of /usr/include/asm/*.
- definitions depending on CONFIG_* would be messed up; in fact, uml-config.h
is a translation of config.h which defines UML_CONFIG_* instead of CONFIG_*,
because CONFIG_* macros are defined by /usr/include/linux/autoconf.h. So if
an "user-objs" file includes linux/mm.h, that header could even think that
CONFIG_HIGHMEM is defined because the distro said so!
--
Paolo Giarrusso, aka Blaisorblade
Linux registered user n. 292729
-------------------------------------------------------
SF.Net is sponsored by: Speed Start Your Linux Apps Now.
Build and deploy apps & Web services for Linux with
a free DVD software kit from IBM. Click Now!
http://ads.osdn.com/?ad_id\x1356&alloc_id438&opÌk
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2004-02-28 19:59 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-02-26 21:26 [uml-devel] [patch] module symbol fix Gerd Knorr
2004-02-27 9:26 ` [uml-devel] " Gerd Knorr
2004-02-28 16:32 ` BlaisorBlade
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.