This patch is what I needed to compile coreboot with LLVM.
- call va_* directly if coreboot is running on GCC so we don't need to maintain hacks to get to stdarg.h - only define LIBGCC_FILE_NAME if it's an absolute path. GCC and LLVM just print "libgcc.a" if the file is not there. Signed-off-by: Stefan Reinauer <stepan@coresystems.de> Acked-by: Ronald G. Minnich <rminnich@gmail.com> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@5215 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
committed by
Stefan Reinauer
parent
c6b0e7e2d9
commit
68a564f7ac
@ -20,7 +20,19 @@
|
||||
#ifndef __CONSOLE_VTXPRINTF_H
|
||||
#define __CONSOLE_VTXPRINTF_H
|
||||
|
||||
/* With GCC we use -nostdinc -ffreestanding to keep out system includes.
|
||||
* Unfortunately this also gets us rid of the _compiler_ includes, like
|
||||
* stdarg.h. To work around the issue, we define varargs directly here.
|
||||
* On LLVM we can still just include stdarg.h.
|
||||
*/
|
||||
#ifdef __GNUC__
|
||||
#define va_start(v,l) __builtin_va_start(v,l)
|
||||
#define va_end(v) __builtin_va_end(v)
|
||||
#define va_arg(v,l) __builtin_va_arg(v,l)
|
||||
typedef __builtin_va_list va_list;
|
||||
#else
|
||||
#include <stdarg.h>
|
||||
#endif
|
||||
|
||||
int vtxprintf(void (*tx_byte)(unsigned char byte), const char *fmt, va_list args);
|
||||
|
||||
|
Reference in New Issue
Block a user