mirror of
https://github.com/ipxe/ipxe
synced 2025-12-27 10:02:42 +03:00
[netdevice] Separate concept of scope ID from network device name index
The network device index currently serves two purposes: acting as a
sequential index for network device names ("net0", "net1", etc), and
acting as an opaque unique integer identifier used in socket address
scope IDs.
There is no particular need for these usages to be linked, and it can
lead to situations in which devices are named unexpectedly. For
example: if a system has two network devices "net0" and "net1", a VLAN
is created as "net1-42", and then a USB NIC is connected, then the USB
NIC will be named "net3" rather than the expected "net2" since the
VLAN device "net1-42" will have consumed an index.
Separate the usages: rename the "index" field to "scope_id" (matching
its one and only use case), and assign the name without reference to
the scope ID by finding the first unused name. For consistency,
assign the scope ID by similarly finding the first unused scope ID.
Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
@@ -199,7 +199,7 @@ static void efi_pxe_ip_sockaddr ( struct efi_pxe *pxe, EFI_IP_ADDRESS *ip,
|
||||
memset ( sockaddr, 0, sizeof ( *sockaddr ) );
|
||||
sockaddr->sa.sa_family = pxe->tcpip->sa_family;
|
||||
memcpy ( &sockaddr->se.se_addr, ip, pxe->net->net_addr_len );
|
||||
sockaddr->se.se_scope_id = pxe->netdev->index;
|
||||
sockaddr->se.se_scope_id = pxe->netdev->scope_id;
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -934,11 +934,11 @@ static uint8_t efi_undi_checksum ( void *data, size_t len ) {
|
||||
*/
|
||||
static unsigned int efi_undi_ifnum ( struct efi_snp_device *snpdev ) {
|
||||
|
||||
/* iPXE network device indexes are one-based (leaving zero
|
||||
/* iPXE network device scope IDs are one-based (leaving zero
|
||||
* meaning "unspecified"). UNDI interface numbers are
|
||||
* zero-based.
|
||||
*/
|
||||
return ( snpdev->netdev->index - 1 );
|
||||
return ( snpdev->netdev->scope_id - 1 );
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user