Banana Pi BPI-R4 Router board with MediaTek MT7988A (Filogic 880) quad-core ARM Corex-A73 design ,4GB DDR4 RAM,8GB eMMC,128MB SPI-NAND flash onboard, also have 2x 10Gbe SFP, 4x Gbe network port,with USB3.2 port,M.2 support 4G/5G/NVME SSD.2x miniPCIe slots with PCIe3.0 2lane interface for Wi-Fi 7 NIC (Network Interface Card). It is a very high performance open source router development board.
More Infomation: Banana Pi BPI-R4 |
Prepare 8G/above TF card, USB-Serial cable, Ubuntu System
12V/2A power adapter (without any peripherals, the power consumption of BPI-R4 Main Board will not exceed 10W in the most extreme cases. but you need to determine whether you need a higher power power adapter according to your own accessory usage)
Using your USB-Serial cable(3.3V TTL,Baud=115200) Connect to debug console on BPI-R4
G=GND; RX=BPI-R4 input; TX=BPI-R4 output0
Download the image to be burned
Default IP address for LAN port: 192.168.1.1
User name/password: pi/bananapi ,root/bananapi.
Or the user is root without a password.
WIFI: AP_MTK_MT7990_2G/AP_MTK_MT7990_5G/AP_MTK_MT7990_6G
All Jumper is "1", BPI-R4 will boot from SD card
SW3-A is "0" and SW3-B is "1" , BPI-R4 will boot from SPI NAND
SW3-A is "1" and SW3-B is "0" , BPI-R4 will boot from eMMC
If the console said "system halt!", it means that the bootup storage does not cotain any OS
F0: 102B 0000
FA: 5100 0000
FA: 5100 0000 [0200]
F9: 1041 0000
F3: 1001 0000 [0200]
F3: 1001 0000
F6: 102C 0000
F5: 1026 0000
00: 1005 0000
FA: 5100 0000
FA: 5100 0000 [0200]
F9: 1041 0000
F3: 1001 0000 [0200]
F3: 1001 0000
F6: 102C 0000
01: 102A 0001
02: 1005 0000
BP: 0200 00C0 [0001]
EC: 0000 0000 [0000]
MK: 0000 0000 [0000]
T0: 0000 00D7 [0101]
System halt!
After booting the SD image using Ubuntu and Debian 6.1 kernels, the image in NAND will not start and needs to be burned again. |
Please low level format the SD and clear all data of SD. It’s very important. Otherwise, you will encounter a "jffs2" error during the startup process. |
Please follow the following diagram for Windows PC.
Linux PC, you can use the "mksf" command for formatting, or use the "dd" command to write zeros.
Burn image to SD card on windows computer
Balena Etcher is an opensource GUI flash tool by Balena, Flash OS images to SDcard or USB drive.
Click on "Flash from file" to select image.
Click on "Select target" to select USB device.
Click on "Flash!" Start burning.
Burn image to SD card on linux computer
You could download latest image from our forum
Install bpi-tools on your Ubuntu. If you can’t access this URL or any other problems, please go to bpi-tools repo and install this tools manually.
apt-get install pv
curl -sL https://github.com/BPI-SINOVOIP/bpi-tools/raw/master/bpi-tools | sudo -E bash
After you download the image, insert your TF card into your Ubuntu. Execute
bpi-copy xxx.img /dev/sdx
to install image on your TF card
After step 3, then you can insert your TF card into R4, and press power button to setup R4
Change Boot Jumper to boot from SD, Enable SD Card Device.
NAND has an image burned at the factory. If you want to use it, simply switch to the corresponding boot and then power on to start. |
When you want to Update Nand device, Firstly Change boot switch to boot from SD device and insert one SD with SD boot Image, then after boot up,you need flash one Nand image into Nand device. Finally you change bootstrap to boot from Nand device. |
Before burning image into Nand, please prepare a USB disk. Let’s take OpenWrt image (mtk-bpi-r4-NAND-20231030.img) for example, the steps are below:
Copy Nand boot OpenWrt image(mtk-bpi-r4-NAND-20231030.img) to USB disk.
Change boot switch Jumper, the board boot from SD device, then power up the board.
Plug in USB disk to the board, and mount the USB to /mnt or other directory as follows: (you can skip mounting if it is mounted automatically)
mount -t vfat /dev/sda1 /mnt
cd /mnt
Execute following command to erase the whole Nand flash and copy image to nand device:
mtd erase /dev/mtd0
dd if=mtk-bpi-r4-NAND-20231030.img of=/dev/mtdblock0
Power off BPI-R4 board, unplug u-disk driver, change bootstrap to boot from Nand device.
Because SD card and EMMC device share one SOC’s controller, it is necessary to switch to NAND startup and then burn the EMMC image into the EMMC. Finally, you will change the boot to boot from EMMC. |
Before burning image to eMMC, please prepare a USB disk. Let’s take OpenWrt image (bl2_emmc-r4.img, mtk-bpi-r4-EMMC-20231030.img) for example, the steps are below:
Copy EMMC boot OpenWrt image(bl2_emmc-r4.img,mtk-bpi-r4-EMMC-20231030.img) to USB disk, if the image is compressed please uncompress it before copying to USB disk.
Change the switch jumper to Nand and start the motherboard from Nand.
Plug in USB disk to the board, and mount the USB to /mnt or other directory as follows: (you can skip mounting if it is mounted automatically)
mount -t vfat /dev/sda1 /mnt
cd /mnt
Execute :
echo 0 > /sys/block/mmcblk0boot0/force_ro
dd if=bl2_emmc-r4.img of=/dev/mmcblk0boot0
dd if=mtk-bpi-r4-EMMC-20231030.img of=/dev/mmcblk0
mmc bootpart enable 1 1 /dev/mmcblk0
Power off R4 board, remove u-disk driver, change bootstrap to boot from emmc device.
Network-Configuration refer to: http://www.fw-web.de/dokuwiki/doku.php?id=en:bpi-r2:network:start
Network Interface: eth2, lan0 is for WAN; eth1, lan0, lan1, lan2, lan3 is for LAN, ra0/ra1 is for 2.4G wireless, rai0 is for 5G wifi6 wireless, rax0 is for 6G wifi7 wireless.
root@OpenWrt:/# ifconfig
br-lan Link encap:Ethernet HWaddr EE:A1:57:81:CA:19
inet addr:192.168.1.1 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::eca1:57ff:fe81:ca19/64 Scope:Link
inet6 addr: fd63:8bea:d5ce::1/60 Scope:Global
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:15 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:2418 (2.3 KiB)
br-wan Link encap:Ethernet HWaddr EE:A1:57:81:CA:19
inet6 addr: fe80::eca1:57ff:fe81:ca19/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:34 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:8538 (8.3 KiB)
eth0 Link encap:Ethernet HWaddr EE:A1:57:81:CA:19
inet6 addr: fe80::eca1:57ff:fe81:ca19/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:32 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:4408 (4.3 KiB)
Interrupt:124
eth1 Link encap:Ethernet HWaddr 4A:BB:84:B4:5D:3F
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:34 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:8674 (8.4 KiB)
Interrupt:124
eth2 Link encap:Ethernet HWaddr 22:02:CE:9C:92:BA
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:34 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:8674 (8.4 KiB)
Interrupt:124
lan0 Link encap:Ethernet HWaddr EE:A1:57:81:CA:19
UP BROADCAST MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
lan1 Link encap:Ethernet HWaddr EE:A1:57:81:CA:19
UP BROADCAST MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
lan2 Link encap:Ethernet HWaddr EE:A1:57:81:CA:19
UP BROADCAST MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
lan3 Link encap:Ethernet HWaddr EE:A1:57:81:CA:19
UP BROADCAST MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:56 errors:0 dropped:0 overruns:0 frame:0
TX packets:56 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:4368 (4.2 KiB) TX bytes:4368 (4.2 KiB)
ra0 Link encap:Ethernet HWaddr 00:0C:43:26:60:88
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
ra1 Link encap:Ethernet HWaddr 02:0C:43:36:60:88
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
rai0 Link encap:Ethernet HWaddr 00:0C:43:2B:B1:F8
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
rax0 Link encap:Ethernet HWaddr 0C:0C:43:26:60:D8
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
root@OpenWrt:/# brctl show br-wan
bridge name bridge id STP enabled interfaces
br-wan 7fff.eea15781ca19 no lan0, eth2
root@OpenWrt:/# brctl show br-lan
bridge name bridge id STP enabled interfaces
br-lan 7fff.eea15781ca19 no apclii0 apclix0 apcli0 ra1 rai0 rax0 lan2 eth1 ra0 lan3 lan1
root@OpenWrt:/#
The SFP serdes speed of BPI-R4 is fixed at 10Gbps, so only SFP that support this can be used!
Usually the PIN6 of 10G SFP+ module is GND. After inserting the module, SFP_MOD_DEF0 will be pulled low, thereby turning on the SFP power supply.
Therefore, if this PIN of the module is not GND, 3.3V_SFP power will not be supplied!
The temperature of this module is very high when used for a long time, It can reach 90℃ without a heat sink or cooling fan. Be careful to prevent burns!
root@R4CN:/# [ 67.870063] sfp sfp@0: SM: enter empty:up:down event insert
[ 67.875642] sfp sfp@0: SM: exit probe:up:down
[ 68.199179] sfp sfp@0: SM: enter probe:up:down event timeout
[ 68.215970] sfp sfp@0: module OEM SFP-10G-T rev 10 sn 2309250003 dc 230925
[ 68.225443] sfp sfp@0: module OEM SFP-10G-T rev 10 has been found in the quirk list
[ 68.235004] sfp sfp@0: sfp: support mode 00,00000800,00007040
[ 68.240749] sfp sfp@0: tx disable 1 -> 0
[ 68.244681] sfp sfp@0: SM: exit present:up:wait
[ 68.343638] sfp sfp@0: SM: enter present:up:wait event los_high
[ 68.349549] sfp sfp@0: SM: exit present:up:wait
[ 82.476711] sfp sfp@0: SM: enter present:up:wait event los_low
[ 82.482550] sfp sfp@0: SM: exit present:up:wait
[ 83.584504] alloc new entry for 18:f2:2c:6f:45:3e, interface:eth2
[ 83.590595] recv intf mac ae:19:d1:7e:2a:74
[ 95.271188] sfp sfp@0: SM: enter present:up:wait event timeout
[ 95.277715] sfp sfp@0: probing phy device through the [MDIO_I2C_ROLLBALL] protocol
[ 95.821247] sfp sfp@0: CL45 PHY device [0x31c3:0x1c13] found!
[ 95.826999] sfp sfp@0: CL45 PHY device [0x31c3:0x1c13] found!
[ 95.832741] sfp sfp@0: CL45 PHY device [0x31c3:0x1c13] found!
[ 95.838479] sfp sfp@0: CL45 PHY device [0x31c3:0x1c13] found!
[ 95.844217] sfp sfp@0: CL45 PHY driver [Aquantia AQR113C] found!
[ 95.850215] sfp sfp@0: phy: support mode 00,00018000,000e706c
[ 95.855960] mtk_soc_eth 15100000.ethernet eth2: requesting link mode inband/10gbase-kr with support 00,00018000,000a7068
[ 96.273193] mtk_soc_eth 15100000.ethernet eth2: PHY [i2c:sfp@0:11] driver [Aquantia AQR113C]
[ 96.357199] sfp sfp@0: SM: exit present:up:link_up
[ 96.357206] mtk_soc_eth 15100000.ethernet eth2: resolve link status: system iface=1, line iface=0
[ 96.630718] sfp sfp@0: SM: enter present:up:link_up event los_high
[ 96.636904] sfp sfp@0: SM: exit present:up:wait_los
[ 101.395228] sfp sfp@0: SM: enter present:up:wait_los event los_low
[ 101.401416] sfp sfp@0: SM: exit present:up:link_up
[ 101.401426] mtk_soc_eth 15100000.ethernet eth2: resolve link status: system iface=1, line iface=0
[ 101.696172] mtk_soc_eth 15100000.ethernet eth2: Link is Up - 10Gbps/Full - flow control off
[ 101.704534] br-wan: port 2(eth2) entered blocking state
[ 101.709754] br-wan: port 2(eth2) entered forwarding state
root@R4CN:/#
root@R4CN:/# i2cdetect -y 3
0 1 2 3 4 5 6 7 8 9 a b c d e f
00: -- -- -- -- -- -- -- --
10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
50: 50 51 -- -- -- -- 56 -- -- -- -- -- -- -- -- --
60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
70: UU -- -- -- -- -- -- --
root@R4CN:/#
root@R4CN:/# ethtool eth2
Settings for eth2:
Supported ports: [ ]
Supported link modes: 100baseT/Full
1000baseT/Full
10000baseT/Full
1000baseKX/Full
10000baseKR/Full
2500baseT/Full
5000baseT/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 100baseT/Full
1000baseT/Full
10000baseT/Full
1000baseKX/Full
10000baseKR/Full
2500baseT/Full
5000baseT/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Link partner advertised link modes: 10baseT/Full
100baseT/Full
1000baseT/Full
10000baseT/Full
2500baseT/Full
5000baseT/Full
Link partner advertised pause frame use: No
Link partner advertised auto-negotiation: Yes
Link partner advertised FEC modes: Not reported
Speed: 10000Mb/s
Duplex: Full
Port: MII
PHYAD: 17
Transceiver: external
Auto-negotiation: on
Current message level: 0x000000ff (255)
drv probe link timer ifdown ifup rx_err tx_err
Link detected: yes
root@R4CN:/#
Note:Do not pull out this module once it is inserted, otherwise it will cause BPI-R4 to reboot.This phenomenon does not exist with other modules. |
root@R4CN:/# [ 201.763041] mapfilter:drop IP addr timeout! stop dropping IP addr.
[ 499.938345] sfp sfp@0: SM: enter present:up:link_up event los_high
[ 499.950712] mtk_soc_eth 15100000.ethernet eth2: Link is Down
[ 499.956370] sfp sfp@0: SM: exit present:up:wait_los
[ 499.961367] br-wan: port 2(eth2) entered disabled state
[ 502.867442] sfp sfp@0: SM: enter present:up:wait_los event remove
[ 502.873705] sfp sfp@0: module removed
[ 502.877937] sfp sfp@0: tx disable 0 -> 1
[ 502.881872] sfp sfp@0: SM: exit empty:up:down
[ 503.164077] Unable to handle kernel NULL pointer dereference at virtual address 0000000000000180
[ 503.172853] Mem abort info:
[ 503.175634] ESR = 0x96000006
[ 503.178683] EC = 0x25: DABT (current EL), IL = 32 bits
[ 503.183985] SET = 0, FnV = 0
[ 503.187030] EA = 0, S1PTW = 0
[ 503.190162] Data abort info:
[ 503.193035] ISV = 0, ISS = 0x00000006
[ 503.196861] CM = 0, WnR = 0
[ 503.199816] user pgtable: 4k pages, 39-bit VAs, pgdp=000000012fd21000
[ 503.206246] [0000000000000180] pgd=0000000132bfb003, pud=0000000132bfb003, pmd=0000000000000000
[ 503.214936] Internal error: Oops: 96000006 [#1] SMP
[ 503.219799] Modules linked in: ksmbd mt7991(P) mt7990(P) iptable_nat ipt_REJECT xt_time xt_tcpudp xt_state xt_socket xt_recent xt_policy xt_nat xt_multiport xt_mark xt_mac xt_limit xt_iprange xt_helper xt_esp xt_conntrack xt_connmark xt_connlimit xt_connbytes xt_comment xt_TPROXY xt_TCPMSS xt_REDIRECT xt_MASQUERADE xt_LOG xt_FLOWOFFLOAD xt_CT usblp ts_fsm ts_bm spidev rfcomm pptp ppp_mppe nf_tproxy_ipv6 nf_tproxy_ipv4 nf_socket_ipv6 nf_socket_ipv4 nf_reject_ipv4 nf_nat_tftp nf_nat_snmp_basic nf_nat_sip nf_nat_pptp nf_nat_irc nf_nat_h323 nf_nat_amanda nf_nat nf_log_ipv4 nf_flow_table_hw nf_flow_table nf_conntrack_tftp nf_conntrack_snmp nf_conntrack_sip nf_conntrack_pptp nf_conntrack_netlink nf_conntrack_irc nf_conntrack_h323 nf_conntrack_broadcast ts_kmp nf_conntrack_amanda nf_conncount mtqos mtfwd mapfilter libcrc32c l2tp_ppp iptable_raw iptable_mangle iptable_filter ipt_ah ip_tables hidp btusb btintel bnep asn1_decoder mt7990_dbg(P) mtk_wed(P) mtk_pci(P) connac_if(P) mtk_hwifi(P)
[ 503.219869] mt_wifi(P) hid mt_wifi_cmn evdev input_core cfg80211 compat xt_set ip_set_list_set ip_set_hash_netportnet ip_set_hash_netport ip_set_hash_netnet ip_set_hash_netiface ip_set_hash_net ip_set_hash_mac ip_set_hash_ipportnet ip_set_hash_ipportip ip_set_hash_ipport ip_set_hash_ipmark ip_set_hash_ip ip_set_bitmap_port ip_set_bitmap_ipmac ip_set_bitmap_ip ip_set nfnetlink nf_log_ipv6 nf_log_common ip6table_mangle ip6table_filter ip6_tables ip6t_REJECT x_tables nf_reject_ipv6 nfsd ip6_gre ip_gre gre l2tp_netlink l2tp_core udp_tunnel ip6_udp_tunnel ipcomp6 xfrm6_tunnel esp6 ah6 ip6_tunnel tunnel6 ip_tunnel rpcsec_gss_krb5 auth_rpcgss oid_registry af_key lockd sunrpc grace autofs4 dm_mirror dm_region_hash dm_log dm_crypt nls_utf8 nls_iso8859_1 nls_cp437 macsec seqiv md4 ghash_generic gf128mul gcm cts ctr ccm arc4 mtk_warp mtkhnat leds_gpio xhci_plat_hcd ohci_platform ohci_hcd fsl_mph_dr_of ehci_platform ehci_fsl ehci_hcd gpio_button_hotplug
[ 503.390068] CPU: 2 PID: 7304 Comm: aqr107_mib_thre Tainted: P 5.4.246 #0
[ 503.398227] Hardware name: Bananapi BPI-R4 (DT)
[ 503.402746] pstate: 80000005 (Nzcv daif -PAN -UAO)
[ 503.407531] pc : __phy_read_mmd+0x20/0xa0
[ 503.411529] lr : phy_read_mmd+0x38/0x60
[ 503.415351] sp : ffffffc01388bd90
[ 503.418653] x29: ffffffc01388bd90 x28: 0000000000000000
[ 503.423952] x27: ffffff80f2ae3638 x26: ffffffc010a373c0
[ 503.429250] x25: ffffffc010557918 x24: ffffff80f4ce8800
[ 503.434547] x23: ffffffc010d83908 x22: ffffffc01388be3c
[ 503.439845] x21: 000000000000e811 x20: 0000000000000003
[ 503.445142] x19: ffffff80f4ce8800 x18: ffffffc010c0a1a8
[ 503.450440] x17: 000000000000003c x16: 000000000000003c
[ 503.455738] x15: 0000000000000018 x14: 00000000fffbd1b0
[ 503.461035] x13: 00000000000001f4 x12: ffffffc010c0a160
[ 503.466332] x11: 000000000000c503 x10: 0000000000000830
[ 503.471630] x9 : ffffffc01388bd10 x8 : ffffff80efda0890
[ 503.476927] x7 : ffffffc0eec26000 x6 : ffffffc0eec26000
[ 503.482224] x5 : 0000000000000000 x4 : 0000000000000000
[ 503.487522] x3 : ffffff80f4ce8800 x2 : 000000000000e811
[ 503.492819] x1 : 0000000000000003 x0 : ffffff80f4ce8800
[ 503.498117] Call trace:
[ 503.500553] __phy_read_mmd+0x20/0xa0
[ 503.504202] phy_read_mmd+0x38/0x60
[ 503.507680] aqr107_mib_read_word+0x2c/0x60
[ 503.511850] aqr107_mib_read+0x24/0x200
[ 503.515673] aqr107_mib_thread+0x20/0x50
[ 503.519585] kthread+0x120/0x128
[ 503.522801] ret_from_fork+0x10/0x1c
[ 503.526368] Code: a9be7bfd aa0003e3 910003fd f9418005 (f940c0a5)
[ 503.532447] ---[ end trace 3fa317a53584315f ]---
[ 503.538554] Kernel panic - not syncing: Fatal exception
[ 503.543768] SMP: stopping secondary CPUs
[ 503.547680] Kernel Offset: disabled
[ 503.551155] CPU features: 0x10002,20002008
[ 503.555238] Memory Limit: none
[ 503.559792] Starting Memory dump SMCC
[ 503.563452] Memory dump SMCC failed
[ 503.566929] Rebooting in 3 seconds..
root@R4CN:/# [ 455.370399] sfp sfp@1: SM: enter empty:up:down event insert
[ 455.375999] sfp sfp@1: SM: exit probe:up:down
[ 455.687021] sfp sfp@1: SM: enter probe:up:down event timeout
[ 455.703815] sfp sfp@1: module OEM SFP-10G-BX20-U rev 1.0 sn 2309250008 dc 230925
[ 455.713292] sfp sfp@1: sfp: support mode 00,00001000,00006040
[ 455.719042] mtk_soc_eth 15100000.ethernet eth1: requesting link mode inband/10gbase-kr with support 00,00001000,00006440
[ 455.740862] sfp sfp@1: tx disable 1 -> 0
[ 455.744792] sfp sfp@1: SM: exit present:up:wait
[ 455.799020] sfp sfp@1: SM: enter present:up:wait event timeout
[ 455.804849] sfp sfp@1: probing phy device through the [MDIO_I2C_NONE] protocol
[ 455.812066] sfp sfp@1: SM: exit present:up:link_up
[ 455.833979] mtk_soc_eth 15100000.ethernet eth1: resolve link status: system iface=0
[ 455.843477] sfp sfp@1: SM: enter present:up:link_up event los_high
[ 455.849657] sfp sfp@1: SM: exit present:up:wait_los
[ 476.904686] sfp sfp@1: SM: enter present:up:wait_los event los_low
[ 476.910875] sfp sfp@1: SM: exit present:up:link_up
[ 476.941863] mtk_soc_eth 15100000.ethernet eth1: Link is Up - 10Gbps/Full - flow control off
[ 476.950225] br-lan: port 4(eth1) entered blocking state
[ 476.955445] br-lan: port 4(eth1) entered forwarding state
[ 477.784529] alloc new entry for 18:f2:2c:6f:45:3e, interface:eth1
[ 477.790622] recv intf mac 76:38:02:df:74:7f
root@R4CN:/#
root@R4CN:/# i2cdetect -y 4
0 1 2 3 4 5 6 7 8 9 a b c d e f
00: -- -- -- -- -- -- -- --
10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
20: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
50: 50 51 -- -- -- -- -- -- -- -- -- -- -- -- -- --
60: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
70: UU -- -- -- -- -- -- --
root@R4CN:/#
root@R4CN:/# ethtool eth1
Settings for eth1:
Supported ports: [ FIBRE ]
Supported link modes: 10000baseLR/Full
Supported pause frame use: Symmetric Receive-only
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 10000baseLR/Full
Advertised pause frame use: Symmetric Receive-only
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Speed: 10000Mb/s
Duplex: Full
Port: FIBRE
PHYAD: 0
Transceiver: internal
Auto-negotiation: on
Current message level: 0x000000ff (255)
drv probe link timer ifdown ifup rx_err tx_err
Link detected: yes
root@R4CN:/#
Please do not insert the card tray into the slot when the SIM card is not installed, otherwise it will easily damage the slot. |
BPI-R4 supports M.2 USB Interface 4G LTE/5G Modules: Quectel EM05, RM500U-CN ,RM500Q-GL& RM520N-GL
If you want to use M.2 Cellular Module on BPI-R4:
Install 4G/5G Cellular Module into CN16 Slot(M.2 KEYB)
Inset NANOSIM Card into SIMSlot(SIM1) with card tray(pay attention to the direction)
Install antenna on the module
After powering on, it will automatically dial
The availability of 4G/5G depends on the local carrier frequency band. |
Quectel RM520N-GL
Quectel RM520N-GL
wwan0 Link encap:Ethernet HWaddr A6:35:F7:7A:9E:A7
inet6 addr: fe80::a435:f7ff:fe7a:9ea7/64 Scope:Link
UP RUNNING NOARP MTU:1500 Metric:1
RX packets:4 errors:0 dropped:0 overruns:0 frame:0
TX packets:9 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:1272 (1.2 KiB) TX bytes:1932 (1.8 KiB)
wwan0_1 Link encap:Ethernet HWaddr A6:35:F7:7A:9E:A7
inet addr:10.46.121.135 Mask:255.255.255.240
inet6 addr: fe80::a435:f7ff:fe7a:9ea7/64 Scope:Link
UP RUNNING NOARP MTU:1500 Metric:1
RX packets:4 errors:0 dropped:0 overruns:0 frame:0
TX packets:9 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:1292 (1.2 KiB) TX bytes:1932 (1.8 KiB)
root@R4CN:/#
root@R4CN:/# lsusb
Bus 002 Device 003: ID 2c7c:0801 Quectel RM520N-GL
Bus 002 Device 002: ID 2109:0822 VIA Labs, Inc. USB3.1 Hub
Bus 002 Device 001: ID 1d6b:0003 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 001 Device 003: ID 2109:8822 VIA Labs, Inc. USB Billboard Device
Bus 001 Device 002: ID 2109:2822 VIA Labs, Inc. USB2.0 Hub
Bus 001 Device 001: ID 1d6b:0002 Linux 5.4.246 xhci-hcd xHCI Host Controller
root@R4CN:/#
root@R4CN:/# ping www.baidu.com
PING www.baidu.com (120.232.145.185): 56 data bytes
64 bytes from 120.232.145.185: seq=0 ttl=52 time=30.712 ms
64 bytes from 120.232.145.185: seq=1 ttl=52 time=32.774 ms
64 bytes from 120.232.145.185: seq=2 ttl=52 time=45.222 ms
64 bytes from 120.232.145.185: seq=3 ttl=52 time=37.850 ms
64 bytes from 120.232.145.185: seq=4 ttl=52 time=53.459 ms
^C
--- www.baidu.com ping statistics ---
5 packets transmitted, 5 packets received, 0% packet loss
round-trip min/avg/max = 30.712/40.003/53.459 ms
root@R4CN:/#
RM500U-CN
usb0 Link encap:Ethernet HWaddr 5E:3B:9C:76:7C:46
inet addr:10.95.9.23 Bcast:10.95.9.255 Mask:255.255.255.0
inet6 addr: fe80::5c3b:9cff:fe76:7c46/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:34 errors:0 dropped:0 overruns:0 frame:0
TX packets:62 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:7908 (7.7 KiB) TX bytes:10100 (9.8 KiB)
root@R4CN:/#
root@R4CN:/# lsusb
Bus 002 Device 003: ID 2c7c:0900 Quectel RM500U-CN
Bus 002 Device 002: ID 2109:0822 VIA Labs, Inc. USB3.1 Hub
Bus 002 Device 001: ID 1d6b:0003 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 001 Device 003: ID 2109:8822 VIA Labs, Inc. USB Billboard Device
Bus 001 Device 002: ID 2109:2822 VIA Labs, Inc. USB2.0 Hub
Bus 001 Device 001: ID 1d6b:0002 Linux 5.4.246 xhci-hcd xHCI Host Controller
root@R4CN:/#
root@R4CN:/# ping www.baidu.com
PING www.baidu.com (2409:8c54:870:34e:0:ff:b024:1916): 56 data bytes
64 bytes from 2409:8c54:870:34e:0:ff:b024:1916: seq=0 ttl=51 time=55.105 ms
64 bytes from 2409:8c54:870:34e:0:ff:b024:1916: seq=1 ttl=51 time=38.725 ms
64 bytes from 2409:8c54:870:34e:0:ff:b024:1916: seq=2 ttl=51 time=39.890 ms
^C
--- www.baidu.com ping statistics ---
3 packets transmitted, 3 packets received, 0% packet loss
round-trip min/avg/max = 38.725/44.573/55.105 ms
root@R4CN:/#
EM05-CE
wwan0 Link encap:Ethernet HWaddr F2:CC:52:10:2E:27
inet addr:10.21.103.116 Bcast:0.0.0.0 Mask:255.255.255.248
inet6 addr: fe80::f0cc:52ff:fe10:2e27/64 Scope:Link
UP BROADCAST RUNNING NOARP MULTICAST MTU:1500 Metric:1
RX packets:56 errors:0 dropped:0 overruns:0 frame:0
TX packets:91 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:7868 (7.6 KiB) TX bytes:10133 (9.8 KiB)
root@R4CN:/#
root@R4CN:/# lsusb
Bus 001 Device 012: ID 2c7c:0125 Quectel Incorporated LTE Module
Bus 002 Device 002: ID 2109:0822 VIA Labs, Inc. USB3.1 Hub
Bus 002 Device 001: ID 1d6b:0003 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 001 Device 003: ID 2109:8822 VIA Labs, Inc. USB Billboard Device
Bus 001 Device 002: ID 2109:2822 VIA Labs, Inc. USB2.0 Hub
Bus 001 Device 001: ID 1d6b:0002 Linux 5.4.246 xhci-hcd xHCI Host Controller
root@R4CN:/#
root@R4CN:/# ping www.baidu.com
PING www.baidu.com (120.232.145.144): 56 data bytes
64 bytes from 120.232.145.144: seq=0 ttl=53 time=47.085 ms
64 bytes from 120.232.145.144: seq=1 ttl=53 time=36.447 ms
^C
--- www.baidu.com ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss
round-trip min/avg/max = 36.447/41.766/47.085 ms
root@R4CN:/#
Theoretically, it also supports PCIe cellular modules, but it has not been tested
BPI-R4 supports MiniPCIe USB Interface 4G LTE Module :Quectel EC25
If you want to use MiniPCIe Cellular Module on BPI-R4:
Install 4G Cellular Module into CN12 Slot
Inset NANOSIM Card into SIMSlot(SIM2) with card tray(pay attention to the direction)
Install antenna on the module
After powering on, it will automatically dial
CN14 (SIM3) is also available
The availability of 4G depends on the local carrier frequency band. |
Due to the compatibility of the BPI-R4 with Qualcomm/Unisoc modules, the EC25 module cannot directly access the DNS server and connect to the internet. Therefore, manual configuration is required to modify the default.script file via console port.
vim /usr/share/udhcpc/default.script
Add: echo "nameserver 202.96.128.86" >> /etc/resolv.conf
echo "nameserver 202.96.128.86" >> /etc/resolv.conf
Modify the IP address according to your local DNS server. |
EC25-E
wwan0 Link encap:Ethernet HWaddr 12:19:B1:54:2E:04
inet addr:10.41.254.97 Mask:255.255.255.252
inet6 addr: fe80::1019:b1ff:fe54:2e04/64 Scope:Link
UP RUNNING NOARP MTU:1500 Metric:1
RX packets:12 errors:0 dropped:0 overruns:0 frame:0
TX packets:24 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:1623 (1.5 KiB) TX bytes:2222 (2.1 KiB)
root@Simon-R4:/#
root@Simon-R4:/# lsusb
Bus 001 Device 004: ID 2c7c:0125 Android Android
Bus 002 Device 002: ID 2109:0822 VIA Labs, Inc. USB3.1 Hub
Bus 002 Device 001: ID 1d6b:0003 Linux 5.4.260 xhci-hcd xHCI Host Controller
Bus 001 Device 003: ID 2109:8822 VIA Labs, Inc. USB Billboard Device
Bus 001 Device 002: ID 2109:2822 VIA Labs, Inc. USB2.0 Hub
Bus 001 Device 001: ID 1d6b:0002 Linux 5.4.260 xhci-hcd xHCI Host Controller
root@Simon-R4:/#
root@Simon-R4:/# ping www.baidu.com
PING www.baidu.com (183.2.172.42): 56 data bytes
64 bytes from 183.2.172.42: seq=0 ttl=52 time=24.309 ms
64 bytes from 183.2.172.42: seq=1 ttl=52 time=55.576 ms
64 bytes from 183.2.172.42: seq=2 ttl=52 time=55.507 ms
64 bytes from 183.2.172.42: seq=3 ttl=52 time=39.399 ms
64 bytes from 183.2.172.42: seq=4 ttl=52 time=31.386 ms
^C
--- www.baidu.com ping statistics ---
5 packets transmitted, 5 packets received, 0% packet loss
round-trip min/avg/max = 24.309/41.235/55.576 ms
root@Simon-R4:/#
Please insert one M.2 KeyM SSD(PCIe interface) into KeyM slot(CN18).
No compatibility testing has been done and there is no guarantee that all SSDs can be used. |
Knowning issue: Due to the influence of R228 and R230, after inserting certain SSD, it will affect the reading and writing of I2C. These two resistors will be removed in subsequent production batches. |
root@R4CN:/# lspci
0002:00:00.0 PCI bridge: MEDIATEK Corp. Device 7988 (rev 01)
0002:01:00.0 Non-Volatile memory controller: KIOXIA Corporation Device 0001
0004:00:00.0 Unclassified device [0002]: MEDIATEK Corp. Device 7981
root@R4CN:/#
root@R4CN:/#
root@R4CN:/# cat /proc/partitions
major minor #blocks name
31 0 131072 mtdblock0
259 0 125034840 nvme0n1
259 1 125033472 nvme0n1p1
31 1 1024 mtdblock1
31 2 512 mtdblock2
31 3 4096 mtdblock3
31 4 2048 mtdblock4
31 5 115200 mtdblock5
179 0 7634944 mmcblk0
253 0 56172 ubiblock0_1
root@R4CN:/#
BPI-R4 supports JMicron’s JMB585 (PCIe to 5x SATA chip)
root@R4CN:/# lspci
0002:00:00.0 PCI bridge: MEDIATEK Corp. Device 7988 (rev 01)
0002:01:00.0 SATA controller: JMicron Technology Corp. JMB58x AHCI SATA controller
0004:00:00.0 Unclassified device [0002]: MEDIATEK Corp. Device 7981
root@R4CN:/#
root@R4CN:/# [ 743.794932] ata1: SATA link up 1.5 Gbps (SStatus 113 SControl 300)
[ 743.802031] ata1.00: HPA detected: current 234439535, native 234441648
[ 743.808746] ata1.00: ATA-8: Hitachi HTS542512K9SA00, BB2OC31P, max UDMA/133
[ 743.815699] ata1.00: 234439535 sectors, multi 0: LBA48 NCQ (depth 32), AA
[ 743.823749] ata1.00: configured for UDMA/133
[ 743.828182] scsi 0:0:0:0: Direct-Access ATA Hitachi HTS54251 C31P PQ: 0 ANSI: 5
[ 743.836710] sd 0:0:0:0: [sda] 234439535 512-byte logical blocks: (120 GB/112 GiB)
[ 743.844204] sd 0:0:0:0: [sda] Write Protect is off
[ 743.848992] sd 0:0:0:0: [sda] Mode Sense: 00 3a 00 00
[ 743.854075] sd 0:0:0:0: [sda] Write cache: enabled, read cache: enabled, doesn't support DPO or FUA
[ 744.221268] sda: sda1 sda2
[ 744.224485] sd 0:0:0:0: [sda] Attached SCSI disk
[ 744.459896] EXT4-fs (sda1): The kernel was not built with CONFIG_QUOTA and CONFIG_QFMT_V2
root@R4CN:/#
root@R4CN:/#
root@R4CN:/# cat /proc/partitions
major minor #blocks name
31 0 131072 mtdblock0
31 1 1024 mtdblock1
31 2 512 mtdblock2
31 3 4096 mtdblock3
31 4 2048 mtdblock4
31 5 115200 mtdblock5
179 0 7634944 mmcblk0
253 0 56172 ubiblock0_1
8 0 117219767 sda
8 1 8388608 sda1
8 2 2097152 sda2
root@R4CN:/#
BPI-R4 Also supports ASMedia’s ASM2142. But this module requires an additional 5V power supply.
root@R4CN:/# lspci
0002:00:00.0 PCI bridge: MEDIATEK Corp. Device 7988 (rev 01)
0002:01:00.0 USB controller: ASMedia Technology Inc. ASM2142 USB 3.1 Host Controller
0004:00:00.0 Unclassified device [0002]: MEDIATEK Corp. Device 7981
root@R4CN:/#
root@R4CN:/# lsusb
Bus 002 Device 001: ID 1d6b:0003 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 003 Device 003: ID 2109:8822 VIA Labs, Inc. USB Billboard Device
Bus 003 Device 002: ID 2109:2822 VIA Labs, Inc. USB2.0 Hub
Bus 004 Device 002: ID 2109:0822 VIA Labs, Inc. USB3.1 Hub
Bus 004 Device 001: ID 1d6b:0003 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 001 Device 001: ID 1d6b:0002 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 003 Device 001: ID 1d6b:0002 Linux 5.4.246 xhci-hcd xHCI Host Controller
root@R4CN:/#
root@R4CN:/# [ 65.031157] usb 1-2: new high-speed USB device number 2 using xhci_hcd
[ 65.312671] usb-storage 1-2:1.0: USB Mass Storage device detected
[ 65.318899] scsi host0: usb-storage 1-2:1.0
[ 66.341397] scsi 0:0:0:0: Direct-Access HIKSEMI MD202 1.00 PQ: 0 ANSI: 6
[ 66.351211] sd 0:0:0:0: [sda] 250069680 512-byte logical blocks: (128 GB/119 GiB)
[ 66.359500] sd 0:0:0:0: [sda] Write Protect is off
[ 66.364288] sd 0:0:0:0: [sda] Mode Sense: 37 00 00 08
[ 66.370127] sd 0:0:0:0: [sda] Write cache: disabled, read cache: enabled, doesn't support DPO or FUA
[ 66.399133] sda: sda1 sda2
[ 66.405370] sd 0:0:0:0: [sda] Attached SCSI disk
[ 66.567935] [EXFAT] trying to mount...
[ 66.596276] [EXFAT] mounted successfully
[ 66.688447] FAT-fs (sda2): utf8 is not a recommended IO charset for FAT filesystems, filesystem will be case sensitive!
[ 66.705213] FAT-fs (sda2): Volume was not properly unmounted. Some data may be corrupt. Please run fsck.
root@R4CN:/#
root@R4CN:/# lsusb
Bus 001 Device 002: ID 0bda:9210 HIKSEMI MD202
Bus 002 Device 001: ID 1d6b:0003 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 003 Device 003: ID 2109:8822 VIA Labs, Inc. USB Billboard Device
Bus 003 Device 002: ID 2109:2822 VIA Labs, Inc. USB2.0 Hub
Bus 004 Device 002: ID 2109:0822 VIA Labs, Inc. USB3.1 Hub
Bus 004 Device 001: ID 1d6b:0003 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 001 Device 001: ID 1d6b:0002 Linux 5.4.246 xhci-hcd xHCI Host Controller
Bus 003 Device 001: ID 1d6b:0002 Linux 5.4.246 xhci-hcd xHCI Host Controller
root@R4CN:/#
root@R4CN:/#
root@R4CN:/# cat /proc/partitions
major minor #blocks name
31 0 131072 mtdblock0
31 1 1024 mtdblock1
31 2 512 mtdblock2
31 3 4096 mtdblock3
31 4 2048 mtdblock4
31 5 115200 mtdblock5
179 0 7634944 mmcblk0
253 0 56172 ubiblock0_1
8 0 125034840 sda
8 1 125001048 sda1
8 2 32768 sda2
root@R4CN:/#
This module can be used on M.2 KEYB Slot (but the module size2260 and has no place to fix it)
root@R4CN:/# lspci
0003:00:00.0 PCI bridge: MEDIATEK Corp. Device 7988 (rev 01)
0003:01:00.0 USB controller: ASMedia Technology Inc. ASM2142 USB 3.1 Host Controller
0004:00:00.0 Unclassified device [0002]: MEDIATEK Corp. Device 7981
Device - RTL9210 M.2 NVME Adapter + SAMSUNG PCIe SSD PM981A
OS - ubuntu-24.04-server-bpi-r4-5.4-aarch64-sd-emmc
SpeedTest on PC:
SpeedTest on BPI-R4:
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1# dd if=HD.Club.mp4 of=/dev/null
7175971+1 records in
7175971+1 records out
3674097294 bytes (3.7 GB, 3.4 GiB) copied, 9.09406 s, 404 MB/s
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1# dd if=HD.Club.mp4 of=/dev/null
7175971+1 records in
7175971+1 records out
3674097294 bytes (3.7 GB, 3.4 GiB) copied, 7.19301 s, 511 MB/s
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1# dd if=HD.Club.mp4 of=/dev/null
7175971+1 records in
7175971+1 records out
3674097294 bytes (3.7 GB, 3.4 GiB) copied, 7.12881 s, 515 MB/s
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1# dd if=/dev/zero of=./test.img bs=1024M count=5
5+0 records in
5+0 records out
5368709120 bytes (5.4 GB, 5.0 GiB) copied, 14.5756 s, 368 MB/s
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1# dd if=HD.Club.mp4 of=/dev/null
7175971+1 records in
7175971+1 records out
3674097294 bytes (3.7 GB, 3.4 GiB) copied, 10.249 s, 358 MB/s
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1#
root@BPI-R4:/mnt/sda1# dd if=HD.Club.mp4 of=/dev/null
7175971+1 records in
7175971+1 records out
3674097294 bytes (3.7 GB, 3.4 GiB) copied, 7.24647 s, 507 MB/s
root@BPI-R4:/mnt/sda1#
You can insert the BPI-R4-NIC into CN12 and CN14 at the bottom of BPI-R4-Main, and then fix it with two M2 screws.
The BPI-R4-NIC module requires 12V power supply, so the power supply on the BPI-R4-Main must be turned on before powering on (SW4 is turned to the "ON" position, and the 12V LED will lights up when power on)
The 12V power supply will be supplied to the BPI-R4-NIC through PIN6/28/48 of the miniPCI socket. When plugging in other modules, be sure to turn off SW4 if you cannot confirm whether the module can withstand 12V. |
BPI-R4-NIC-BE14 : MT7995AV+MT7976CN+MT7977IAN
root@R4RN:/# lspci
0000:00:00.0 PCI bridge: MEDIATEK Corp. Device 7988 (rev 01)
0000:01:00.0 Network controller: MEDIATEK Corp. Device 7990
0001:00:00.0 PCI bridge: MEDIATEK Corp. Device 7988 (rev 01)
0001:01:00.0 Network controller: MEDIATEK Corp. Device 7991
0004:00:00.0 Unclassified device [0002]: MEDIATEK Corp. Device 7981
root@R4RN:/# ifconfig
ra0 Link encap:Ethernet HWaddr 00:0C:43:26:60:A8
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:10 errors:10 dropped:0 overruns:0 frame:0
TX packets:46 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:320 (320.0 B) TX bytes:1184 (1.1 KiB)
rai0 Link encap:Ethernet HWaddr 00:0C:43:26:60:B8
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:1290969 errors:51890 dropped:0 overruns:0 frame:0
TX packets:17549107 errors:254037 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:363742528 (346.8 MiB) TX bytes:25491834560 (23.7 GiB)
rax0 Link encap:Ethernet HWaddr 00:0C:43:26:60:28
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:563140 errors:187 dropped:0 overruns:0 frame:0
TX packets:1683329 errors:11607 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:785902144 (749.4 MiB) TX bytes:2175529280 (2.0 GiB)
OpenWRT MTK MP4.0 WiFi Setting:
When all functions are OK, we can detect Three SSIDs and the three blue LEDs on BE14 will also light up.
Open web and configure the corresponding STA hotspot in config. And click Connect to connect.
In the debugging serial port to see whether the open interface.
ifconfig
Try ping.
brctl show br-lan
It can be seen that the interface is bridged on the br-lan port and needs to be changed to the br-wan.
brctl delif br-lan apcli0
Remove the bridge on the br-lan.
brctl addif br-lan apcli0
Add bridging on br-wan.
At this point, ping the public network will succeed.
At present, the driver supports 6G AP, but the open source nmcli toolkit does not support 6G AP, waiting for the open source organization to update, 6G STA can support. |
Add interface wlan0 first.
root@BPI-R4:~# sudo iw phy phy0 interface add wlan0 type __ap
root@BPI-R4:~# ifconfig wlan0
wlan0: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
ether 00:0c:43:26:60:10 txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
Enable WiFi, and set WiFi name, AP mode, etc.
root@BPI-R4:~# sudo nmcli radio wifi on
root@BPI-R4:~# sudo nmcli c add type wifi ifname wlan0 con-name test24G autoconnect no ssid hotspotname24G
Connection 'test24G' (02558bf7-6a8f-494d-a680-457985d03021) successfully added.
root@BPI-R4:~# sudo nmcli connection modify test24G 802-11-wireless.mode ap 802-11-wireless.band bg ipv4.method shared
Set WiFi encryption and password.
root@BPI-R4:~# sudo nmcli c modify test5G 802-11-wireless-security.key-mgmt wpa-psk
root@BPI-R4:~# sudo nmcli c modify test5G 802-11-wireless-security.psk 12345678
Turn on AP.
root@BPI-R4:~# sudo nmcli connection up test5G
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/5)
Connect to the WiFi name hotspotname24G.
The 5G is similar to the 2.4G. |
Add interface wlan1 first.
root@BPI-R4:~# sudo iw phy phy1 interface add wlan1 type __ap
root@BPI-R4:~# ifconfig wlan1
wlan1: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
ether 00:0c:43:26:60:11 txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
Enable WiFi, and set WiFi name, AP mode, etc.
root@BPI-R4:~# sudo nmcli radio wifi on
root@BPI-R4:~# sudo nmcli c add type wifi ifname wlan1 con-name test5G autoconnect no ssid hotspotname5G
Connection 'test5G' (cacedf66-d86c-42cd-845a-b3c2954dc03d) successfully added.
root@BPI-R4:~# sudo nmcli c modify test5G 802-11-wireless.mode ap 802-11-wireless.band a 802-11-wireless.channel 149 802-11-wireless.powersave 2 ipv4.method shared
Set WiFi encryption and password.
root@BPI-R4:~# sudo nmcli c modify test5G 802-11-wireless-security.key-mgmt wpa-psk
root@BPI-R4:~# sudo nmcli c modify test5G 802-11-wireless-security.psk 12345678
Turn on AP.
root@BPI-R4:~# sudo nmcli connection up test5G
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/5)
Connect to the wifi name hotspotname5G.
5G and 6G are similar to 2.4G, so only 2.4G connections are demonstrated here. |
Start by enabling the appropriate interface configuration.
root@BPI-R4:~# iw phy phy0 interface add wlan0 type station
root@BPI-R4:~# iw phy phy1 interface add wlan1 type station
root@BPI-R4:~# iw phy phy2 interface add wlan2 type station
root@BPI-R4:~# ifconfig wlan0 up
root@BPI-R4:~# ifconfig wlan1 up
root@BPI-R4:~# ifconfig wlan2 up
Check the WiFi corresponding to the scan.
SSID is the name of your WiFi |
root@BPI-R4:~# iw dev wlan0 scan | grep SSID
SSID: XXX
root@BPI-R4:~# iw dev wlan1 scan | grep SSID_5G
SSID: XXX_5G
Create a WiFi profile to connect
root@BPI-R4:~# sudo nano /etc/wpa_supplicant/wpa_supplicant.conf
The content is:
network={
ssid="your_network_name"
psk="your_wifi_password"
key_mgmt=WPA2-PSK
}
WiFi connection configuration.
sudo wpa_supplicant -B -i wlan0 -c /etc/wpa_supplicant/wpa_supplicant.conf
Make connections.
root@BPI-R4:~# iw dev wlan0 link
Connected to fc:11:52:44:bb:67 (on wlan0)
SSID: XXX
freq: 2412
RX: 36384 bytes (546 packets)
TX: 0 bytes (182 packets)
signal: -34 dBm
rx bitrate: 195.0 MBit/s HE-MCS 9 HE-NSS 2 HE-GI 2 HE-DCM 0
tx bitrate: 1.0 MBit/s
bss flags: short-preamble short-slot-time
dtim period: 2
beacon int: 100
MTK OpwnWRT MP4.0 fan with PWM control reference.
root@R4RN:/# cat /sbin/fan-speed
#!/bin/sh /etc/rc.common
if [ ! -f /sys/class/pwm/pwmchip0/export ]; then
exit 0
fi
### enable fan ###
echo 0 > /sys/class/pwm/pwmchip0/export
echo 10000 > /sys/class/pwm/pwmchip0/pwm0/period
echo 7000 > /sys/class/pwm/pwmchip0/pwm0/duty_cycle
echo normal > /sys/class/pwm/pwmchip0/pwm0/polarity
echo 1 > /sys/class/pwm/pwmchip0/pwm0/enable
while :
do
sleep 20
result=`cat /sys/class/thermal/thermal_zone0/temp`
temperature=$((result))
#echo $temperature
if [ ${temperature} -ge 53000 ]; then
echo 5000 > /sys/class/pwm/pwmchip0/pwm0/duty_cycle
fi
if [ ${temperature} -ge 62000 ]; then
echo 1000 > /sys/class/pwm/pwmchip0/pwm0/duty_cycle
fi
if [ ${temperature} -le 4800 ]; then
echo 7000 > /sys/class/pwm/pwmchip0/pwm0/duty_cycle
fi
if [ ${temperature} -le 4000 ]; then
echo 10000 > /sys/class/pwm/pwmchip0/pwm0/duty_cycle
fi
done
root@R4RN:/#
BPI-R4 26 PIN Header(CON2) GPIO define of BPI-R4 | |||
---|---|---|---|
BPI-R4-CON2 |
PIN |
PIN |
BPI-R4-CON2 |
3.3VD |
1 |
2 |
5VD |
GPIO18/I2C_1_SDA |
3 |
4 |
5VD |
GPIO17/I2C_1_SCL |
5 |
6 |
GND |
GPIO62/JTAG_JTRST_N/PWM6 |
7 |
8 |
GPIO59/JTAG_JTDO/UART1_TX/UART2_TX |
GND |
9 |
10 |
GPIO58/JTAG_JTDI/UART1_RX/UART2_RX |
GPIO81/UART1_TXD |
11 |
12 |
GPIO51/PCM_CLK_I2S_BCLK |
GPIO80/UART1_RXD |
13 |
14 |
GND |
GPIO50/PCM_FS_I2S_LRCK |
15 |
16 |
GPIO61/JTAG_JTCLK/UART1_RTS/UART2_RTS |
3.3VD |
17 |
18 |
GPIO60/JTAG_JTMS/UART1_CTS/UART2_CTS |
GPIO30/SPI1_MOSI |
19 |
20 |
GND |
GPIO29/SPI1_MISO |
21 |
22 |
GPIO53/PCM_DTX_I2S_DOUT |
GPIO31/SPI1_CLK |
23 |
24 |
GPIO28/SPI1_CSB |
GND |
25 |
26 |
GPIO52/PCM_DRX_I2S_DIN |
BPI-R4 M.2 B-KEY(CN16) GPIO define of BPI-R4 | |||
---|---|---|---|
BPI-R4 M.2 B-KEY(CN16) |
PIN |
PIN |
BPI-R4 M.2 B-KEY(CN16) |
NI |
1 |
2 |
VCC_KEYB |
GND |
3 |
4 |
VCC_KEYB |
GND |
5 |
6 |
NI(10K PullUp to 3.3V) |
USBHUB_USB1_Dp |
7 |
8 |
NI(10K PullUp to 3.3V) |
USBHUB_USB1_Dn |
9 |
10 |
LED |
GND |
11 |
12 |
NOTCH |
NOTCH |
13 |
14 |
|
15 |
16 |
||
17 |
18 |
||
19 |
20 |
NI |
|
NI |
21 |
22 |
NI |
NI(10K PullUp to 1.8V) |
23 |
24 |
NI |
NI |
25 |
26 |
NI(10K PullUp to 3.3V) |
GND |
27 |
28 |
NI |
USBHUB_USB1_RXn |
29 |
30 |
USIM_RST-1A |
USBHUB_USB1_RXp |
31 |
32 |
USIM_CLK-1A |
GND |
33 |
34 |
USIM_DATA-1A |
USBHUB_USB1_TXn |
35 |
36 |
USIM_VDD-1A |
USBHUB_USB1_TXp |
37 |
38 |
NI |
GND |
39 |
40 |
NI |
PCIE_1L_0_LN0_SOC_RXn |
41 |
42 |
NI |
PCIE_1L_0_LN0_SOC_RXp |
43 |
44 |
NI |
GND |
45 |
46 |
NI |
PCIE_1L_0_LN0_SOC_TXn |
47 |
48 |
NI |
PCIE_1L_0_LN0_SOC_TXp |
49 |
50 |
NGFF_PCIE_PERST_V3P3 |
GND |
51 |
52 |
NGFF_PCIE_CLKREQ_V3P3 |
PCIE_1L_0_SOC_CKn |
53 |
54 |
NGFF_PCIE_PEWAKE_V3P3 |
PCIE_1L_0_SOC_CKp |
55 |
56 |
NI |
GND |
57 |
58 |
NI |
NI |
59 |
60 |
NI |
NI |
61 |
62 |
NI |
NI |
63 |
64 |
NI |
NI |
65 |
66 |
USIM_DET-1A |
NI |
67 |
68 |
32KOUT |
NI |
69 |
70 |
VCC_KEYB |
GND |
71 |
72 |
VCC_KEYB |
GND |
73 |
74 |
VCC_KEYB |
NI |
75 |
BPI-R4 M.2 M-KEY(CN18) GPIO define of BPI-R4 | |||
---|---|---|---|
BPI-R4 M.2 M-KEY(CN18) |
PIN |
PIN |
BPI-R4 M.2 M-KEY(CN18) |
GND |
1 |
2 |
VDD33_M2 |
GND |
3 |
4 |
VDD33_M2 |
NI |
5 |
6 |
NI |
NI |
7 |
8 |
NI |
GND |
9 |
10 |
LED |
NI |
11 |
12 |
VDD33_M2 |
NI |
13 |
14 |
VDD33_M2 |
GND |
15 |
16 |
VDD33_M2 |
NI |
17 |
18 |
VDD33_M2 |
NI |
19 |
20 |
NI |
GND |
21 |
22 |
NI |
NI |
23 |
24 |
NI |
NI |
25 |
26 |
NI |
GND |
27 |
28 |
NI |
NI |
29 |
30 |
NI |
NI |
31 |
32 |
NI |
GND |
33 |
34 |
NI |
NI |
35 |
36 |
NI |
NI |
37 |
38 |
NI |
GND |
39 |
40 |
NI |
PCIE_1L_1_LN0_SOC_RXn |
41 |
42 |
NI |
PCIE_1L_1_LN0_SOC_RXp |
43 |
44 |
NI |
GND |
45 |
46 |
NI |
PCIE_1L_1_LN0_SOC_TXn |
47 |
48 |
NI |
PCIE_1L_1_LN0_SOC_TXp |
49 |
50 |
NGFF_KEYM_PCIE_PERST_3VP3 |
GND |
51 |
52 |
NGFF_KEYM_PCIE_CLKREQ_V3P3 |
PCIE_1L_1_SOC_CKn |
53 |
54 |
NGFF_KEYM_PCIE_WAKE_V3P3 |
PCIE_1L_1_SOC_CKp |
55 |
56 |
I2C_SDA_KEYM |
GND |
57 |
58 |
I2C_SCL_KEYM |
NOCTH |
59 |
60 |
NOCTH |
61 |
62 |
||
63 |
64 |
||
65 |
66 |
||
NI |
67 |
68 |
32KOUT |
NI |
69 |
70 |
VDD33_M2 |
GND |
71 |
72 |
VDD33_M2 |
GND |
73 |
74 |
VDD33_M2 |
GND |
75 |
BPI-R4 miniPCIe(CN12) GPIO define of BPI-R4 | |||
---|---|---|---|
BPI-R4 miniPCIe(CN12) |
PIN |
PIN |
BPI-R4 miniPCIe(CN12) |
PCIE_2L_0_WAKE_N(1.8V) |
1 |
2 |
PCIe_3V3#2 |
NI |
3 |
4 |
GND |
NI |
5 |
6 |
PCIe_12V#2 |
PCIE_2L_0_CLKREQ_N |
7 |
8 |
USIM_VDD-2 |
GND |
9 |
10 |
USIM_DATA-2 |
PCIE_2L_0_SOC_CKn |
11 |
12 |
USIM_CLK-2 |
PCIE_2L_0_SOC_CKp |
13 |
14 |
USIM_RST-2 |
GND |
15 |
16 |
NI |
PCIE_2L_0_LN1_SOC_RXn |
17 |
18 |
GND |
PCIE_2L_0_LN1_SOC_RXp |
19 |
20 |
NI |
GND |
21 |
22 |
PCIE_2L_0_PRESET_N(1.8V) |
PCIE_2L_0_LN0_SOC_RXn |
23 |
24 |
PCIe_3V3#2 |
PCIE_2L_0_LN0_SOC_RXp |
25 |
26 |
GND |
GND |
27 |
28 |
PCIe_12V#2 |
GND |
29 |
30 |
I2C_SCL_WiFi |
PCIE_2L_0_LN0_SOC_TXn |
31 |
32 |
I2C_SDA_WiFi |
PCIE_2L_0_LN0_SOC_TXp |
33 |
34 |
GND |
GND |
35 |
36 |
USBHUB_USB3_Dn |
GND |
37 |
38 |
USBHUB_USB3_Dp |
PCIe_3V3#2 |
39 |
40 |
GND |
PCIe_3V3#2 |
41 |
42 |
LTE_LED-2 |
GND |
43 |
44 |
USIM_DET-2 |
PCIE_2L_0_LN1_SOC_TXn |
45 |
46 |
NI |
PCIE_2L_0_LN1_SOC_TXp |
47 |
48 |
PCIe_12V#2 |
GND |
49 |
50 |
GND |
MT7996_EINT_RESETB(1.8V) |
51 |
52 |
PCIe_3V3#2 |
BPI-R4 miniPCIe(CN14) GPIO define of BPI-R4 | |||
---|---|---|---|
BPI-R4 miniPCIe(CN14) |
PIN |
PIN |
BPI-R4 miniPCIe(CN14) |
PCIE_2L_1_WAKE_N(1.8V) |
1 |
2 |
PCIe_3V3#1 |
NI |
3 |
4 |
GND |
NI |
5 |
6 |
PCIe_12V#1 |
PCIE_2L_1_CLKREQ_N |
7 |
8 |
USIM_VDD-3 |
GND |
9 |
10 |
USIM_DATA-3 |
PCIE_2L_1_SOC_CKn |
11 |
12 |
USIM_CLK-3 |
PCIE_2L_1_SOC_CKp |
13 |
14 |
USIM_RST-3 |
GND |
15 |
16 |
NI |
PCIE_2L_1_LN1_SOC_RXn |
17 |
18 |
GND |
PCIE_2L_1_LN1_SOC_RXp |
19 |
20 |
NI |
GND |
21 |
22 |
PCIE_2L_1_PRESET_N(1.8V) |
PCIE_2L_1_LN0_SOC_RXn |
23 |
24 |
PCIe_3V3#1 |
PCIE_2L_1_LN0_SOC_RXp |
25 |
26 |
GND |
GND |
27 |
28 |
PCIe_12V#1 |
GND |
29 |
30 |
I2C_SCL_WiFi |
PCIE_2L_1_LN0_SOC_TXn |
31 |
32 |
I2C_SDA_WiFi |
PCIE_2L_1_LN0_SOC_TXp |
33 |
34 |
GND |
GND |
35 |
36 |
USBHUB_USB2_Dn |
GND |
37 |
38 |
USBHUB_USB2_Dp |
PCIe_3V3#1 |
39 |
40 |
GND |
PCIe_3V3#1 |
41 |
42 |
LTE_LED-3 |
GND |
43 |
44 |
USIM_DET-3 |
PCIE_2L_1_LN1_SOC_TXn |
45 |
46 |
NI |
PCIE_2L_1_LN1_SOC_TXp |
47 |
48 |
PCIe_12V#1 |
GND |
49 |
50 |
GND |
NI |
51 |
52 |
PCIe_3V3#1 |
BPI-R4 5V/12V OUT(CN19,XH4A-2.54mm) of BPI-R4 | |
---|---|
BPI-R4 5V/12V OUT |
PIN |
+12V |
1 |
GND |
2 |
GND |
3 |
+5V |
4 |
BPI-R4 FAN(CN1,PH3A-2.00mm) of BPI-R4 | |
---|---|
+5V |
1 |
GND |
2 |
PWM0 |
3 |
BPI-R4 Debug UART(CON1,3PIN-2.54mm) of BPI-R4 | |
---|---|
BPI-R4 Debug UART |
PIN |
GND |
1 |
RXD |
2 |
TXD |
3 |