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:
Carl-Daniel Hailfinger 2008-08-17 21:51:13 +00:00
commit 9342d1be4e
9 changed files with 65 additions and 71 deletions

View file

@ -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, ...);