docs: Migrate network documentation of sim to Documentations

Move the docs in boards of sim to common place.

Signed-off-by: Huang Qi <huangqi3@xiaomi.com>
This commit is contained in:
Huang Qi 2024-09-12 22:56:03 +08:00 committed by Xiang Xiao
parent 74df0974b2
commit 55e4a98df7
3 changed files with 36 additions and 9 deletions

View file

@ -12,3 +12,5 @@ The following Simulator/Emulators are supported:
:glob: :glob:
*/* */*
network_linux
network_vpnkit

View file

@ -25,10 +25,11 @@ you assign an IP that is already in use on your network, your host won't be
able to see it until the simulation is stopped. The host route will force all able to see it until the simulation is stopped. The host route will force all
traffic destined for that IP to be sent to the tap interface. traffic destined for that IP to be sent to the tap interface.
NOTE: If you configure an IP address that is not on the same subnet as your .. note::
host, additional manual setup will be required. A helper script, If you configure an IP address that is not on the same subnet as your
`tools/simhostroute.sh` is provided that can do this setup on Linux. host, additional manual setup will be required. A helper script,
On Windows or macOS using host route mode is not recommended. `tools/simhostroute.sh` is provided that can do this setup on Linux.
On Windows or macOS using host route mode is not recommended.
Recent versions of Linux require setting kernel capabilities to allow the nuttx Recent versions of Linux require setting kernel capabilities to allow the nuttx
executable access to the tap network driver. You can see more about the tun/tap executable access to the tap network driver. You can see more about the tun/tap
@ -41,6 +42,8 @@ configuration.
To compile: To compile:
.. code-block:: bash
$ cp boards/sim/sim/sim/configs/tcpblaster/defconfig .config $ cp boards/sim/sim/sim/configs/tcpblaster/defconfig .config
$ make menuconfig # optional, to adjust configuration $ make menuconfig # optional, to adjust configuration
$ make clean; make $ make clean; make
@ -49,6 +52,8 @@ You can do the following after compiling the NuttX simulator:
On Linux: On Linux:
.. code-block:: bash
$ # necessary on recent Linux distributions $ # necessary on recent Linux distributions
$ sudo setcap cap_net_admin+ep ./nuttx $ sudo setcap cap_net_admin+ep ./nuttx
$ # set up the host route and IP tables rules $ # set up the host route and IP tables rules
@ -59,6 +64,8 @@ On Linux:
On the NuttX Simulator: On the NuttX Simulator:
.. code-block:: bash
nsh> # replace or omit dns if needed, IPv6 line is optional nsh> # replace or omit dns if needed, IPv6 line is optional
nsh> ifconfig eth0 inet6 fc00::2/112 dns 2001:4860:4860::8888 nsh> ifconfig eth0 inet6 fc00::2/112 dns 2001:4860:4860::8888
nsh> ifconfig eth0 10.0.1.2 dns 8.8.8.8 nsh> ifconfig eth0 10.0.1.2 dns 8.8.8.8
@ -66,6 +73,8 @@ On the NuttX Simulator:
On Linux: On Linux:
.. code-block:: bash
$ # is nuttx up? $ # is nuttx up?
$ ping 10.0.1.2 $ ping 10.0.1.2
@ -84,6 +93,8 @@ To create the bridge, first install the bridge utilities package for your
platform (the net-tools RPM in RedHat, for example). Then execute a platform (the net-tools RPM in RedHat, for example). Then execute a
command like the following: command like the following:
.. code-block:: bash
# ip link add nuttx0 type bridge # ip link add nuttx0 type bridge
This will create the nuttx0 bridge. Once created, the bridge may be used by This will create the nuttx0 bridge. Once created, the bridge may be used by
@ -100,6 +111,8 @@ that the subnet chosen should not already be in use. For example, if
you want to use the 172.26.23.0/24 subnet for your simluations, you you want to use the 172.26.23.0/24 subnet for your simluations, you
would do something like the following: would do something like the following:
.. code-block:: bash
# ip link add nuttx0 type bridge # ip link add nuttx0 type bridge
# ifconfig nuttx0 172.26.23.1/24 # ifconfig nuttx0 172.26.23.1/24
@ -119,6 +132,8 @@ with NuttX. For example, if you have a secondary eth1 interface on your host,
you can simply connect it to the network you want your simulations to access, you can simply connect it to the network you want your simulations to access,
and run the following command: and run the following command:
.. code-block:: bash
# ip link set eth1 master nuttx0 # ip link set eth1 master nuttx0
From that point on, your simulations will be directly connected to the same From that point on, your simulations will be directly connected to the same
@ -129,6 +144,8 @@ If you only have a single interface, you can configure your system so that eth0
(or other primary interface) is on the bridge. To do this, you would execute (or other primary interface) is on the bridge. To do this, you would execute
commands like the following from the system console: commands like the following from the system console:
.. code-block:: bash
# ip link add nuttx0 type bridge # ip link add nuttx0 type bridge
# ip link set eth0 master nuttx0 # ip link set eth0 master nuttx0
# ifconfig nuttx0 <host-ip-address/netmask> # ifconfig nuttx0 <host-ip-address/netmask>

View file

@ -8,37 +8,45 @@ as well.
Configuration Configuration
------------- -------------
.. code-block:: bash
CONFIG_SIM_NETDEV=y CONFIG_SIM_NETDEV=y
CONFIG_SIM_NETDEV_TAP is not set CONFIG_SIM_NETDEV_TAP is not set
CONFIG_SIM_NETDEV_VPNKIT=y CONFIG_SIM_NETDEV_VPNKIT=y
CONFIG_SIM_NETDEV_VPNKIT_PATH="/tmp/vpnkit-nuttx" CONFIG_SIM_NETDEV_VPNKIT_PATH="/tmp/vpnkit-nuttx"
You can use the sim:vpnkit configuration, which includes the above You can use the ``sim:vpnkit`` configuration, which includes the above
settings. settings.
.. code-block:: bash
./tools/configure.sh sim:vpnkit ./tools/configure.sh sim:vpnkit
VPNKit setup VPNKit setup
------------ ------------
See https://github.com/moby/vpnkit for build instructions. See `https://github.com/moby/vpnkit` for build instructions.
If you have Docker Desktop for Mac installed on your machine, If you have Docker Desktop for Mac installed on your machine,
you can find a vpnkit binary at: you can find a vpnkit binary at:
.. code-block:: bash
/Applications/Docker.app/Contents/Resources/bin/com.docker.vpnkit /Applications/Docker.app/Contents/Resources/bin/com.docker.vpnkit
A docker image containing a static Linux binary is also available: A docker image containing a static Linux binary is also available:
https://hub.docker.com/r/djs55/vpnkit `https://hub.docker.com/r/djs55/vpnkit`
How to run How to run
---------- ----------
You can use it as the following: You can use it as the following:
.. code-block:: bash
% vpnkit --ethernet /tmp/vpnkit-nuttx & % vpnkit --ethernet /tmp/vpnkit-nuttx &
% ./nuttx % ./nuttx
NuttX's CONFIG_SIM_NETDEV_VPNKIT_PATH should match vpnkit's NuttX's ``CONFIG_SIM_NETDEV_VPNKIT_PATH`` should match vpnkit's
--ethernet option. ``--ethernet`` option.