diff options
| author | Michael Brown | 2009-05-26 12:05:58 +0200 |
|---|---|---|
| committer | Michael Brown | 2009-05-26 12:05:58 +0200 |
| commit | 3c06277bbb6ea135e6a1daf22463a347fc7898c7 (patch) | |
| tree | 48469dfe123ab00d0e417535ac7ae7879e84ff24 /src/net | |
| parent | [multiboot] Include argv[0] as part of "command line" (diff) | |
| download | ipxe-3c06277bbb6ea135e6a1daf22463a347fc7898c7.tar.gz ipxe-3c06277bbb6ea135e6a1daf22463a347fc7898c7.tar.xz ipxe-3c06277bbb6ea135e6a1daf22463a347fc7898c7.zip | |
[settings] Allow for arbitrarily-named settings
This provides a mechanism for using arbitrarily-named variables within
gPXE, using the existing syntax for settings.
Diffstat (limited to 'src/net')
| -rw-r--r-- | src/net/netdev_settings.c | 18 | ||||
| -rw-r--r-- | src/net/netdevice.c | 5 |
2 files changed, 16 insertions, 7 deletions
diff --git a/src/net/netdev_settings.c b/src/net/netdev_settings.c index 54ce2fbce..b9220f5ea 100644 --- a/src/net/netdev_settings.c +++ b/src/net/netdev_settings.c @@ -56,9 +56,9 @@ static int netdev_store ( struct settings *settings, struct setting *setting, return -EINVAL; memcpy ( netdev->ll_addr, data, len ); return 0; - } else { - return simple_settings_store ( settings, setting, data, len ); } + + return generic_settings_store ( settings, setting, data, len ); } /** @@ -80,13 +80,23 @@ static int netdev_fetch ( struct settings *settings, struct setting *setting, len = netdev->ll_protocol->ll_addr_len; memcpy ( data, netdev->ll_addr, len ); return netdev->ll_protocol->ll_addr_len; - } else { - return simple_settings_fetch ( settings, setting, data, len ); } + + return generic_settings_fetch ( settings, setting, data, len ); +} + +/** + * Clear network device settings + * + * @v settings Settings block + */ +static void netdev_clear ( struct settings *settings ) { + generic_settings_clear ( settings ); } /** Network device configuration settings operations */ struct settings_operations netdev_settings_operations = { .store = netdev_store, .fetch = netdev_fetch, + .clear = netdev_clear, }; diff --git a/src/net/netdevice.c b/src/net/netdevice.c index 1a68af2c4..77edbcd37 100644 --- a/src/net/netdevice.c +++ b/src/net/netdevice.c @@ -282,6 +282,7 @@ static void free_netdev ( struct refcnt *refcnt ) { netdev_tx_flush ( netdev ); netdev_rx_flush ( netdev ); + clear_settings ( netdev_settings ( netdev ) ); free ( netdev ); } @@ -303,9 +304,7 @@ struct net_device * alloc_netdev ( size_t priv_size ) { netdev->refcnt.free = free_netdev; INIT_LIST_HEAD ( &netdev->tx_queue ); INIT_LIST_HEAD ( &netdev->rx_queue ); - settings_init ( netdev_settings ( netdev ), - &netdev_settings_operations, &netdev->refcnt, - netdev->name, 0 ); + netdev_settings_init ( netdev ); netdev->priv = ( ( ( void * ) netdev ) + sizeof ( *netdev ) ); } return netdev; |
