The ABI wrapper from r775 made the SHARED definitions obsolete. They're
not that readable anyway, so kill them and use standard definitions instead. Introduce EXPORT_SYMBOL for shared symbols. EXPORT_SYMBOL tells the compiler to use the standard calling conventions for a given symbol and not to optimize it away. Benefits: - We can later use gcc -combine -fwhole-program without problems. - It's a correctness fix for some optimizations. - We could check for duplicated exported functions at link time. - We could check whether exported functions are linked into initram or stage2 by accident. - We could generate usage statistics and possibly optimize away unused shared functions. - Through the above points, significant side reductions of 10-40% Build and boot tested on qemu. Build tested on all targets. Signed-off-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net> Acked-by: Ronald G. Minnich <rminnich@gmail.com> git-svn-id: svn://coreboot.org/repository/coreboot-v3@780 f3766cd6-281f-0410-b1cd-43a5c92072e9
This commit is contained in:
parent
4c19fcbd44
commit
9342d1be4e
9 changed files with 65 additions and 71 deletions
|
|
@ -31,10 +31,14 @@ int strcmp(const char *s1, const char *s2);
|
|||
int strncmp(const char *s1, const char *s2, int maxlen);
|
||||
|
||||
/* lib/mem.c */
|
||||
SHARED(memcpy, void *, void *dest, const void *src, size_t len);
|
||||
SHARED(memmove, void *, void *dest, const void *src, size_t len);
|
||||
SHARED(memset, void *, void *s, int c, size_t len);
|
||||
SHARED(memcmp, int , const void *s1, const void *s2, size_t len);
|
||||
void * memcpy(void *dest, const void *src, size_t len);
|
||||
EXPORT_SYMBOL(memcpy);
|
||||
void * memmove(void *dest, const void *src, size_t len);
|
||||
EXPORT_SYMBOL(memmove);
|
||||
void * memset(void *s, int c, size_t len);
|
||||
EXPORT_SYMBOL(memset);
|
||||
int memcmp(const void *s1, const void *s2, size_t len);
|
||||
EXPORT_SYMBOL(memcmp);
|
||||
|
||||
/* console/vsprintf.c */
|
||||
int sprintf(char *buf, const char *fmt, ...);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue