diff options
author | Michael Brown | 2009-03-12 20:41:40 +0100 |
---|---|---|
committer | Michael Brown | 2009-03-13 03:06:30 +0100 |
commit | 1266d7902bf7f2534ee279671d48613ef9b2434c (patch) | |
tree | a1a5b188148d983fa962a887476259768f1751d4 /src/core/gdbstub.c | |
parent | [tcp] Avoid setting PSH flag when SYN flag is set (diff) | |
download | ipxe-1266d7902bf7f2534ee279671d48613ef9b2434c.tar.gz ipxe-1266d7902bf7f2534ee279671d48613ef9b2434c.tar.xz ipxe-1266d7902bf7f2534ee279671d48613ef9b2434c.zip |
[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/gdbstub.c')
-rw-r--r-- | src/core/gdbstub.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/src/core/gdbstub.c b/src/core/gdbstub.c index bbed344f..45df7f2b 100644 --- a/src/core/gdbstub.c +++ b/src/core/gdbstub.c @@ -54,10 +54,6 @@ struct gdbstub { int len; /* length of payload */ }; -/* Transports */ -static struct gdb_transport gdb_transport_start[0] __table_start ( struct gdb_transport, gdb_transports ); -static struct gdb_transport gdb_transport_end[0] __table_end ( struct gdb_transport, gdb_transports ); - /* Packet parser states */ static void gdbstub_state_new ( struct gdbstub *stub, char ch ); static void gdbstub_state_data ( struct gdbstub *stub, char ch ); @@ -387,7 +383,8 @@ void gdbstub_handler ( int signo, gdbreg_t *regs ) { struct gdb_transport *find_gdb_transport ( const char *name ) { struct gdb_transport *trans; - for ( trans = gdb_transport_start; trans < gdb_transport_end; trans++ ) { + + for_each_table_entry ( trans, GDB_TRANSPORTS ) { if ( strcmp ( trans->name, name ) == 0 ) { return trans; } |