diff options
author | Michael Brown <mcb30@etherboot.org> | 2009-03-12 19:41:40 +0000 |
---|---|---|
committer | Michael Brown <mcb30@etherboot.org> | 2009-03-13 02:06:30 +0000 |
commit | 1266d7902bf7f2534ee279671d48613ef9b2434c (patch) | |
tree | a1a5b188148d983fa962a887476259768f1751d4 /src/core/console.c | |
parent | 3ed468e0c58bb0eb94925c18a0461cd5014b5777 (diff) | |
download | ipxe-1266d7902bf7f2534ee279671d48613ef9b2434c.tar.gz |
[tables] Redefine methods for accessing linker tables
Intel's C compiler (icc) chokes on the zero-length arrays that we
currently use as part of the mechanism for accessing linker table
entries. Abstract away the zero-length arrays, to make a port to icc
easier.
Introduce macros such as for_each_table_entry() to simplify the common
case of iterating over all entries in a linker table.
Represent table names as #defined string constants rather than
unquoted literals; this avoids visual confusion between table names
and C variable or type names, and also allows us to force a
compilation error in the event of incorrect table names.
Diffstat (limited to 'src/core/console.c')
-rw-r--r-- | src/core/console.c | 11 |
1 files changed, 2 insertions, 9 deletions
diff --git a/src/core/console.c b/src/core/console.c index c9773f713..1ea3dc13e 100644 --- a/src/core/console.c +++ b/src/core/console.c @@ -5,11 +5,6 @@ /** @file */ -static struct console_driver console_drivers[0] - __table_start ( struct console_driver, console ); -static struct console_driver console_drivers_end[0] - __table_end ( struct console_driver, console ); - /** * Write a single character to each console device. * @@ -28,8 +23,7 @@ void putchar ( int character ) { if ( character == '\n' ) putchar ( '\r' ); - for ( console = console_drivers; console < console_drivers_end ; - console++ ) { + for_each_table_entry ( console, CONSOLES ) { if ( ( ! console->disabled ) && console->putchar ) console->putchar ( character ); } @@ -51,8 +45,7 @@ void putchar ( int character ) { static struct console_driver * has_input ( void ) { struct console_driver *console; - for ( console = console_drivers; console < console_drivers_end ; - console++ ) { + for_each_table_entry ( console, CONSOLES ) { if ( ( ! console->disabled ) && console->iskey ) { if ( console->iskey () ) return console; |