Unify all Intel gigabit drivers into a single iflib implementation.
Details
- Reviewers
franco_opnsense.org sbruno - Group Reviewers
Intel Networking - Commits
- rS311849: Migrate e1000 to the IFLIB framework:
Diff Detail
- Repository
- rS FreeBSD src repository - subversion
- Lint
Lint Passed - Unit
No Test Coverage - Build Status
Buildable 5664 Build 5948: CI src build Jenkins Build 5947: arc lint + arc unit
Event Timeline
I have not done anything more than *compile* tested this.
It is missing legacy mode and should not be committed as-is.
Make a if_igb.ko (legacy) and an if_igb_iflib.ko so that we have
the ability to test this stuff out before going live.
I need to actually test this somewhere, but it compiles a legacy and iflib module now.
Updating to capture all the things.
This unifies lem, em and igb into one 'em' device, enables multiple
queues in em(4) when supported.
Purge legacy driver support from 12-current version. We'll do the
legacy/iflib dance for the MFC to 11-stable.
Due to POLA issues, Matt is using the suggestions from John to create
an igbX device to keep users from being SUPER angry when this lands
later today.
Changes need to be made to build and use if_lem for the boards that need it. Also, we are going to install a symlink from if_em.ko to if_igb.ko such that users of modules don't get immediately hosed on an update if they aren't building the drivers into the kernel and are expecting loader.conf 'if_igb_load=YES' to work.
sys/conf/files | ||
---|---|---|
3805 | Ugh, yeah. I'll revert that uneeded bit. | |
sys/dev/e1000/igb_txrx.c | ||
1 ↗ | (On Diff #23742) | Seems redundant as I do have that in the module Makefile. I'll remove. |
52 ↗ | (On Diff #23742) | Its in if_em.c which is being hidden from default view as most, if not all of the file is being replaced. |
Address review comments:
- restore broken white space
- remove uneeded #ifdef KLD_MODULE
Add installation of symlink during installkernel so that loader.conf:if_igb_load=YES
still works for users who are currently using igb(4) as a module and don't have em(4)
loaded or built into their kernel.