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/net/arp.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/net/arp.c')
-rw-r--r-- | src/net/arp.c | 9 |
1 files changed, 1 insertions, 8 deletions
diff --git a/src/net/arp.c b/src/net/arp.c index ba9ebf48..cf2fe988 100644 --- a/src/net/arp.c +++ b/src/net/arp.c @@ -36,12 +36,6 @@ * */ -/** Registered ARP protocols */ -static struct arp_net_protocol arp_net_protocols[0] - __table_start ( struct arp_net_protocol, arp_net_protocols ); -static struct arp_net_protocol arp_net_protocols_end[0] - __table_end ( struct arp_net_protocol, arp_net_protocols ); - /** An ARP cache entry */ struct arp_entry { /** Network-layer protocol */ @@ -176,8 +170,7 @@ int arp_resolve ( struct net_device *netdev, struct net_protocol *net_protocol, static struct arp_net_protocol * arp_find_protocol ( uint16_t net_proto ) { struct arp_net_protocol *arp_net_protocol; - for ( arp_net_protocol = arp_net_protocols ; - arp_net_protocol < arp_net_protocols_end ; arp_net_protocol++ ) { + for_each_table_entry ( arp_net_protocol, ARP_NET_PROTOCOLS ) { if ( arp_net_protocol->net_protocol->net_proto == net_proto ) { return arp_net_protocol; } |