Compare commits
	
		
			4 commits
		
	
	
		
			994f36a727
			...
			274bdf95b6
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 274bdf95b6 | |||
|   | 025dd396e9 | ||
|   | 92b638d842 | ||
|   | 1429436f75 | 
					 1 changed files with 79 additions and 125 deletions
				
			
		
							
								
								
									
										204
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										204
									
								
								README.md
									
									
									
									
									
								
							|  | @ -1,10 +1,8 @@ | ||||||
| # About | # About | ||||||
| 
 | 
 | ||||||
| pfatt is a set of notes and scripts for setting up pfSense with AT&T U-Verse Fiber Internet. pfatt utilizes [netgraph](https://www.freebsd.org/cgi/man.cgi?netgraph(4)), which is a graph based kernel networking subsystem of FreeBSD to enable pfSense to fully manage the WAN address. This kernel-level solution was required to account for the unique issues surrounding bridging 802.1X traffic and/or transmitting 802.1Q Ethernet frames with the VLAN ID tag set to 0. pfatt does NOT enable theft of service, altering service speed or other malicious intent in any way. | This repository includes my notes on enabling a true bridge mode setup with AT&T U-Verse and OPNsense. This method utilizes [netgraph](https://www.freebsd.org/cgi/man.cgi?netgraph(4)) which is a graph based kernel networking subsystem of FreeBSD. This low-level solution was required to account for the unique issues surrounding bridging 802.1X traffic and tagging a VLAN with an id of 0.  | ||||||
| 
 | 
 | ||||||
| # Introduction | There are a few other methods to accomplish true bridge mode, so be sure to see what easiest for you. True Bridge Mode is also possible in a Linux via ebtables or using hardware with a VLAN swap trick. | ||||||
| 
 |  | ||||||
| I strongly advise reading this introduction, so you understand the background of how everything works. However, you can skip to the **Setup** section if you want to get to the point. |  | ||||||
| 
 | 
 | ||||||
| ## Residential Gateway | ## Residential Gateway | ||||||
| 
 | 
 | ||||||
|  | @ -15,30 +13,30 @@ AT&T currently offers a variety of residential gateways to their fiber customers | ||||||
| - Arris BGW210 | - Arris BGW210 | ||||||
| - Pace 5268AC | - Pace 5268AC | ||||||
| 
 | 
 | ||||||
| While these gateways offer something called _IP Passthrough_, it does not provide the ability to fully utilize your own hardware. For example, the NAT table is still managed by the gateway, which is limited to a measly 8192 sessions on some models (and it becomes unstable at even 60% capacity). | While many AT&T residential gateways offer something called _IP Passthrough_, it does not provide the same advantages of a true bridge mode. For example, the NAT table is still managed by the gateway, which is limited to a measly 8192 sessions (although it becomes unstable at even 60% capacity). | ||||||
| 
 | 
 | ||||||
| pfatt will allow you to fully utilize your own router either by enabling true bridge mode or by bypassing the gateway completely. It should handle reboots, power/service outages,  re-authentications, IPv6, and new DHCP leases. | The netgraph method will allow you to fully utilize your own router and fully bypass your residential gateway. It survives reboots, re-authentications, IPv6, and new DHCP leases. | ||||||
| 
 | 
 | ||||||
| ## How it Works | # How it Works | ||||||
| 
 | 
 | ||||||
| Before setting up pfatt, it's important to understand how the stock residential gateway authenticates and acquires its WAN address. This will make pfatt configuration and troubleshooting much easier. | Before continuing to the setup, it's important to understand how this method works. This will make configuration and troubleshooting much easier. | ||||||
| 
 | 
 | ||||||
| ### Stock Procedure | ## Standard Procedure | ||||||
| 
 | 
 | ||||||
| First, let's talk about what happens in the stock residential gateway setup (without pfatt). At a high level, the following process happens when the residential gateway boots up: | First, let's talk about what happens in the standard setup (without any bypass). At a high level, the following process happens when the gateway boots up: | ||||||
| 
 | 
 | ||||||
| 1. All traffic on the ONT is protected with [802.1X](https://en.wikipedia.org/wiki/IEEE_802.1X). So in order to talk to anything, the residential gateway must first perform the [EAP-TLS authentication procedure](https://tools.ietf.org/html/rfc5216). This process utilizes a unique keys and certificates that are hardcoded to authorized devices, like your residential gateway. | 1. All traffic on the ONT is protected with [802.1/X](https://en.wikipedia.org/wiki/IEEE_802.1X). So in order to talk to anything, the Router Gateway must first perform the [authentication procedure](https://en.wikipedia.org/wiki/IEEE_802.1X#Typical_authentication_progression). This process uses a unique certificate that is hardcoded on your residential gateway. | ||||||
| 2. Once the authentication completes, your residential gateway will be to properly "talk" to the outside. However, all of your Ethernet frames will need to be transmitted with a VLAN ID tag of 0 before the internet gateway will respond.  VLAN 0 is a [Cisco feature](https://www.cisco.com/c/en/us/td/docs/ios-xml/ios/atm/configuration/15-mt/atm-15-mt-book/atm-vlan-prty-tag.html) extension of standard 802.1Q. (Thanks for pointing this out @devicelocksmith). | 2. Once the authentication completes, you'll be able to properly "talk" to the outside. However, all of your traffic will need to be tagged with VLAN ID 0 (a.k.a. VLAN Priority Tagging<sup>[[1]](https://wikipedia.org/wiki/IEEE_802.1Q#Frame_format)[[2]](https://www.cisco.com/c/en/us/td/docs/switches/connectedgrid/cg-switch-sw-master/software/configuration/guide/vlan0/b_vlan_0.html)</sup>) before the IP gateway will respond.   | ||||||
| 3. Once traffic is tagged as VLAN ID 0, your residential gateway then needs to request its public IPv4 address via DHCP. The MAC address in the DHCP request needs to match that of the MAC address that's assigned to your AT&T account. | 3. Once traffic is tagged with VLAN0, your residential gateway needs to request a public IPv4 address via DHCP. The MAC address in the DHCP request needs to match that of the MAC address that's assigned to your AT&T account. Other than that, there's nothing special about the DCHPv4 handshake. | ||||||
| 4. After the DHCP lease is issued, the WAN setup is complete. Your LAN traffic is then NAT'd and routed to the outside. | 4. After the DHCP lease is issued, the WAN setup is complete. Your LAN traffic is then NAT'd and routed to the outside. | ||||||
| 
 | 
 | ||||||
| ### Bypass Procedure | ## Bypass Procedure | ||||||
| 
 | 
 | ||||||
| To bypass your residential gateway to fully utilize pfSense, we can emulate the above stock procedure by either two methods: bridging the 802.1X EAP-TLS authentication traffic or by utilizing the native [wpa_supplicant](https://www.freebsd.org/cgi/man.cgi?wpa_supplicant) client with valid certificates to perform the 802.1X EAP-TLS authentication.  | To bypass the gateway using OPNsense, we can emulate the standard procedure. If we connect our Residential Gateway and ONT to our OPNsense box, we can bridge the 802.1/X authentication sequence, tag our WAN traffic as VLAN0, and request a public IPv4 via DHCP using a spoofed MAC address. | ||||||
| 
 | 
 | ||||||
| The bridge method is the easiest, but it requires the residential gateway to be powered on and connected to your pfsense box during the authentication procedure.  | Unfortunately, there are some challenges with emulating this process. First, it's against RFC to bridge 802.1/X traffic and it is not supported. Second, tagging traffic as VLAN0 is not supported through the standard interfaces. | ||||||
| 
 | 
 | ||||||
| The supplicant method is more difficult, because it requires extracting valid certificates through the exploitation of known vulnerabilities or by dumping the flash of your residential gateway. However, it comes with the benefit of being able to give full network management to pfsense (no residential gateway required to be connected at all, even at boot). It is also more stable and resilient to edge cases of reboots, outages, or other conditions. | This is where netgraph comes in. Netgraph allows you to break some rules and build the proper plumbing to make this work. So, our cabling looks like this: | ||||||
| 
 | 
 | ||||||
| #### Bridge Method   | #### Bridge Method   | ||||||
| 
 | 
 | ||||||
|  | @ -53,7 +51,7 @@ Residential Gateway | ||||||
| [ONT Port] | [ONT Port] | ||||||
|   | |   | | ||||||
|   | |   | | ||||||
| [nic0] pfSense [nic1]  | [nic0] OPNsense [nic1] | ||||||
|                  | |                  | | ||||||
|                  | |                  | | ||||||
|                [ONT] |                [ONT] | ||||||
|  | @ -62,14 +60,14 @@ Residential Gateway | ||||||
| 
 | 
 | ||||||
| With netgraph, our procedure looks like this (at a high level): | With netgraph, our procedure looks like this (at a high level): | ||||||
| 
 | 
 | ||||||
| 1. The residential gateway initiates a 802.1X EAPOL-START packet. | 1. The Residential Gateway initiates a 802.1/X EAPOL-START. | ||||||
| 2. The packet then is bridged through netgraph to the ONT interface. | 1. The packet then is bridged through netgraph to the ONT interface. | ||||||
| 3. If the packet matches an 802.1X type (which is does), it is passed to the ONT interface. If it does not, the packet is discarded. This prevents our residential gateway from initiating DHCP. We want pfSense to handle that. | 1. If the packet matches an 802.1/X type (which is does), it is passed to the ONT interface. If it does not, the packet is discarded. This prevents our Residential Gateway from initiating DHCP. We want OPNsense to handle that. | ||||||
| 4. The AT&T RADIUS server should then see and respond to the EAPOL-START, which is passed back through our netgraph back to the residential gateway. At this point, the 802.1X EAP-TLS authentication should be continue and complete. | 1. The ONT should then see and respond to the EAPOL-START, which is passed back through our netgraph back to the residential gateway. At this point, the 802.1/X authentication should be complete. | ||||||
| 5. netgraph has also created an interface for us called `ngeth0`. This interface is connected to `ng_vlan` which is configured to tag all traffic as VLAN0 before sending it on to the ONT interface.  | 1. netgraph has also created an interface for us called `ngeth0`. This interface is connected to `ng_vlan` which is configured to tag all traffic as VLAN0 before sending it on to the ONT interface. | ||||||
| 6. pfSense can then be configured to use `ngeth0` as the WAN interface. | 1. OPNsense can then be configured to use `ngeth0` as the WAN interface. | ||||||
| 7. Next, we spoof the MAC address of the residential gateway and request a DHCP lease on `ngeth0`. The packets get tagged as VLAN0 and exit to the ONT.  | 1. Next, we spoof the MAC address of the residential gateway and request a DHCP lease on `ngeth0`. The packets get tagged as VLAN0 and exit to the ONT. | ||||||
| 8. Now the DHCP handshake should complete and we should be on our way! | 1. Now the DHCP handshake should complete and we should be on our way! | ||||||
| 
 | 
 | ||||||
| #### Supplicant Method | #### Supplicant Method | ||||||
| 
 | 
 | ||||||
|  | @ -95,6 +93,10 @@ Hopefully, that now gives you an idea of what we are trying to accomplish. See t | ||||||
| 
 | 
 | ||||||
| But enough talk. Now for the fun part! | But enough talk. Now for the fun part! | ||||||
| 
 | 
 | ||||||
|  | Hopefully, that now gives you an idea of what we are trying to accomplish. See the comments and commands `bin/pfatt.sh` for details about the netgraph setup. | ||||||
|  | 
 | ||||||
|  | But enough talk. Now for the fun part! | ||||||
|  | 
 | ||||||
| # Setup | # Setup | ||||||
| 
 | 
 | ||||||
| First, you need to decide which method to perform EAP authentication: bridge mode or supplicant mode. | First, you need to decide which method to perform EAP authentication: bridge mode or supplicant mode. | ||||||
|  | @ -140,104 +142,56 @@ For supplicant mode: | ||||||
| * The MAC address of your EAP-TLS Identity (which is the same as your residential gateway if you are using its certificates) | * The MAC address of your EAP-TLS Identity (which is the same as your residential gateway if you are using its certificates) | ||||||
| * Valid certificates to perform EAP-TLS authentication (see **Extracting Certificates**) | * Valid certificates to perform EAP-TLS authentication (see **Extracting Certificates**) | ||||||
| 
 | 
 | ||||||
| If you need a third NIC, you can buy this cheap USB 100Mbps NIC [from Amazon](https://amzn.to/2P0yn8k). It has the Asix AX88772 chipset, which is supported in FreeBSD with the [axe](https://www.freebsd.org/cgi/man.cgi?query=axe&sektion=4) driver. I've confirmed it works in my setup. The driver was already loaded and I didn't have to install or configure anything to get it working.  | If you only have two NICs, you can buy this cheap USB 100Mbps NIC [from Amazon](https://www.amazon.com/gp/product/B00007IFED) as your third. It has the Asix AX88772 chipset, which is supported in FreeBSD with the [axe](https://www.freebsd.org/cgi/man.cgi?query=axe&sektion=4) driver. I've confirmed it works in my setup. The driver was already loaded and I didn't have to install or configure anything to get it working.  | ||||||
| 
 | 
 | ||||||
| Also, don't worry about the poor performance of USB or 100Mbps NICs. This third NIC will only send/receive a few packets periodically to authenticate your residential gateway. The rest of your traffic will utilize your other (and much faster) NICs. | Also, don't worry about the poor performance of USB or 100Mbps NICs. This third NIC will only send/recieve a few packets periodicaly to authenticate your Router Gateway. The rest of your traffic will utilize your other (and much faster) NICs. | ||||||
| 
 |  | ||||||
| Next, proceed to the appropriate installation section. |  | ||||||
| 
 | 
 | ||||||
| ## Install | ## Install | ||||||
| 
 | 
 | ||||||
| 1. Grab this repo to your local machine. | 1. Edit the following configuration variables in `bin/pfatt.sh` as noted below. `$RG_ETHER_ADDR` should match the MAC address of your Residential Gateway. AT&T will only grant a DHCP lease to the MAC they assigned your device. In my environment, it's: | ||||||
| ``` |     ```shell | ||||||
| git clone https://github.com/aus/pfatt |     ONT_IF='xx0' # NIC -> ONT / Outside | ||||||
| ``` |     RG_IF='xx1'  # NIC -> Residential Gateway's ONT port | ||||||
| 2. Next, edit all configuration variables in `pfatt.sh`. |     RG_ETHER_ADDR='xx:xx:xx:xx:xx:xx' # MAC address of Residential Gateway | ||||||
|  |     ``` | ||||||
| 
 | 
 | ||||||
| 1. Upload the pfatt directory to `/conf` on your pfSense box. | 2. Copy `bin/opnatt.sh` to `/user/local/etc/rc.syshook.d/early/99-opnatt.sh` (or any directory): | ||||||
| ``` |     ``` | ||||||
| scp -r pfatt root@pfsense:/conf/ |     scp bin/pfatt.sh root@OPNsense:/user/local/etc/rc.syshook.d/early/99-opnatt.sh | ||||||
| ``` |     ssh root@OPNsense chmod +x /user/local/etc/rc.syshook.d/early/99-opnatt.sh | ||||||
| 4. If you are using supplicant mode, upload your extracted certs (see **Extracting Certificates**) to `/conf/pfatt/wpa`. You should have three files in the wpa directory as such. You may also need to match the permissions. |     ``` | ||||||
| ``` |  | ||||||
| [2.4.4-RELEASE][root@pfsense.knox.lan]/conf/pfatt/wpa: ls -al |  | ||||||
| total 19 |  | ||||||
| drwxr-xr-x  2 root  wheel     5 Jan 10 16:32 . |  | ||||||
| drwxr-xr-x  4 root  wheel     5 Jan 10 16:33 .. |  | ||||||
| -rw-------  1 root  wheel  5150 Jan 10 16:32 ca.pem |  | ||||||
| -rw-------  1 root  wheel  1123 Jan 10 16:32 client.pem |  | ||||||
| -rw-------  1 root  wheel   887 Jan 10 16:32 private.pem |  | ||||||
| ``` |  | ||||||
| 5. Edit your `/conf/config.xml` to include `<earlyshellcmd>/conf/pfatt/bin/pfatt.sh</earlyshellcmd>` above `</system>`.  |  | ||||||
| 
 | 
 | ||||||
| 1. Connect cables |     **NOTE:** If you have the 5268AC, you'll also need to install `pfatt-5268AC-startup.sh` and `pfatt-5268.sh`. The scripts monitor your connection and disable or enable the EAP bridging as needed. It's a hacky workaround, but it enables you to keep your 5268AC connected, avoid EAP-Logoffs and survive reboots. Consider changing the `PING_HOST` in `pfatt-5268AC.sh` to a reliable host. Then perform these additional steps to install: | ||||||
|     - `$EAP_BRIDGE_IF` to Residential Gateway on the ONT port (not the LAN ports!) |     ``` | ||||||
|  |     scp bin/pfatt-5268AC-startup.sh root@OPNsense:/usr/local/etc/rc.d/pfatt-5268AC-startup.sh | ||||||
|  |     scp bin/pfatt-5268AC.sh root@OPNsense:/root/bin/ | ||||||
|  |     ssh root@OPNsense chmod +x /usr/local/etc/rc.d/pfatt-5268AC-startup.sh /root/bin/pfatt-5268AC.sh | ||||||
|  |     ``` | ||||||
|  | 
 | ||||||
|  | 3. The pfatt.sh script will start with the boot process due to it's placement in /user/local/etc/rc.syshook.d/early/. | ||||||
|  | 
 | ||||||
|  | 4. Connect cables: | ||||||
|  |     - `$RG_IF` to Residential Gateway on the ONT port (not the LAN ports!) | ||||||
|     - `$ONT_IF` to ONT (outside) |     - `$ONT_IF` to ONT (outside) | ||||||
|     - `LAN NIC` to local switch (as normal) |     - `LAN NIC` to local switch (as normal) | ||||||
| 
 | 
 | ||||||
| 1. Prepare for console access. | 5. Prepare for console access. | ||||||
| 1. Reboot. | 6. Reboot. | ||||||
| 1. pfSense will detect new interfaces on bootup. Follow the prompts on the console to configure `ngeth0` as your pfSense WAN. Your LAN interface should not normally change. However, if you moved or re-purposed your LAN interface for this setup, you'll need to re-apply any existing configuration (like your VLANs) to your new LAN interface. pfSense does not need to manage `$EAP_BRIDGE_IF` or `$ONT_IF`. I would advise not enabling those interfaces in pfSense as it can cause problems with the netgraph. | 7. OPNsense will detect new interfaces on bootup. Follow the prompts on the console to configure `ngeth0` as your OPNsense WAN. Your LAN interface should not normally change. However, if you moved or re-purposed your LAN interface for this setup, you'll need to re-apply any existing configuration (like your VLANs) to your new LAN interface. OPNsense does not need to manage `$RG_IF` or `$ONT_IF`. I would advise not enabling those interfaces in OPNsense as it can cause problems with the netgraph. | ||||||
| 1. In the webConfigurator, configure the  WAN interface (`ngeth0`) to DHCP using the MAC address of your Residential Gateway. | 8. In the webConfigurator, configure the  WAN interface (`ngeth0`) to DHCP using the MAC address of your Residential Gateway. | ||||||
| 
 | 
 | ||||||
| If everything is setup correctly, EAP authentication should complete. Netgraph should be tagging the WAN traffic with VLAN0, and your WAN interface is configured with a public IPv4 address via DHCP. | If everything is setup correctly, netgraph should be bridging EAP traffic between the ONT and RG, tagging the WAN traffic with VLAN0, and your WAN interface configured with an IPv4 address via DHCP. | ||||||
| 
 |  | ||||||
| ### Extracting Certificates |  | ||||||
| 
 |  | ||||||
| Certificates can be extracted by either the exploitation of the residential gateway to get a root shell or by desoldering and dumping the NAND. Public research and tools to do so are most available for the NVG589 and the NVG599. |  | ||||||
| 
 |  | ||||||
| #### Exploit |  | ||||||
| 
 |  | ||||||
| TODO |  | ||||||
| 
 |  | ||||||
| References |  | ||||||
| - https://www.devicelocksmith.com/2018/12/eap-tls-credentials-decoder-for-nvg-and.html |  | ||||||
| - https://www.nomotion.net/blog/sharknatto/ |  | ||||||
| - https://github.com/MakiseKurisu/NVG589/wiki |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| #### Dumping the NAND |  | ||||||
| 
 |  | ||||||
| User @KhoasT posted instructions for dumping the NAND. See the comment on devicelocksmith's site [here](https://www.devicelocksmith.com/2018/12/eap-tls-credentials-decoder-for-nvg-and.html?showComment=1549236760112#c5606196700989186087). |  | ||||||
| 
 |  | ||||||
| ### Notes on ng_etf  |  | ||||||
| 
 |  | ||||||
| If you do not trust my provided ng_etf kernel module (and you shouldn't because I am a random internet stranger), you can compile your own. |  | ||||||
| 
 |  | ||||||
| From another, trusted FreeBSD machine, run the following. _You cannot build packages directly on pfSense._ Your FreeBSD version should match that of your pfSense version. (Example: pfSense 2.4.4 = FreeBSD 11.2 |  | ||||||
| 
 |  | ||||||
| ``` |  | ||||||
|     # from a FreeBSD machine (not pfSense!) |  | ||||||
|     fetch ftp://ftp.freebsd.org/pub/FreeBSD/releases/amd64/amd64/11.2-RELEASE/src.txz |  | ||||||
|     tar -C / -zxvf src.txz |  | ||||||
|     cd /usr/src/sys/modules/netgraph |  | ||||||
|     make |  | ||||||
|     scp etf/ng_etf.ko root@pfsense:/boot/kernel/ |  | ||||||
|     ssh root@pfsense chmod 555 /boot/kernel/ng_etf.ko |  | ||||||
| ``` |  | ||||||
| **NOTE:** The `ng_etf.ko` in this repo was compiled for amd64 from the FreeBSD 11.2 release source code. It may also work on other/future versions of pfSense depending if there have been [significant changes](https://github.com/freebsd/freebsd/commits/master/sys/netgraph/ng_etf.c).   |  | ||||||
| 
 |  | ||||||
| **NOTE:** You'll need to tweak your compiler parameters if you need to build for another architecture, like ARM. |  | ||||||
| 
 | 
 | ||||||
| # IPv6 Setup | # IPv6 Setup | ||||||
| 
 | 
 | ||||||
| Once your netgraph setup is in place and working, there aren't any netgraph changes required to the setup to get IPv6 working. These instructions can also be followed with a different bypass method other than the netgraph method. Big thanks to @pyrodex1980's [post](http://www.dslreports.com/forum/r32118263-) on DSLReports for sharing your notes. | Once your netgraph setup is in place and working, there aren't any netgraph changes required to the setup to get IPv6 working. These instructions can also be followed with a different bypass method other than the netgraph method. Big thanks to @pyrodex1980's [post](http://www.dslreports.com/forum/r32118263-) on DSLReports for sharing your notes. | ||||||
| 
 | 
 | ||||||
| This setup assumes you have a fairly recent version of pfSense. I'm using 2.4.4. |  | ||||||
| 
 |  | ||||||
| **DUID Setup** |  | ||||||
| 
 |  | ||||||
| 1. Go to _System > Advanced > Networking_ |  | ||||||
| 2. Configure **DHCP6 DUID** to _DUID-EN_ |  | ||||||
| 3. Configure **DUID-EN** to _3561_ |  | ||||||
| 4. Configure your **IANA Private Enterprise Number**. This number is unique for each customer and (I believe) based off your Residential Gateway serial number. You can generate your DUID using [gen-duid.sh](https://github.com/aus/pfatt/blob/master/bin/gen-duid.sh), which just takes a few inputs. Or, you can take a pcap of the Residential Gateway with some DHCPv6 traffic. Then fire up Wireshark and look for the value in _DHCPv6 > Client Identifier > Identifier_. Add the value as colon separated hex values `00:00:00`. |  | ||||||
| 5. Save |  | ||||||
| 
 |  | ||||||
| **WAN Setup** | **WAN Setup** | ||||||
| 
 | 
 | ||||||
| 1. Go to _Interfaces > WAN_ | 1. Go to _Interfaces > WAN_ | ||||||
| 1. Enable **IPv6 Configuration Type** as _DHCP6_ | 1. Enable **IPv6 Configuration Type** as _DHCP6_ | ||||||
| 1. Scroll to _DCHP6 Client Configuration_ | 1. Scroll to _DCHP6 Client Configuration_ | ||||||
|  | 1. Enable **Request only an IPv6 prefix** | ||||||
| 1. Enable **DHCPv6 Prefix Delegation size** as _60_ | 1. Enable **DHCPv6 Prefix Delegation size** as _60_ | ||||||
| 1. Enable _Send IPv6 prefix hint_ | 1. Enable _Send IPv6 prefix hint_ | ||||||
| 1. Enable _Do not wait for a RA_ | 1. Enable _Do not wait for a RA_ | ||||||
|  | @ -248,7 +202,7 @@ This setup assumes you have a fairly recent version of pfSense. I'm using 2.4.4. | ||||||
| 1. Go to _Interfaces > LAN_ | 1. Go to _Interfaces > LAN_ | ||||||
| 1. Change the **IPv6 Configuration Type** to _Track Interface_ | 1. Change the **IPv6 Configuration Type** to _Track Interface_ | ||||||
| 1. Under Track IPv6 Interface, assign **IPv6 Interface** to your WAN interface. | 1. Under Track IPv6 Interface, assign **IPv6 Interface** to your WAN interface. | ||||||
| 1. Configure **IPv6 Prefix ID** to _1_. We start at _1_ and not _0_ because pfSense will use prefix/address ID _0_ for itself and it seems AT&T is flakey about assigning IPv6 prefixes when a request is made with a prefix ID that matches the prefix/address ID of the router. | 1. Configure **IPv6 Prefix ID** to _0_. You *CAN* use IPv6 Prefix id 0, as OPNSense does *NOT* assign a routeable IPv6 address to ngeth0 | ||||||
| 1. Save | 1. Save | ||||||
| 
 | 
 | ||||||
| If you have additional LAN interfaces repeat these steps for each interface except be sure to provide an **IPv6 Prefix ID** that is not _0_ and is unique among the interfaces you've configured so far. | If you have additional LAN interfaces repeat these steps for each interface except be sure to provide an **IPv6 Prefix ID** that is not _0_ and is unique among the interfaces you've configured so far. | ||||||
|  | @ -258,12 +212,15 @@ If you have additional LAN interfaces repeat these steps for each interface exce | ||||||
| 1. Go to _Services > DHCPv6 Server & RA_ | 1. Go to _Services > DHCPv6 Server & RA_ | ||||||
| 1. Enable DHCPv6 server on interface LAN | 1. Enable DHCPv6 server on interface LAN | ||||||
| 1. Configure a range of ::0001 to ::ffff:ffff:ffff:fffe | 1. Configure a range of ::0001 to ::ffff:ffff:ffff:fffe | ||||||
| 1. Configure a **Prefix Delegation Range** to _64_ | 1. Leave **Prefix Delegation Range** _blank_. | ||||||
|  | 1. Configure **Prefix Delegation Size** to _64_ | ||||||
| 1. Save | 1. Save | ||||||
| 1. Go to the _Router Advertisements_ tab | 1. Go to the _Router Advertisements_ tab | ||||||
| 1. Configure **Router mode** as _Stateless DHCP_ | 1. Configure **Router mode** as _Stateless DHCP_ | ||||||
| 1. Save | 1. Save | ||||||
| 
 | 
 | ||||||
|  | If you have additional LAN interfaces repeat these steps for each interface. | ||||||
|  | 
 | ||||||
| That's it! Now your clients should be receiving public IPv6 addresses via DHCP6. | That's it! Now your clients should be receiving public IPv6 addresses via DHCP6. | ||||||
| 
 | 
 | ||||||
| # Troubleshooting | # Troubleshooting | ||||||
|  | @ -297,21 +254,21 @@ tcpdump -ei $ONT_IF port 67 or port 68 | ||||||
| tcpdump -ei ngeth0 port 67 or port 68 | tcpdump -ei ngeth0 port 67 or port 68 | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| Verify you are seeing 802.1Q (tagged as vlan0) traffic on your `$ONT_IF ` interface and untagged traffic on `ngeth0`.  | Verify you are seeing 802.1Q (tagged as vlan0) traffic on your `$ONT_IF ` interface and untagged traffic on `ngeth0`. | ||||||
| 
 | 
 | ||||||
| Verify the DHCP request is firing using the MAC address of your Residential Gateway. | Verify the DHCP request is firing using the MAC address of your Residential Gateway. | ||||||
| 
 | 
 | ||||||
| If the VLAN0 traffic is being properly handled, next pfSense will need to request an IP. `ngeth0` needs to DHCP using the authorized MAC address. You should see an untagged DCHP request on `ngeth0` carry over to the `$ONT_IF` interface tagged as VLAN0. Then you should get a DHCP response and you're in business. | If the VLAN0 traffic is being properly handled, next OPNsense will need to request an IP. `ngeth0` needs to DHCP using the authorized MAC address. You should see an untagged DCHP request on `ngeth0` carry over to the `$ONT_IF` interface tagged as VLAN0. Then you should get a DHCP response and you're in business. | ||||||
| 
 | 
 | ||||||
| If you don't see traffic being bridged between `ngeth0` and `$ONT_IF`, then netgraph is not setup correctly.  | If you don't see traffic being bridged between `ngeth0` and `$ONT_IF`, then netgraph is not setup correctly. | ||||||
| 
 | 
 | ||||||
| ## Promiscuous Mode | ## Promiscuous Mode | ||||||
| 
 | 
 | ||||||
| `pfatt.sh` will put `$RG_IF` in promiscuous mode via `/sbin/ifconfig $RG_IF promisc`. Otherwise, the EAP packets would not bridge. I think this is necessary for everyone but I'm not sure. Turn it off if it's causing issues.  | `pfatt.sh` will put `$RG_IF` in promiscuous mode via `/sbin/ifconfig $RG_IF promisc`. Otherwise, the EAP packets would not bridge. I think this is necessary for everyone but I'm not sure. Turn it off if it's causing issues. | ||||||
| 
 | 
 | ||||||
| ## netgraph | ## netgraph | ||||||
| 
 | 
 | ||||||
| The netgraph system provides a uniform and modular system for the implementation of kernel objects which perform various networking functions. If you're unfamiliar with netgraph, this [tutorial](http://www.netbsd.org/gallery/presentations/ast/2012_AsiaBSDCon/Tutorial_NETGRAPH.pdf) is a great introduction.  | The netgraph system provides a uniform and modular system for the implementation of kernel objects which perform various networking functions. If you're unfamiliar with netgraph, this [tutorial](http://www.netbsd.org/gallery/presentations/ast/2012_AsiaBSDCon/Tutorial_NETGRAPH.pdf) is a great introduction. | ||||||
| 
 | 
 | ||||||
| Your netgraph should look something like this: | Your netgraph should look something like this: | ||||||
| 
 | 
 | ||||||
|  | @ -367,10 +324,6 @@ $ ngctl show ue0: | ||||||
| /usr/sbin/ngctl shutdown ngeth0: | /usr/sbin/ngctl shutdown ngeth0: | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| ## pfSense |  | ||||||
| 
 |  | ||||||
| In some circumstances, pfSense may alter your netgraph. This is especially true if pfSense manages either your `$RG_IF` or `$ONT_IF`. If you make some interface changes and your connection breaks, check to see if your netgraph was changed. |  | ||||||
| 
 |  | ||||||
| # Virtualization Notes | # Virtualization Notes | ||||||
| 
 | 
 | ||||||
| This setup has been tested on physical servers and virtual machines. Virtualization adds another layer of complexity for this setup, and will take extra consideration. | This setup has been tested on physical servers and virtual machines. Virtualization adds another layer of complexity for this setup, and will take extra consideration. | ||||||
|  | @ -379,7 +332,7 @@ This setup has been tested on physical servers and virtual machines. Virtualizat | ||||||
| 
 | 
 | ||||||
| Proxmox uses a bridged networking model, and thus utilizes Linux's native bridge capability. To use this netgraph method, you do a PCI passthrough for the `$RG_IF` and `$ONT_IF` NICs. The bypass procedure should then be the same. | Proxmox uses a bridged networking model, and thus utilizes Linux's native bridge capability. To use this netgraph method, you do a PCI passthrough for the `$RG_IF` and `$ONT_IF` NICs. The bypass procedure should then be the same. | ||||||
| 
 | 
 | ||||||
| You can also solve the EAP/802.1X and VLAN0/802.1Q problem by setting the `group_fwd_mask` and creating a vlan0 interface to bridge to your VM. See *Other Methods* below.  | You can also solve the EAP/802.1X and VLAN0/802.1Q problem by setting the `group_fwd_mask` and creating a vlan0 interface to bridge to your VM. See *Other Methods* below. | ||||||
| 
 | 
 | ||||||
| ## ESXi | ## ESXi | ||||||
| 
 | 
 | ||||||
|  | @ -395,15 +348,15 @@ If you're looking how to do this on a Linux-based router, please refer to [this | ||||||
| 
 | 
 | ||||||
| There is a whole thread on this at [DSLreports](http://www.dslreports.com/forum/r29903721-AT-T-Residential-Gateway-Bypass-True-bridge-mode). The gist of this method is that you connect your ONT, RG and WAN to a switch. Create two VLANs. Assign the ONT and RG to VLAN1 and the WAN to VLAN2. Let the RG authenticate, then change the ONT VLAN to VLAN2. The WAN the DHCPs and your in business. | There is a whole thread on this at [DSLreports](http://www.dslreports.com/forum/r29903721-AT-T-Residential-Gateway-Bypass-True-bridge-mode). The gist of this method is that you connect your ONT, RG and WAN to a switch. Create two VLANs. Assign the ONT and RG to VLAN1 and the WAN to VLAN2. Let the RG authenticate, then change the ONT VLAN to VLAN2. The WAN the DHCPs and your in business. | ||||||
| 
 | 
 | ||||||
| However, I don't think this works for everyone. I had to explicitly tag my WAN traffic to VLAN0 which wasn't supported on my switch.  | However, I don't think this works for everyone. I had to explicitly tag my WAN traffic to VLAN0 which wasn't supported on my switch. | ||||||
| 
 | 
 | ||||||
| ## OPNSense / FreeBSD | ## FreeBSD | ||||||
| 
 | 
 | ||||||
| I haven't tried this with OPNSense or native FreeBSD, but I imagine the process is ultimately the same with netgraph. Feel free to submit a PR with notes on your experience. | I haven't tried this with native FreeBSD, but I imagine the process is ultimately the same with netgraph. Feel free to submit a PR with notes on your experience. | ||||||
| 
 | 
 | ||||||
| # U-verse TV | # U-verse TV | ||||||
| 
 | 
 | ||||||
| See [issue #3](https://github.com/aus/pfatt/issues/3). | See [U-VERSE_TV.md](U-VERSE_TV.md) | ||||||
| 
 | 
 | ||||||
| # References | # References | ||||||
| 
 | 
 | ||||||
|  | @ -413,12 +366,13 @@ See [issue #3](https://github.com/aus/pfatt/issues/3). | ||||||
| - https://www.dslreports.com/forum/r32127305-True-Bridge-mode-on-pfSense-with-netgraph | - https://www.dslreports.com/forum/r32127305-True-Bridge-mode-on-pfSense-with-netgraph | ||||||
| - https://www.dslreports.com/forum/r32116977-AT-T-Fiber-RG-Bypass-pfSense-IPv6 | - https://www.dslreports.com/forum/r32116977-AT-T-Fiber-RG-Bypass-pfSense-IPv6 | ||||||
| - http://www.netbsd.org/gallery/presentations/ast/2012_AsiaBSDCon/Tutorial_NETGRAPH.pdf | - http://www.netbsd.org/gallery/presentations/ast/2012_AsiaBSDCon/Tutorial_NETGRAPH.pdf | ||||||
| - https://www.devicelocksmith.com/ |  | ||||||
| 
 | 
 | ||||||
| # Credits | # Credits | ||||||
| 
 | 
 | ||||||
| - [dls](https://www.devicelocksmith.com/) - for mfg_dat_decode and many other tips | This took a lot of testing and a lot of hours to figure out. A unique solution was required for this to work in pfSense. If this helped you out, please buy us a coffee. | ||||||
| - [rajl](https://forum.netgate.com/user/rajl) - for the netgraph idea |  | ||||||
| - [pyrodex](https://www.dslreports.com/profile/1717952) - for IPv6 notes |  | ||||||
| - [aus](https://github.com/aus)  |  | ||||||
| 
 | 
 | ||||||
|  | - [rajl](https://forum.netgate.com/user/rajl) - for the netgraph idea - 1H8CaLNXembfzYGDNq1NykWU3gaKAjm8K5 | ||||||
|  | - [pyrodex](https://www.dslreports.com/profile/1717952) - for IPv6 - ? | ||||||
|  | - [aus](https://github.com/aus) - 31m9ujhbsRRZs4S64njEkw8ksFSTTDcsRU | ||||||
|  | - [/u/MisterBazz](https://www.reddit.com/user/MisterBazz/) - [for the initial setup guide on U-verse TV documentation](https://www.reddit.com/r/PFSENSE/comments/ag43rb/att_bgw210_true_independent_bridge_mode_uverse/) that formed the basis for [U-VERSE_TV.md](U-VERSE_TV.md) | ||||||
|  | - [0xC0ncord](https://github.com/0xC0ncord) - for the [U-Verse TV Documentation](U-VERSE_TV.md) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue