Fedora Test Days | |
---|---|
Network Device Naming With Biosdevname | |
Date | Thursday, January 27, 2011 |
Time | all day |
Website | QA/Fedora_15_test_days |
IRC | #fedora-test-day (webirc) |
Mailing list | test |
What to test?
Today's installment of Fedora Test Day will focus on Network Interface Naming.
Traditionally network interfaces in Linux are named ethN. With multiple network adapters, both onboard and add-in, single and multiport, in modern server platforms, the naming of these interfaces is non-deterministic. Specifically, eth0 does not always map to Gb1 or Embedded NIC 1 as named on the server chassis. This makes the existing naming not very user friendly for administration.
This issue is addressed by assigning names to network interfaces based on their physical location on the system board. Biosdevname, which is a Dell developed utility, can suggest names to network interfaces, which are physical location based.
The naming convention followed is:
- Embedded devices:
em<port>
Image - Add-in PCI cards:
pci<slot>#<port>_<virtual-function-instance>
Image
Please find an example ifconfig
output from this naming convention here
Please refer to the following link for more details on the issue itself and various solutions we proposed upstream to address this issue which were unsuccessful.
Who's available
The following cast of characters will be available testing, workarounds, bug fixes, and general discussion ...
- Narendra K (nick: narendrak) -- 3:30 - 18:30 UTC
- Matt Domsch (nick: mdomsch) -- 18:00 - 23:00 UTC
- James Laska (nick: jlaska) -- 13:00 - 22:00 UTC
- Shyam Iyer (nick: shyam_iyer) -- 02:00 - 4:00 and 15:00 - 21:00 UTC
Prerequisite for Test Day
Hardware Requirements
A script is available to determine whether your system will be impacted by the biosdevname
change. The following example shows how to run the script to determine whether your hardware can be used during the Test Day.(Ensure that you have dmidecode package installed before running the script)
# su -c 'curl -s https://fedoraproject.org/w/uploads/3/38/Biosdevname-support-check.sh | bash' Password: Checking hardware requirements [ OK ] Checking for SMBIOS type 41 support [ OK ] Checking for SMBIOS type 9 support [ OK ] Checking for PCI Interrupt Routing support [ OK ]
If the output of the script is [ OK ]
and any of the following checks is [ OK ]
, your hardware is supported by biosdevname and you can take part in the Test Day.
For reference, the hardware requirements are:
- A system (servers, laptop, or desktop) with one or more onboard network adapter(s) and/or one or more add-in network adapter(s)
- System firmware/BIOS should implement an SMBIOS type 41 or type 9 record, or PCI Interrupt Routing
- Requirements for Testing a SR-IOV capable network adapter
- SR-IOV support (enabled in BIOS if BIOS provides the option)
- Single and multiport add-in network adapters with SRIOV capability
For more information on SR-IOV Please see here
It is strongly advised that you upload your hardware profile uploaded to Smolt according to these instructions
Software Requirements
- Fedora Rawhide
- Optional - the SMBIOS type 41 device type instance and string should be available in sysfs. This will be available in sysfs only when BIOS implements type 41. If type 41 is not implemented, then
$PIRQ
will be the fallback and this attribute will not be available in sysfs. This attribute is available on kernels with version >= 2.6.36 (includes Rawhide)
How to test?
At a high level, the testing will focus on
- Network interface names during install time
- Network interface names after installation is completed (after you login for first time)
- Required changes available in
ifcfg-ethN
config files - Upgrading from a previous release (Fedora 14) to Fedora Rawhide does not affect the naming scheme that existed in the previous release
Install or upgrade to Rawhide
There are several ways to set up your test system.
Upgrading From Fedora 14 to Rawhide
- You can upgrade an already installed Fedora 14 system using
yum
- for guidance, see yum update from previous release
Install Rawhide
- You can install Rawhide with Fedora 14 ISO media - for guidance, see Install Rawhide using Fedora 14 ISO
- Or you can use a special Rawhide install image provided for this test day - i386 or x86_64
boot.iso
. For guidance, see the installation guide
Boot into a Rawhide live image
- You can download and boot a Fedora Rawhide live image - for guidance, see How_to_create_and_use_Live_USB
Complete the Test Cases
Upgrade Testing - These test cases should be executed when upgrading a Fedora 14 system to Rawhide. Please refer to the section Upgrading From Fedora 14 to Rawhide above.
- QA:Testcase biosdevname NIC rules persist after upgrade - Verify upgrade from Fedora 14 to Rawhide
- To have your system make use of the "new" names after upgrade, run the following and reboot:
#!/bin/bash yum --enablerepo=rawhide install biosdevname for f in /etc/sysconfig/network-scripts/ifcfg-eth*; do oldifname=$(basename $f | sed -e 's/ifcfg-//') newifname=$(/sbin/biosdevname -i $oldifname) [ ! $? ] && continue unset HWADDR . $f [ -n "${HWADDR}" ] && sed -i -e "/ATTR{address}==\"${HWADDR}\"/d" /etc/udev/rules.d/70-persistent-net.rules sed -i -e "s/^DEVICE=.*/DEVICE=$newifname/" -e "/^HWADDR=/d" $f mv $f /etc/sysconfig/network-scripts/ifcfg-$newifname done
After reboot, your system should now be using the new names.
Install Time Testing - The test cases in this category should be executed when performing a new Rawhide installation. Please refer to the section Install Rawhide above.
- QA:Testcase biosdevname NIC naming after install - Verify that onboard and add-in interfaces are named as expected during install time
- QA:Testcase biosdevname Automated Kickstart Installation - Unattended/automated kickstart installation using ksdevice=emN option
Run Time Testing - The test cases in this category should be executed when running a fresh Rawhide - either from the live image, or after performing a new Rawhide installation.
- QA:Testcase biosdevname on-board network interface names - Verify that onboard interfaces are named as
emN
- QA:Testcase biosdevname add-in network interface names - Verify that PCI add-in interfaces are named as
pci<slot>#<port>
- QA:Testcase biosdevname SRIOV virtual function interface names - Verify that Virtual Function interfaces are named as
pci<slot>#<port>_<virtual-function-instance>
- QA:Testcase biosdevname interface configuration - Verify that onboard, add-in, and add-in Virtual Function interfaces can be configured
Report your results
If you have problems with any of the tests, report a bug to Bugzilla usually for the component biosdevname. If you are unsure about exactly how to file the report or what other information to include, just ask on IRC and we will help you. Once you have completed the tests, add your results to the Results table below, following the example results from the first line as a template. The first column should be your name with a link to your User page in the Wiki if you have one, and the second should be a link to the Smolt profile of the system you tested. For each test case, if your system worked correctly, simply enter the word PASS. If you had trouble, enter the word FAIL, with a footnote indicator, and put a link to the bug report in the References column (as in the example line). For tests you could not perform, enter a dash.
Useful information to include in your bugzilla report include output from:
sudo /sbin/biosdevname -d sudo /usr/sbin/dmidecode sudo /usr/sbin/dump_pirq lspci -tv
User | Smolt Profile | install | upgrade | kickstart | on-board | add-in | SRIOV | iface configuration | References |
---|---|---|---|---|---|---|---|---|---|
Sample User | HW | ||||||||
shyam_iyer | HW (This is a Dell PER 710 with 4 onboard Nics) [1] | ||||||||
shyam_iyer | HW (This is a Dell SC 1435 with 2 onboard Nics) [1] | ||||||||
David Ramsey | Add Smolt Profile HW URL |