Having trouble getting my Intel I219-V attached to a driver
-
You really shouldn't need to compile anything for em at this point.
It sounds like what you did compile isn't loading anyway. Check the boot log for errors.
That device is not listed by the in-kernel driver in 2.5:
https://github.com/pfsense/FreeBSD-src/blob/RELENG_2_5_0/sys/dev/e1000/e1000_hw.h#L45It's not in head either. It's not even in head in FreeBSD.
Is it actually shown in whatever you were compiling?
Steve
-
So after my original post, I was doing some more digging around and I discovered exactly what you just posted.
I was initially working with the latest file set from Intel's website.
I added this line to e1000_hw.h
#define E1000_DEV_ID_PCH_TGP_I219_V14 0x15FA
This to the em_vendor_info_array[] in if_em.c
{ 0x80086, E1000_DEV_ID_PCH_TGP_I219_V4, PCI_ANY_ID, PCI_ANY_ID, 0}
And then I got e1000_api.c and I didn't know exactly what the mac type was. I assumed it would be considered a new one not listed yet, e1000_pch_tgp but I also didn't know what or if there were any additional functions that would be needed to incorporate the newer Tiger Point PCH architecture.
Luckily, I found Linux's driver set and compared it. Linux's driver set actually supports I-219 all the way to V19, it looks like.
Looking at Linux's driver set, I saw it actually listed V14 right below V11 which assigned it's mac type as e1000_pch_cnp.
e1000_pch_cnp is also in FreeBSD's e1000_api.c. So, I inserted it's case into there.
case E1000_DEV_ID_PCH_CMP_I219_V11: case E1000_DEV_ID_PCH_TGP_I219_V14: mac->type = e1000_pch_cnp;
And, then I guess I got a little carried away as during all this I was reading older forum posts from various places, trying to find out how to incorporate an unattached driver. And I thought I needed to recompile the kernel without if_em.ko and have it load as a separate file.
So, I did that and scp'd the new /boot/kernel over to my pfSense machine along with if_em.ko, adding the appropriate lines to the loader.conf.local, and it actually picked up em(0) for the I-219! But for some reason I lost all the igb's for my I350.
After that is when I discovered that configuration files in e1000 in pfSenses source modules folder were a bit different from Intel's files, even tho it says this file set is from version 7.7.8 which is the latest version.
I restarted and made clean installs of my pfSense machine and the virtual machine I was using to compile the file.
This time I modified the files in the /usr/src/sys/dev/e1000 folder, adding this line to if_em.c instead and the additional lines in the other two files.
PVID(0x8086, E1000_DEV_ID_PCH_TGP_I219_V14, "Intel(R) PRO/1000 Network Connection")
I ran a make on it from the sys/modules/em folder and scp'd the new if_em.ko to my pfSense machine /boot/modules (finding where the Makefile put the .ko was a pain in the butt), adding the appropriate lines to the loader.conf.local file.
if_em_load="YES" if_em_name="/boot/modules/if_em.ko"
Restarted and still nothing!
Tried to force load using kldload and it output that couldn't load as it was compiled from a different kernel or something.
I thought I was using the right virtual machine setup, installing FreeBSD 12.2-STABLE and cloning the devel-12 branch of the pfsense/FreeBSD-src to my virtual machine's /src folder. But I guess not.
This is the first time actually using a Unix OS and github.
I bet once I figure out how to get the appropriate virtual machine setup that compiling a new if_em.ko with those line additions above will get my I-219 working while keeping my igb's intact.
-
@lncabin
I have a simillar problem. Any updates, please? -
That device is now supported in FreeBSD head:
https://github.com/freebsd/freebsd-src/blob/main/sys/dev/e1000/e1000_hw.h#L167Part of this commit which doesn't look to be anything too complex. Though it may significantly far from 12-stable.
Steve
-
So, I updated to 2.5.2, which my I219-V (14) seems to be supported but I still can not get the driver to attach. Not sure where to go from here.
-
Mmm, it's in 2.5.2:
https://github.com/pfsense/FreeBSD-src/blob/RELENG_2_5_2/sys/dev/e1000/e1000_hw.h#L167What does the boot log show when it tries to attach?
Anything more if you boot verbose?Can you try a 2.6 snapshot?
Steve
-
Curiously,
Dashboard shows version as 2.5.2-RELEASE
but the kernal shows as FreeBSD 12.2-STABLE fd0f54f44b5c(RELENG_2_5_0) pfSense amd64Wouldn't one expect 2.5.2-RELEASE to show as RELENG_2_5_2?
-
Ah, that's it, yes. We had to roll a bunch of changes in 2.5.2 after a performance regression was found. It was built on the 2.5.0 branch so doesn't have that NIC support.
It is in 2.6 snapshots though that are built on devel-12.Steve
-
@stephenw10
Please forgive my lack of understanding, I literally just installed my first pfsense 2.5.2 installation and was hunting down an issue with a I219-V NIC not being recognized. First, I went to the github repository
https://github.com/pfsense/FreeBSD-src/blob/RELENG_2_5_2/sys/dev/e1000/e1000_hw.h to check for the supported hardware and it shows the I219-V I have is there.Then I ran across this post, and I think what you are saying (and my uname -a would infer) is that my 2.5.2 installation is really a 2.5.0? And that if I want to have the I219-V driver I need to get a 2.6 snapshot? Also inferred: I should not rely on the github 2.5.2 source files as they are not in sync with the 2.5.2 download?
Like I said I'm new to pfsense, and if my hardware is not supported in the current build so be it. But putting out a build that is not in sync with the source files and not clearly documenting that divergence where a newer user like me can find it makes it nearly impossible to really troubleshoot these low level driver issues.
Woody
-
Yes, you will need to use a 2.6 snapshot to get support for that NIC with the in kernel driver.
No, github is not out of sync. The RELENG_2_5_2 branch was created with a number of additional features we expected to be in 2.5.2 release but we hit some issues in testing that could not be resolved in reasonable time. In order to make the bug fixes we had available as soon as possible we ended up building 2.5.2 on the RELENG_2_5_0 branch. It's not how we would normally do it but for a bug fix release a new branch is not normally required. There isn't a 2.5.1 branch for example.
Steve
-
@stephenw10
Thank you for the response and the explanation. While researching the I219-V problem I found some other forums where users where trying to resolve this issue by compiling their own drivers. I will try and find those posts and mention the 2.6 snapshot as a potential solution instead of compiling drivers and mucking with the kernel config.