I noticed that IP forwarding appears to be enabled in WSL (Windows 10pro 1709), according to sysctl. I'm hoping I can use this to make a software router on WSL -- to play with Hyper-V VM traffic on the same physical host. The VM and the host can communicate over a shared /24 ipv4 subnet.

Ideally, I'd want to use WSL to configure iptables-like rules, or have some sort of software router program using RAW sockets that could rewrite traffic.

    # on the WSL bash
    $ sysctl net.ipv4.ip_forward
    net.ipv4.ip_forward = 1

My windows host and the VM are both in 192.168.4.X. 192.168.4.215 is the host. 192.168.4.228 is the VM. 

I've added a rule to the windows firewall to allow every incoming TCP port on that subnet, and tested connectivity by transferring web pages served by the  WSL host and downloaded by the VM. (e.g. ran `python -m SimpleHTTPServer` in wsl and used  `curl http://192.168.2.215` on the vm)

I've added the windows host as the default gateway inside the VM:

    # route add default gw 192.168.4.215
    # route -n
    Kernel IP routing table
    Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
    0.0.0.0         192.168.4.215   0.0.0.0         UG    0      0        0 eth0
    172.17.0.0      0.0.0.0         255.255.0.0     U     0      0        0 docker0
    192.168.4.0     0.0.0.0         255.255.255.0   U     0      0        0 eth0


But my TCP connections initiated on the VM are not being routed by Windows (e.g. `curl http://<publicip>`.). Can't connect

What else do I need to unblock in Windows?

**Edit**

I've somewhat given up on this. Because all I wanted to do with the VM traffic was to NAT it over the host's VPN tunnel, I ended up using creating a special NAT interface with powershell:

https://serverfault.com/questions/911578/windows-10-pro-as-a-nat-between-two-interfaces