跳转到内容
主菜单
主菜单
移至侧栏
隐藏
导航
首页
最近更改
随机页面
MediaWiki帮助
Mcuzone Wiki
搜索
搜索
登录
个人工具
登录
查看“0001 MPRG4 EN”的源代码
页面
讨论
大陆简体
阅读
查看源代码
查看历史
工具
工具
移至侧栏
隐藏
操作
阅读
查看源代码
查看历史
常规
链入页面
相关更改
特殊页面
页面信息
←
0001 MPRG4 EN
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
[[0001 MPRG4|切换语言为中文]] =='''Keywords'''== Raspberry Pi 5 MPRG4 Quad-Gigabit Ethernet Expansion Board Pi OS Ubuntu OpenWrt software router switch =='''I. Introduction'''== The MPRG4 (also known as MPG4) is a Quad-Gigabit Ethernet expansion board designed specifically for the Raspberry Pi 5, utilizing the PCIe interface. This expansion board connects the RTL8111H PCIe Ethernet controller via the PCIe interface, and then extends into four Gigabit Ethernet ports through a switch chip. It can be used in the following scenarios: 1. In Raspberry Pi or Ubuntu OS, one network port connected to the upstream router, and the remaining three network ports providing network access to other nearby devices (all four network ports should be in the same subnet), it can save an additional external switch and power supply. 2. In OpenWrt OS, configure the native gigabit port of RPI5 as the WAN port, and the four extended ports as LAN ports, providing network access for up to four devices. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_74.jpg Note1: The four Gigabit ports have independent IP addresses but are located within the same subnet, with addresses assigned by the upstream router from its address pool. If the upstream router is not connected, Raspberry Pi or Ubuntu OS will be unable to obtain a valid IP address (they will receive an IP address in the range of 169.254.xx.xx, indicating that there is only a physical connection but no valid IP address). Note2: In the Raspberry Pi or Ubuntu OS, if the network cable is not plugged in at startup, the system will obtain an IP address like 169.254.xx.xx after a while. At this time, even if you plug in a network cable from an upstream router, the system will not obtain a valid IP address. You need to press the reset button to acquire a valid IP address again. The expansion board is driver-free on the official Raspberry Pi OS and OpenWrt. However, on the Ubuntu OS, you need to install the driver. =='''II. Hardware Resources'''== 1. It connected via a 16-pin 0.5mm PCIe to Raspberry Pi 5. 2. Onboard RTL8111H chip, enabling PCIe to Gigabit Ethernet. 3. Four Gigabit Ethernet. 4. A PWR LED. 5. A switch reset button (Switch RST). 6. One extension power button for Raspberry Pi 5 (Raspberry Pi 5 cotians a power button, with additional reserved pinholes for extension power buttons). 7. Size: 86mm*75mm. 8. The circuit board uses an immersion gold process, is produced in a lead-free manufacturing process, and the material is UL and RoHS certified with a fire resistance rating of 94V-0. 9. Optional metal case. 10. Optional 3D-printed base to protect your desk from scratches.9. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_68.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_69.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_70.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_71.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_72.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_73.jpg A 4G module can be installed on top of the Raspberry Pi 5 to set up a 4G router. The 4G module is an optional module. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_75.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_98.jpg {| class="wikitable" |+ !4G module !Band !4G module !Band |- |CAT 4G |• LTE FDD: Band 1/3/5/8 • LTE TDD: Band 34/38/39/40/41 |NL668-EU |• LTE FDD: Band 1/3/5/7/8/20 • WCDMA: Band 1/5/8 • GSM/GPRS/EDGE: 850/900/1800MHz |- |Qualcomm 4G/GPS |• LTE FDD: Band 1/3/5/8 • LTE TDD: Band 34/38/39/40/41 • WCDMA: Band 1/8 • TD-SCDMA: Band 34/39 • EVDO/CDMA1X: BC0 • GSM/GPRS/EDGE: 900/1800MHz(OPT) |NL668-EAU |• LTE FDD: Band 1/3/5/7/8/20/28 • LTE TDD: Band 38/40/41 • WCDMA: Band 1/5/8 • GSM/GPRS/EDGE: 850/900/1800MHz |- |NL668-AM |• Memory: 2Gb NAND+1Gb DDR • LTE FDD: B2/4/5/12/13/17/66/71 • WCDMA: B2/4/5 | | |} == '''III. Work with Raspberry Pi OS''' == Under the Raspberry Pi OS, the necessary drivers are integrated by default, so no additional driver installation is required, and you can use it directly. The version of the Raspberry Pi OS is: 2024-07-04-raspios-bookworm-arm64.img.xz You can download the Raspberry Pi OS in: https://www.raspberrypi.com/software/operating-systems/#raspberry-pi-os-64-bit === 3.1 View Ethernet === After the system starts, execute <code>ifconfig -a</code>, and the red box will indicate the extended RTL8111H Ethernet card (four Gigabit Ethernet ports): http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_51.jpg By executing <code>ifconfig -a</code>, you can see that eth0 is the built-in Ethernet port of the Raspberry Pi 5; the eth1 device is the extended RTL8111H network card (which provides four Gigabit Ethernet ports). http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_99.jpg === 3.2 Test Ethernet === Download iperf3(Windows version): http://www.mcuzone.com/down/Software.asp?ID=10000634 Install iperf3 on Linux: <code>sudo apt-get install iperf3</code> After installation, connect one of the four extended Gigabit Ethernet ports to the upstream router, and use iperf3 to test the speed with a PC within the same local network. In client mode, the speed is about 942 Mbps. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_53.jpg In server mode, the speed is about 948 Mbps. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_54.jpg It can basically achieve gigabit speed. '''''Note1: Network speed tests are affected by the network environment and testing methods. Please refer to the actual speed, as this test is for reference only.''''' '''''Note2: The four-port switch is a physical layer device, and is not visible in the system.''''' == '''IV. Work with Ubuntu OS''' == The process of loading network card drivers in Ubuntu 23.10 is relatively complex and cumbersome, and it is not recommended for use. It is recommended to use Ubuntu 24.04. The version of the Ubuntu OS is: ubuntu-24.04-preinstalled-desktop-arm64+raspi.img.xz You can download the Ubuntu OS in: https://ubuntu.com/download/raspberry-pi ===4.1 Install drivers=== On Ubuntu 24.04, you can directly download driver source code and compile it. The steps are as follows: '''Connect the native Ethernet port of the Raspberry Pi 5 to the upstream router.''' Update the system: <code>sudo apt-get update</code> http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_55.jpg Preparing the build environment: <code>sudo apt-get install --reinstall linux-headers-$(uname -r) linux-headers-generic build-essential dkms</code> http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_56.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_58.jpg Download and compile driver: <code>sudo apt install r8168-dkms</code> <code>sudo modprobe r8168</code> http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_59.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_60.jpg After the driver installation is complete, install the net-tools package: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_57.jpg After installation, you can use ifconfig. By executing <code>ifconfig -a</code>, you should see devices starting with enp, which are the four expanded Gigabit Ethernet ports. This indicates that the driver has been installed successfully. At this moment, the four extended Gigabit Ethernet ports are not connected to the upstream router, so they have not obtained IP addresses. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_61.jpg === 4.2 Test Ethernet === Install iperf3 on Linux: <code>sudo apt-get install iperf3</code> After installation, '''connect one of the four expanded Gigabit Ethernet ports to the upstream router''', restart the system, and run `ifconfig -a`. You should see that the expanded Gigabit Ethernet port has obtained an IP address. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_64.jpg Use iperf3 to test the speed with a PC within the same local network. In client mode, the speed is about 943 Mbps. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_62.jpg In server mode, the speed is about 948 Mbps. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_63.jpg It can basically achieve gigabit speed. '''''Note1: Network speed tests are affected by the network environment and testing methods. Please refer to the actual speed, as this test is for reference only.''''' '''''Note2: On an Ubuntu OS, the RTL8111H network card is recognized with a name like enxxxx, while the same switch used as a physical layer chip does not appear in the network card list.''''' == '''V. Work with OpenWrt''' == === 5.1 Overview === The MPRG4 expansion board can be configured in OpenWrt as a switch with one input and four outputs. We can configure the Raspberry Pi5's built-in Ethernet port as the WAN port, and use the four Ethernet ports on the expansion board as LAN ports, which can be used by other devices to obtain IP addresses within the same subnet. System version: openwrt-bcm27xx-bcm2712-rpi-5-squashfs-sysupgrade-linux-6.1.100-20240805.img.gz === 5.2 Preparation === We connect the Raspberry Pi 5's built-in port to the PC's Ethernet port, then power on and start the system. Afterward, we navigate to Network and Internet in the Windows settings, and under Ethernet, we open the connected network to view the IP address of the default gateway. This address is the backend configuration page address for the OpenWrt system. As shown in the image, the address tested in this article is 192.168.198.1: http://www.mcuzone.com/wiki/1006_RPi0_4G_MiniPCIe/1006_RPi0_4G_MiniPCIe_14.jpg Open a web browser, enter 192.168.198.1, and access the OpenWrt system configuration page. The default username is <code>root</code>, and the default password is <code>password</code>. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_50.jpg After logging into the OpenWrt, click on "System - TTYD Terminal", We can then access the terminal that comes with OpenWrt, and log in using the username <code>root</code> and the password <code>password</code>. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_65.jpg Run <code>ifconfig -a</code>, and you can see that the extended Gigabit Ethernet port (eth1) has been recognized: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_100.jpg === 5.3 Configure the WAN port and LAN ports === By default, the native Ethernet port (eth0) of the Raspberry Pi 5 is a LAN port. Now, we need to set the Raspberry Pi 5's native Ethernet port (eth0) as the WAN port and the extended Gigabit Ethernet port (eth1) as the LAN port. The procedure is as follows: We click on "'''Network''' - '''Interface'''". http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_23.png Then we click to '''Add a new interface''', set the name and interface protocol, and set the WAN port to eth0. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_24.png Click "'''Submit'''" and then select "'''WAN'''" in the '''Firewall settings'''. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_25.png After configuration it complete, click "'''Save'''". Be careful, do not click "Save & Apply", or you will not be able to enter the system. Click "'''Back'''" to return to the overview, then click on LAN port modification. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_26.png Set the interface to eth1 in the "Physical Settings". http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_27.png After configuration, we click "'''Save & Apply'''". Please note that since the network settings are being changed, it will continuously display "Applying changes". This is not a malfunction, and after waiting for a while, we can proceed to the next step.http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_28.png The OpenWrt is currently unavailable due to changes in the network interfaces. You need to connect the new WAN port to the upstream router, then connect the new LAN port to the downstream network devices, reboot the system, and log back into the OpenWrt. After configuration, connect the new WAN port (the native Ethernet port on the Raspberry Pi, eth0) to the upstream router, then connect the new LAN port (the extended Gigabit Ethernet port, eth1) to downstream network devices (such as PCs, etc.). Restart the system, and then log into the OpenWrt. === 5.4 Ethernet test === We will connect two of the four LAN ports to two PCs to simply test the network bandwidth. Using iperf3 to test between two computers shows that the test results are normal. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_29.png http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_30.png == '''VI. Radxa Rock 5C (RK3588S2) with MPRG4''' == === 6.1 Overview === The Radxa Rock 5C is designed based on the RK3588S2, dimensions are compatible with the Raspberry Pi 5. It have one gigabit ethernet port and four USB ports, along with a PCIe interface compatible with the Raspberry Pi 5. This interface allows us to expand with various PCIe extension boards designed for the Raspberry Pi 5. In this demonstration, we are using a MRG4 board. System version: rock-5c_bookworm_kde_b1.output.img.xz You can download it in github: https://github.com/radxa-build/rock-5c/releases/tag/rsdk-b1 http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_77.jpg === 6.2 Preparation === 1. Upon system startup, the username and login password for the default account are both <code>radxa</code>: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_78.jpg 2. Entering the system, find Konsole in the menu to access the terminal. 3. Execute <code>lspci</code> to ensure that the device information for RTL8111 is visible (the red box): http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_79.jpg (If you cannot see it, check the reliability of the FPC connection. Note that the FPC cable has an orientation, with one side indicating that it should be connected to the RPi5 on the Rock 5C ). 4. Connect the native Gigabit Ethernet port of the Radxa Rock 5C to the upstream router, then execute: <code>sudo apt-get update</code> <code>sudo apt-get upgrade</code> http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_81.jpg http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_80.jpg <code>sudo apt-get install net-tools</code> http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_82.jpg You can use the <code>ifconfig</code> after installing net-tools. Of course, you can also use other tools to operate the network. === 6.3 Install drivers and test Ethernet === Using DKMS to install the drivers. <code>sudo apt-get install r8168-dkms</code> <code>sudo modprobe r8168</code> http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_83.jpg After installing the drivers, execute <code>sudo ifconfig -a</code> to check for network cards starting with enp, which indicates the RTL8111 network card. Note that the switch is a physical layer device and cannot be seen with ifconfig. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_84.jpg Connect one of the four extended Gigabit Ethernet ports to the upstream router, restart the system, and then execute <code>sudo ifconfig -a</code>. You should see that the extended Gigabit Ethernet port has correctly obtained an IP address. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_86.jpg Confirm network connectivity by using ping packets: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_85.jpg Now, the network card drivers has been successfully installed and is functioning normally. Install iperf3 on Linux: <code>sudo apt-get install iperf3</code> After installation, '''connect one of the four expanded Gigabit Ethernet ports to the upstream router''', restart the system, use iperf3 to test the speed with a PC within the same local network. In client mode, the speed is about 942 Mbps. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_87.jpg In server mode, the speed is about 947 Mbps. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_88.jpg It can basically achieve gigabit speed. '''''Note: Network speed tests are affected by the network environment and testing methods. Please refer to the actual speed, as this test is for reference only.''''' === 6.4 Test 4G module === The 4G modules provided by our company feature driver-free, auto-dialing, system auto-recognition, and plug-and-play functionalities. The Rock 5C can be equipped with CAT4 4G and Qualcomm 4G modules, which are automatically recognized in the system as devices starting with "enx". ==== 6.4.1 Connect to 4G network ==== Connect the 4G module to the Rock 5C via the USB interface, start the system, and execute <code>lsusb</code> in the terminal. The following will be displayed, with the red box indicating the 4G module: CAT4 4G: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_89.jpg Qualcomm 4G: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_90.jpg Below is an example using the CAT4 4G module. Connect one of the native Ethernet ports of the Rock 5C and one of the four extended Gigabit Ethernet ports to the upstream router, restart the system, and then execute <code>sudo ifconfig -a</code>. The display will be as follows: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_101.jpg It shows that the IP address has been correctly obtained (as indicated in the red box). Execute <code>ip route</code>, and you can see that the device starting with "enx" is listed first, therefore prioritizing internet access through the 4G network. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_92.jpg At this point, if we ping both IP addresses and domain names, and they are successful, it indicates that the 4G module is working properly: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_93.jpg Open https://www.speedtest.cn/ to perform a speed test, and the results are as follows: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_94.jpg '''''Note: Network speed tests are affected by the network environment and testing methods. The actual speed may vary, so this test is for reference only.''''' ==== 6.4.2 Modification of Network Priority ==== Taking CAT4 4G as an example, in the previous section we checked the routing table, and by default, internet access is prioritized through the 4G network. If you want to prioritize the wired network for internet access, you can execute the following command: <code>sudo ip route del default && sudo route add -net default netmask 0.0.0.0 gw 192.168.8.1</code> Explanation of these two commands (separated by '&&'): <code>sudo ip route del default</code>: Remove the default route from the routing table. <code>sudo route add -net default netmask 0.0.0.0 gw 192.168.8.1</code>: Add the gateway of the wired network as a new default route (ensure to use the actual gateway address). After completing the execution, execute the <code>ip route</code> command to view the routing table. The current default route is the gateway of the wired network (end1 is listed first, it is the native Ethernet port of the Rock 5C.): http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_95.jpg This way, the network will default to using the wired connection. If you need to switch back to defaulting to the 4G network, please execute the following command: <code>sudo ip route del default && sudo route add -net default netmask 0.0.0.0 gw 192.168.6.1</code> Or, you can restart the system. Note that 192.168.6.1 is the default gateway for the 4G module; please refer to the actual configuration. '''''Note: After a reboot, the routing table resets. To ensure the network continues to use the wired or wireless connection as the default route post-restart, you'll need to execute <code>sudo ip route del default && sudo route add -net default netmask 0.0.0.0 gw 192.168.8.1</code> again.''''' ==== 6.4.3 AT command operation ==== Taking the CAT4 4G as an example, use <code>lsusb</code> to view USB devices, and the red box indicates the 4G module: http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_89.jpg Note down the ID value of the 4G module: 1286 4e3d. Use the following command to enable the ttyUSB serial port of the 4G module, where the value after echo is the ID value recorded earlier: <code>sudo modprobe option</code> <code>sudo sh -c 'echo 1286 4e3d > /sys/bus/usb-serial/drivers/option1/new_id'</code> After executing the above two commands, execute the following: <code>ls /dev/ttyUSB*</code> At this point, you should be able to see three devices under the dev directory: ttyUSB0, ttyUSB1, ttyUSB2. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_96.jpg Then, use a serial communication tool to open the specific serial port (AT command port): Install the serial port software minicom: <code>sudo apt-get install minicom</code> Open the AT command serial port using minicom: <code>sudo minicom -D /dev/ttyUSB1</code> (Note: Which serial port to use should be determined by the ability to enter and execute AT commands without garbled or erratic output after accessing that serial port.) If you need to view echo responses, type the command: <code>ate1</code>, then press Enter. You can continue to type other commands, and after pressing Enter, you will see the results. http://www.mcuzone.com/wiki/0001_MPRG4/MPRG4_97.jpg Common AT commands: 1) Check if the SIM card is detected: <code>at+cpin?</code> Return ready to indicate the card has been recognized, if return error, you need to check the hardware. 2) Check antenna signal quality: <code>at+csq</code> eturn values between 26 and 31 indicate a good signal, with 31 representing a full signal strength; return values between 20 and 25 indicate a barely acceptable signal; return values below 20 indicate a poor signal or that the antenna might not be connected. 3) Check network registration status: <code>at+cops?</code> Normally, it should return the network supporter's code: 7, where 7 represents 4G. Note: The above command <code>at+csq</code> should not include a question mark, while the other two commands require a question mark. 4) View the SIM card's IMEI code: <code>at+cgsn</code> 5) Reset 4G module (Sometimes, if you reinsert the SIM card, hot swapping may not work; in such cases, you can use this reset command to reset the module.): <code>at+reset</code> 6) Disable radio frequency: <code>at+cfun=0</code> Enable radio frequency: <code>at+cfun=1</code> The two commands mentioned above can be used in pairs to allow the module to re-register with the network without restarting the 4G module. ==== 6.4.4 Modify the IP address of the 4G module ==== If the default 4G IP address assigned at the factory conflicts with the IP address being used by the user, or if there is a need to modify the IP address, you can change the 4G module's IP to directly obtain a public IP. Please execute the AT command: '''CAT4 4G:''' Execute the AT command: <code>AT+ROUTEIP=<newip></code> Note: only addresses in the format of 192.168.x.1 are supported. If you set <code>AT+ROUTEIP=192.168.3.1</code>, the final IP address obtained will be 192.168.3.100. After making the changes, you need to power off and restart the system. Query current IP: <code>AT+ROUTEIP?</code>, it returns two values, the first one is the old IP, and the second one is the new IP. Test command: <code>AT+ROUTEIP=?</code> '''Qualcomm 4G:''' Set the 4G module's IP to directly obtain a public IP. Please execute the AT command: Set the IP to public: <code>AT+GTIPPASS=1</code> Set the IP to private: <code>AT+GTIPPASS=0</code> Check whether the current IP is a public or private IP: <code>AT+GTIPPASS?</code> After modifying the IP, a power cycle reboot is required for the changes to take effect. {{Contact_Us_icon}} [http://wiki.mcuzone.com/index.php?title=0001_MPRG4(Designed_based_on_Raspberry_Pi_5_PCIe)&veaction=edit T]
本页使用的模板:
模板:Contact Us icon
(
查看源代码
)
返回
0001 MPRG4 EN
。
开关有限宽度模式