mirror of
https://github.com/ipxe/ipxe
synced 2025-12-26 01:22:37 +03:00
[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.
This commit is contained in:
@@ -48,11 +48,6 @@ static isa_probe_addr_t isa_extra_probe_addrs[] = {
|
||||
isa_extra_probe_addrs[ (ioidx) + ISA_EXTRA_PROBE_ADDR_COUNT ] : \
|
||||
(driver)->probe_addrs[(ioidx)] )
|
||||
|
||||
static struct isa_driver isa_drivers[0]
|
||||
__table_start ( struct isa_driver, isa_drivers );
|
||||
static struct isa_driver isa_drivers_end[0]
|
||||
__table_end ( struct isa_driver, isa_drivers );
|
||||
|
||||
static void isabus_remove ( struct root_device *rootdev );
|
||||
|
||||
/**
|
||||
@@ -100,7 +95,7 @@ static int isabus_probe ( struct root_device *rootdev ) {
|
||||
int ioidx;
|
||||
int rc;
|
||||
|
||||
for ( driver = isa_drivers ; driver < isa_drivers_end ; driver++ ) {
|
||||
for_each_table_entry ( driver, ISA_DRIVERS ) {
|
||||
for ( ioidx = ISA_IOIDX_MIN ( driver ) ;
|
||||
ioidx <= ISA_IOIDX_MAX ( driver ) ; ioidx++ ) {
|
||||
/* Allocate struct isa_device */
|
||||
|
||||
Reference in New Issue
Block a user