Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    pfSense 2.7 on Intel Xeon D-17xx SoC: SFP28 working?

    Scheduled Pinned Locked Moved Hardware
    18 Posts 4 Posters 2.9k Views 5 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • P Offline
      phloggu @tman222
      last edited by

      @tman222
      Thank you for your report!

      E 1 Reply Last reply Reply Quote 0
      • E Offline
        eracerxrs @phloggu
        last edited by

        @phloggu

        Just wanted to add that I've been trying to get the full 25Gbps since 2.7 has been released, but is not yet possible.

        No matter if I get it to connect at 10Gbps using the drivers that come with 2.7, or compiling the intel driver on FreeBSD 14 beta and using that on 2.7 to get it to "say" it is connecting at 25 Gbps, the max throughput is always 6 Gbps.

        According to dmesg output the problem seems to be ice_ddp module failing to load and it goes into safe mode.

        I can get the full 25Gbps in pfsense 2.6 when compiling the drivers under FreeBSD 12.3.

        I am hoping once FreeBSD 14 is finally released at the end of October I'll be able to compile the intel drivers that work.

        T 1 Reply Last reply Reply Quote 0
        • T Offline
          tman222 @eracerxrs
          last edited by

          @eracerxrs said in pfSense 2.7 on Intel Xeon D-17xx SoC: SFP28 working?:

          @phloggu

          Just wanted to add that I've been trying to get the full 25Gbps since 2.7 has been released, but is not yet possible.

          No matter if I get it to connect at 10Gbps using the drivers that come with 2.7, or compiling the intel driver on FreeBSD 14 beta and using that on 2.7 to get it to "say" it is connecting at 25 Gbps, the max throughput is always 6 Gbps.

          According to dmesg output the problem seems to be ice_ddp module failing to load and it goes into safe mode.

          I can get the full 25Gbps in pfsense 2.6 when compiling the drivers under FreeBSD 12.3.

          I am hoping once FreeBSD 14 is finally released at the end of October I'll be able to compile the intel drivers that work.

          Hi @eracerxrs - did you try putting ice_ddp_load="YES" into the loader.conf.local file? When I did this, the ice_dpp.ko module was loaded and the warnings about safe mode went away. Please also see: https://reviews.freebsd.org/rS361541

          Hope this helps.

          E 1 Reply Last reply Reply Quote 0
          • E Offline
            eracerxrs @tman222
            last edited by

            Hey @tman222,

            Yeah, I have:

            ice_ddp_load= "YES"
            if_ice_load="YES"
            

            in my loader.conf file. And it's still going into safe mode. Where am I going wrong...

            Where are you getting the ice_ddp.ko and if_ice.ko files from?
            Are you placing them in the /boot/modules folder?
            You're getting the full 25Gbps throughput?

            T 1 Reply Last reply Reply Quote 0
            • T Offline
              tman222 @eracerxrs
              last edited by tman222

              @eracerxrs said in pfSense 2.7 on Intel Xeon D-17xx SoC: SFP28 working?:

              Hey @tman222,

              Yeah, I have:

              ice_ddp_load= "YES"
              if_ice_load="YES"
              

              in my loader.conf file. And it's still going into safe mode. Where am I going wrong...

              Where are you getting the ice_ddp.ko and if_ice.ko files from?
              Are you placing them in the /boot/modules folder?
              You're getting the full 25Gbps throughput?

              Hi @eracerxrs - make sure you use the loader.conf.local file instead of loader.conf.

              https://docs.netgate.com/pfsense/en/latest/config/advanced-tunables.html#managing-loader-tunables

              All you should need to add is ice_ddp_load="YES". In my case, I had to put that line at the very top of the loader.conf.local file for the DDP module to be loaded a boot. The module is included with pfSense, I didn't have to install any additional drivers.

              I have not been able to test at 25Gbps, but I was getting full throughput at 10Gbps.

              Hope this helps.

              E 1 Reply Last reply Reply Quote 0
              • stephenw10S Offline
                stephenw10 Netgate Administrator
                last edited by

                Both using the D-1718T?

                E 1 Reply Last reply Reply Quote 0
                • E Offline
                  eracerxrs @tman222
                  last edited by

                  @tman222 Thanks for taking me through this...

                  So it sounds like you're actually running pfSense Plus (not CE 2.7) correct? Because my 2.7 CE install doesn't have the necessary drivers included, so I was trying to compile the intel drivers through the FreeBSD 14 beta like I had to do previously for pfSense CE 2.6

                  Realizing this has made me take a look at pfSense Plus. I always thought it was only available for Netgate branded devices. Though I never really had a need for any more advanced features than was provided by CE. I'm grateful they have a free home lab license!

                  For anyone else who stumbles on this thread, along with pfSense plus and ice_ddp_load="YES" in the loader.conf.local file:

                  In the GUI:
                  ENABLE Hardware TCP Segmentation (uncheck disable)
                  ENABLE Large Receive Offloading. (uncheck disable)

                  [In past versions, I also had these overrides in my loader.conf.local file, to achieve max throughput, but so far is looks like they aren't necessary:

                  dev.ice.0.iflib.override_qs_enable="1"
                  dev.ice.0.iflib.override_ntxds="4096"
                  dev.ice.0.iflib.override_nrxds="4096"
                  dev.ice.0.iflib.override_nrxqs="8"
                  dev.ice.0.iflib.override_nrxqs="8"
                  

                  ]

                  1 Reply Last reply Reply Quote 0
                  • E Offline
                    eracerxrs @stephenw10
                    last edited by eracerxrs

                    @stephenw10

                    I'm actually running the D-1736NT, pretty much the same E823-L nic, just double the cores I think.

                    1 Reply Last reply Reply Quote 1
                    • stephenw10S Offline
                      stephenw10 Netgate Administrator
                      last edited by

                      So what throughput are you seeing there with 23.05.1?

                      1 Reply Last reply Reply Quote 0
                      • T Offline
                        tman222
                        last edited by

                        I'm a little surprised that it only works with pfSense Plus since pfSense Plus 23.05.1 and pfSense CE 2.7.0 are both based on FreeBSD 14.

                        https://docs.netgate.com/pfsense/en/latest/releases/versions.html

                        If you start with a fresh install of CE 2.7.0, is everything recognized then? When I upgraded to the Xeon D-1718T based system, I installed pfSense CE 2.7.0 first and the moved pfSense Plus 23.05.1. However, I believe that the 823-L interfaces were also recognized fine in 2.7.0.

                        In any case, were you able to get things working properly in 23.05.1?

                        1 Reply Last reply Reply Quote 0
                        • E Offline
                          eracerxrs
                          last edited by eracerxrs

                          In 23.05.1 I am currently getting 23.5 Gbps using iperf3 as both client and server.
                          If one doesn't enable TSO and LRO as I mentioned above there ends up being suboptimal asymmetric throughput.

                          In 2.7 CE fresh out of the box there is a default driver that establishes a link.
                          "dmesg | grep ice0" says there's a 25GbE connection and looks okay, but it's actually 4.6 Gbps testing with iperf3.
                          "dmesg | grep ddp" says the ice_ddp.ko cannot be found/loaded and is running in safe mode. (even with ice_ddp_load="YES" in loader.conf.local)

                          If you compare the /boot/kernel/ directory between CE and Plus, Plus has far more extensive module support.

                          1 Reply Last reply Reply Quote 0
                          • stephenw10S Offline
                            stephenw10 Netgate Administrator
                            last edited by

                            Yes there was an effort to 'slim down' the CE build and some modules were removed. That should probably be there though given that the driver itself is present. You might open a bug/feature request for that: redmine.pfsense.org

                            23.5Gbps is impressive. Are you running one end of that on pfSense itself?

                            Steve

                            E 1 Reply Last reply Reply Quote 0
                            • E Offline
                              eracerxrs @stephenw10
                              last edited by eracerxrs

                              @stephenw10

                              If you mean "on pfSense itself":
                              I am running iperf3 from the CLI on the pfSense VM instance utilizing the NIC directly passed through to it and the drivers provided by pfSense 23.05.1.
                              It is connecting to a separate machine on the same subnet, so pfSense is not doing any routing.
                              With 8 Xeon D-1736NT threads/cpus allocated to the VM, the cpu load is at about 85% just to handle the 23.5Mbps of switching.

                              I'm about to swap in this box to be my main gateway , and then I'll be able to see what is possible in terms of layer 3 routing. I'm sure it'll be less than line speed and/or require up to the full 18 threads available on the CPU.

                              1 Reply Last reply Reply Quote 1
                              • stephenw10S Offline
                                stephenw10 Netgate Administrator
                                last edited by

                                Hmm, still impressive. Surprising that pfSense will server/sink that much traffic directly. It's usually faster routing.

                                1 Reply Last reply Reply Quote 0
                                • E Offline
                                  eracerxrs
                                  last edited by

                                  I just wanted to give an update regarding achieving full throughput on 2.7 CE especially given the recent pfsense plus licensing debacle:

                                  I was able to attain the full 23.5 Gbps throughput on 2.7 CE straight from a fresh install and the aforementioned enabling of the hardware offloads by enabling SR-IOV on the Proxmox host and passing into pfSense the virtual functions (virtual nics). In this situation, pfSense uses the iavf driver which is included in CE and precludes the need for if_ice.ko and ice_ddp.ko.

                                  On a related note: I was able to hit 31 Gbps on pfSense through an e810-cam2 (which uses the same driver setup as the e823. Though I've only just started playing with this 100GbE nic, so 31 is the starting point.

                                  1 Reply Last reply Reply Quote 2
                                  • First post
                                    Last post
                                  Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.