Howto openwrt

From Vidalinux Wiki
Jump to navigation Jump to search

download stable image

download openwrt image for x86:

wget https://downloads.openwrt.org/releases/23.05.4/targets/x86/legacy/openwrt-23.05.4-x86-legacy-generic-squashfs-combined.img.gz

decompress image:

gzip -d openwrt-23.05.4-x86-legacy-generic-squashfs-combined.img.gz

copy image to pendrive:

dd if=openwrt-23.05.4-x86-legacy-generic-squashfs-combined.img of=/dev/sdd status=progress

download snapshot image

download latest snapshot:

mkdir ~/snapshot-$(date +%F)/openwrt/{image,packages,scripts} -p
cd ~/snapshot-$(date +%F)/openwrt/image
wget https://downloads.openwrt.org/snapshots/targets/x86/legacy/openwrt-x86-legacy-generic-squashfs-combined.img.gz

download packages:

cd ~/openwrt/snapshot-$(date +%F)/packages/
wget https://mirror-03.infra.openwrt.org/snapshots/targets/x86/legacy/kmods/6.6.67-1-798f9a954b40c2dc861e7fb593a9ad97/kmod-e1000e-6.6.67-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/targets/x86/legacy/kmods/6.6.67-1-798f9a954b40c2dc861e7fb593a9ad97/kmod-pptp-6.6.67-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/targets/x86/legacy/kmods/6.6.67-1-798f9a954b40c2dc861e7fb593a9ad97/kmod-gre-6.6.67-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/targets/x86/legacy/kmods/6.6.67-1-798f9a954b40c2dc861e7fb593a9ad97/kmod-iptunnel-6.6.67-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/libsmartcols1-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/losetup-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/libreadline8-8.2-r2.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/libncurses6-6.4-r2.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/blockdev-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/lsblk-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/terminfo-6.4-r2.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/libmount1-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/libblkid1-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/libfdisk1-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/base/fdisk-2.40.2-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/packages/libparted-3.6-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/packages/parted-3.6-r1.apk
wget https://mirror-03.infra.openwrt.org/snapshots/packages/i386_pentium-mmx/packages/bash-5.2.32-r1.apk

decompress image:

gzip -d openwrt-x86-legacy-generic-squashfs-combined.img.gz

flash the image to drive:

dd if=openwrt-x86-legacy-generic-squashfs-combined.img of=/dev/sdd status=progress

boot system then install packages:

touch repo.list && apk add --repositories-file=repo.list --allow-untrusted --no-cache --no-network *.apk

openwrt 24.10.0-rc2

download firmware for x86 generic:

wget https://downloads.openwrt.org/releases/24.10.0-rc2/targets/x86/legacy/openwrt-24.10.0-rc2-x86-legacy-generic-squashfs-combined.img.gz

decompress image:

gzip -d openwrt-24.10.0-rc2-x86-legacy-generic-squashfs-combined.img.gz

copy image to pendrive:

dd if=openwrt-24.10.0-rc2-x86-legacy-generic-squashfs-combined.img of=/dev/sdd status=progress

download kernel packages for network:

wget https://downloads.openwrt.org/releases/24.10.0-rc2/targets/x86/legacy/kmods/6.6.63-1-d72a65c77b491eb21add169b1df0a748/kmod-e1000e_6.6.63-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/targets/x86/legacy/kmods/6.6.63-1-d72a65c77b491eb21add169b1df0a748/kmod-pptp_6.6.63-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/targets/x86/legacy/kmods/6.6.63-1-d72a65c77b491eb21add169b1df0a748/kmod-gre_6.6.63-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/targets/x86/legacy/kmods/6.6.63-1-d72a65c77b491eb21add169b1df0a748/kmod-iptunnel4_6.6.63-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/targets/x86/legacy/packages/libc_1.2.5-r4_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/libsmartcols1_2.40.2-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/losetup_2.40.2-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/packages/bash_5.2.32-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/libreadline8_8.2-r2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/libncurses6_6.4-r2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/blockdev_2.40.2-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/packages/libparted_3.6-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/packages/parted_3.6-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/lsblk_2.40.2-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/terminfo_6.4-r2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/libmount1_2.40.2-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/libblkid1_2.40.2-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/libfdisk1_2.40.2-r1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/24.10.0-rc2/packages/i386_pentium-mmx/base/fdisk_2.40.2-r1_i386_pentium-mmx.ipk

install packages:

opkg install *.ipk

configure grub:

https://wiki.vidalinux.org/index.php?title=Howto_openwrt#configure_grub

resize squashfs filesystem:

https://wiki.vidalinux.org/index.php?title=Howto_openwrt#resize_squashfs

install packages again:

opkg install *

edit /etc/config/network add the following:

config device 'lan_br'
    option name 'br-lan'
    option type 'bridge'
    list ports 'eth1'
    list ports 'eth2'
    list ports 'eth3'

config device 'eth1'
    option name 'eth1' 

config device 'eth2'
    option name 'eth2'

config device 'eth3'
    option name 'eth3'

config interface 'lan'
    option device 'br-lan'
    option proto 'static'
    option netmask '255.255.255.0'
    option ipaddr '192.168.99.1'

config interface 'wan'
    option device 'eth0'
    option proto 'dhcp'

restart network:

service network restart

reboot to enable wifi module:

reboot

install luci web interface:

https://wiki.vidalinux.org/index.php?title=Howto_openwrt#install_luci

upgrade firmware

download upgrade image:

wget https://mirror-03.infra.openwrt.org/releases/23.05.4/targets/x86/legacy/openwrt-23.05.4-x86-legacy-generic-squashfs-combined.img.gz

upgrade from terminal:

sysupgrade -v /tmp/openwrt-23.05.4-x86-legacy-generic-squashfs-combined.img.gz

resize squashfs

download the following scripts:

wget https://raw.githubusercontent.com/vidalinux/openwrt/main/resizefs.sh
wget https://raw.githubusercontent.com/vidalinux/openwrt/main/expand.sh 

execute the script to resize your root partition:

bash resizefs.sh

execute the script to expand your partition:

bash expand.sh

then reboot:

reboot

configure network

edit /etc/config/network:

config interface 'loopback'
    option device 'lo'
    option proto 'static'
    option ipaddr '127.0.0.1'
    option netmask '255.0.0.0'

config globals 'globals'
    option ula_prefix 'fd5c:aa60:b3ab::/48'

config device 'lan_br'
    option name 'br-lan'
    option type 'bridge'
    list ports 'eth1'
    list ports 'eth2'
    list ports 'eth3'

config device 'eth1'
    option name 'eth1'

config device 'eth2'
    option name 'eth2'

config device 'eth3'
    option name 'eth3'

config interface 'lan'
    option device 'br-lan'
    option proto 'static'
    option netmask '255.255.255.0'
    option ipaddr '192.168.99.1'

config interface 'wan'
    option device 'eth0'
    option proto 'dhcp'

start network:

service network restart

install tool packages

update repo for stable version:

opkg update

install packages:

opkg install bash curl parted fdisk lsblk nano hostapd wireless-tools wpa-supplicant kmod-iwlwifi pciutils blockdev mount-utils losetup resize2fs openssh-sftp-server iperf3

upgrade all packages

upgrade all packages installed:

opkg update
opkg list-upgradable | cut -f 1 -d ' ' | xargs -r opkg upgrade

configure dhcp server

edit /etc/config/dhcp:

config dnsmasq
    option domainneeded '1'
    option boguspriv '1'
    option filterwin2k '0'
    option localise_queries '1'
    option rebind_protection '1'
    option rebind_localhost '1'
    option local '/lan/'
    option domain 'lan.ovox.local'
    option expandhosts '1'
    option nonegcache '0'
    option cachesize '1000'
    option authoritative '1'
    option readethers '1'
    option leasefile '/tmp/dhcp.leases'
    option resolvfile '/tmp/resolv.conf.d/resolv.conf.auto'
    option nonwildcard '1'
    option localservice '1'
    option ednspacket_max '1232'
    option filter_aaaa '0'
    option filter_a '0'
    list server '4.2.2.1'
    list server '4.2.2.2'

config dhcp 'lan'
    option interface 'lan'
    option start '100'
    option limit '150'
    option leasetime '12h'
    option dhcpv4 'server'
    option ra 'server'
    option ra_slaac '1'
    list ra_flags 'managed-config'
    list ra_flags 'other-config' 

config dhcp 'wan'
    option interface 'wan'
    option ignore '1' 

config odhcpd 'odhcpd'
    option maindhcp '0'
    option leasefile '/tmp/hosts/odhcpd'
    option leasetrigger '/usr/sbin/odhcpd-update'
    option loglevel '4'  

config dhcp 'wifi2'
    option interface 'wifi2'
    option start '240'
    option leasetime '2m'
    option limit '14'

restart dhcp service:

service dnsmasq restart

configure firewall

edit /etc/config/firewall:

config defaults
    option syn_flood    1
    option input     REJECT
    option output    ACCEPT
    option forward   REJECT

config zone
    option name     lan
    list   network  'lan'
    option input    ACCEPT
    option output   ACCEPT
    option forward  ACCEPT

config zone
   option name     wan
   list   network  'wan'
   option input    REJECT
   option output   ACCEPT
   option forward  REJECT
   option masq     1
   option mtu_fix  1

config zone
   option name     wifi2
   list   network  'wifi2'
   option input    ACCEPT
   option output   ACCEPT
   option forward  ACCEPT
   option masq     1
   option mtu_fix  1

config forwarding
   option src     lan
   option dest    wan

config forwarding
   option src     wifi2
   option dest    wan

# We need to accept udp packets on port 68,
# see https://dev.openwrt.org/ticket/4108
config rule
   option name       Allow-DHCP-Renew
   option src        wan
   option proto      udp
   option dest_port  68
   option target     ACCEPT
   option family     ipv4

# Allow IPv4 ping
config rule
   option name       Allow-Ping
   option src        wan
   option proto      icmp
   option icmp_type  echo-request
   option family     ipv4
   option target     ACCEPT

config rule
   option name       Allow-IGMP
   option src        wan
   option proto      igmp
   option family     ipv4
   option target     ACCEPT

# Allow IPSec
config rule
   option name       Allow-IPSec-ESP
   option src        wan
   option dest       lan
   option proto      esp
   option target     ACCEPT

config rule
   option name       Allow-ISAKMP
   option src        wan
   option dest       lan
   option dest_port  500
   option proto      udp
   option target     ACCEPT

dnat rule example:

config redirect
       option src      wan
       option src_dip  192.168.24.45
       option dest     lan
       option dest_ip  192.168.99.208
       option target   DNAT
       option name     DNAT-IP-WAN-LAN
       option enabled

snat rule example:

config redirect
       option target           SNAT
       option src              lan
       option dest             wan
       option src_ip           192.168.99.208
       option src_dip          192.168.24.45
       option enabled          1
       option name             SNAT-IP-LAN-WAN

restart firewall:

service firewall restart

configure 4g modem

install packages:

opkg update 
opkg install qmi-utils lib-qmi luci-proto-qmi kmod-usb-net-qmi-wwan uqmi kmod-usb-net kmod-usb-net-cdc-ether kmod-usb-serial-wwan kmod-usb-serial-option kmod-usb-serial picocom

configure network interface:

config interface 'wwan'
    option ifname 'wwan0'
    option service 'fdd_lte'
    option apn 'fast.t-mobile.com'
    option proto 'qmi'
    option device '/dev/cdc-wdm0'
    option metric '40'
    option auth 'none'
    option pdptype 'ipv4'

add the following rules to /etc/config/firewall:

config dhcp 'wwan'
    option interface 'wwan'
    option ignore '1' 

config zone
   option name     wwan
   list   network  'wwan'
   option input    REJECT
   option output   ACCEPT
   option forward  REJECT
   option masq     1
   option mtu_fix  1

config forwarding
   option src     lan
   option dest    wwan

reboot system:

reboot

check connection status:

uqmi -d /dev/cdc-wdm0 --get-data-status

check sim card status:

qmicli --device=/dev/cdc-wdm0 --device-open-proxy --uim-get-card-status

install luci

install packages:

opkg update
opkg install luci-compat luci-lib-ipkg luci luci-ssl

install luci modules:

opkg install luci-mod-rpc luci-mod-dashboard luci-mod-network luci-mod-system luci-mod-status luci-app-opkg

download theme ipk:

wget --no-check-certificate https://github.com/jerrykuku/luci-theme-argon/releases/download/v2.3.1/luci-theme-argon_2.3.1_all.ipk -O luci-theme-argon_2.3.1_all.ipk
opkg install luci-theme-argon_2.3.1_all.ipk

restart http server:

service uhttpd restart

enter web interface:

https://192.168.99.1

configure grub

set grub boot loader timeout edit /boot/grub/grub.cfg:

set timeout="0"

soekris net6501

install e1000e driver for intel 82574L:

mkdir openwrt/packages/23.05.4-x86 -p
cd openwrt/packages/23.05.4-x86
wget https://downloads.openwrt.org/releases/23.05.4/targets/x86/legacy/packages/kmod-e1000e_5.15.162-1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/targets/x86/legacy/packages/kmod-ptp_5.15.162-1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/targets/x86/legacy/packages/libc_1.2.4-4_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/libsmartcols1_2.39-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/losetup_2.39-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/packages/bash_5.2.15-1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/libreadline8_8.2-1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/libncurses6_6.4-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/blockdev_2.39-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/packages/libparted_3.6-1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/packages/parted_3.6-1_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/lsblk_2.39-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/terminfo_6.4-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/libmount1_2.39-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/libblkid1_2.39-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/libfdisk1_2.39-2_i386_pentium-mmx.ipk
wget https://downloads.openwrt.org/releases/23.05.4/packages/i386_pentium-mmx/base/fdisk_2.39-2_i386_pentium-mmx.ipk
opkg install *.ipk

ax210 wireless drivers

drivers for intel ax210 wireless module:

opkg install iwlwifi-firmware-ax200 iwlwifi-firmware-ax210

mediatek 7916

drivers for mt7916an wireless module:

opkg install kmod-mt7915e kmod-mt7915-firmware kmod-mt7916-firmware kmod-mt7921-common kmod-mt7921-firmware kmod-mt7921e kmod-mt792x-common mt7986-wo-firmware kmod-mt76x2

mediatek 7916an

drivers for mt7916an wireless module:

opkg update
opkg install kmod-mt7915e kmod-mt7915-firmware kmod-mt7916-firmware kmod-mt7921-common kmod-mt7921-firmware kmod-mt7921e kmod-mt792x-common mt7986-wo-firmware

mediatek 7925

drivers for mt7925 wireless module:

apk update
apk add kmod-mt7925e

install firmware:

mkdir -p /lib/firmware/mediatek/mt7925 && cd /lib/firmware/mediatek/mt7925
wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/mediatek/mt7925/BT_RAM_CODE_MT7925_1_1_hdr.bin
wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/mediatek/mt7925/WIFI_MT7925_PATCH_MCU_1_1_hdr.bin
wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/mediatek/mt7925/WIFI_RAM_CODE_MT7925_1_1.bin

load kernel module:

modprobe mt7925e

watch kernel for errors:

dmesg |grep mt7925

install hostapd-ssl:

apk update
apk del hostapd
apk add hostapd-openssl

enable wifi:

uci set wireless.radio0.disabled=0
wifi up

add the following to /etc/rc.local:

modprobe mt7925e
uci set wireless.radio0.disabled=0
wifi up

configure /etc/config/wireless:

config wifi-device 'radio0'
   option type 'mac80211'
   option path 'pci0000:00/0000:00:1a.0/0000:0d:00.0'
   option band '6g'
   option channel '1'
   option htmode 'HE160'
   option disabled '0'
   option cell_density '0'
   option country 'DE'

config wifi-iface 'default_radio0'
   option device 'radio0'
   option network 'lan'
   option mode 'ap'
   option ssid 'OpenWrt'
   option encryption 'sae'
   option key 'testtest'
   option ieee80211k '1'
   option ieee80211d '1'
   option ieee80211w '2'
   option ieee80211h '1'
   option ieee80211ax '1'

configure /etc/config/network:

config device 
   option name 'phy0-ap0'
config device 
   option name 'phy1-ap0'

reboot system:

reboot

configure wireless 2G

edit /etc/config/wireless:

config wifi-device 'radio0'
    option type 'mac80211'
    option path 'pci0000:00/0000:00:1a.0/0000:0d:00.0'
    option channel '11'
    option band '2g'
    option htmode 'HE80'
    option cell_density '1'
    option txpower '11'
    option country 'US'
    option disabled '0'

config wifi-iface 'wifinet0'
    option device 'radio0'
    option mode 'ap'
    option ssid 'OpenWrt2G'
    option encryption 'psk2+tkip+ccmp'
    option key 'livinglavidalinux'

restart network:

service network restart

configure wireless 5G

edit /etc/config/wireless:

config wifi-device 'radio1'
   option type 'mac80211'
   option path 'pci0000:00/0000:00:1a.0/0000:0d:00.0+1'
   option band '5g'
   option channel '36'
   option htmode 'HE80'
   option disabled '0'

config wifi-iface 'default_radio1'
   option device 'radio1'
   option network 'lan'
   option mode 'ap'
   option ssid 'OpenWrt5G'
   option encryption 'psk2+tkip+ccmp'
   option key 'livinglavidalinux'

restart network:

service network restart

configure wireless 6G

install hostapd-ssl:

opkg update
opkg remove hostapd
opkg install hostapd-openssl

enable wifi:

uci set wireless.radio1.disabled=0
uci set wireless.radio0.disabled=0
uci commit
wifi up

configure /etc/config/wireless:

config wifi-device 'radio0'
  option type 'mac80211'
  option path 'pci0000:00/0000:00:1a.0/0000:0d:00.0'
  option band '6g'
  option channel '1'
  option htmode 'HE160'
  option disabled '0'
  option cell_density '0'
  option country 'DE'
config wifi-iface 'default_radio0'
  option device 'radio0'
  option network 'lan'
  option mode 'ap'
  option ssid 'OpenWrt6G'
  option encryption 'sae'
  option key 'testtest'
  option ieee80211k '1'
  option ieee80211d '1'
  option ieee80211w '2'
  option ieee80211h '1'
  option ieee80211ax '1'

restart network:

service network restart

statistics

install packages:

opkg update
opkg install luci-app-statistics collectd collectd-mod-cpu \
collectd-mod-interface collectd-mod-iwinfo \
collectd-mod-load collectd-mod-memory collectd-mod-network collectd-mod-uptime
/etc/init.d/luci_statistics enable
/etc/init.d/collectd enable

dual wan

change interface name and add metric on /etc/config/network:

config interface 'wan'
       option device 'eth0'
       option proto 'dhcp'
       option metric '10'

config interface 'wan2'
       option device 'eth1'
       option proto 'dhcp'
       option metric '20'

install mwan3 package:

opkg update
opkg install mwan3 

install luci mwan3 module:

opkg install luci-app-mwan3

configure mwan3 wan intefaces on /etc/config/mwan3:

config globals 'globals'
	option mmx_mask '0x3F00'

config interface 'wan'
   option initial_state 'online'
   option family 'ipv4'
   list track_ip '4.2.2.1'
   list track_ip '4.2.2.2'
   list track_ip '8.8.8.8'
   list track_ip '8.8.4.4'
   option track_method 'ping'
   option reliability '1'
   option count '1'
   option size '56'
   option max_ttl '60'
   option timeout '4'
   option interval '10'
   option failure_interval '5'
   option recovery_interval '5'
   option down '5'
   option up '5'
   option enabled '1'

config interface 'wan2'
   option initial_state 'online'
   option family 'ipv4'
   list track_ip '4.2.2.1'
   list track_ip '4.2.2.2'
   list track_ip '8.8.8.8'
   list track_ip '8.8.4.4'
   option track_method 'ping'
   option reliability '1'
   option count '1'
   option size '56'
   option max_ttl '60'
   option timeout '4'
   option interval '10'
   option failure_interval '5'
   option recovery_interval '5'
   option down '5'
   option up '5'
   option enabled '1'

configure mwan3 members on /etc/config/mwan3:

config member 'wan_member'
   option interface 'wan'
   option metric '1'
   option weight '1'

config member 'wan2_member'
   option interface 'wan2'
   option metric '2'
   option weight '2'

configure mwan3 policy on /etc/config/wman3:

config policy 'wan_to_wan2'
   list use_member 'wan_member'
   list use_member 'wan2_member'
   option last_resort 'unreachable'

configure mwan3 rules on /etc/config/mwan3:

config rule 'all'
   option proto 'all'
   option src_ip '192.168.99.0/24'
   option dest_ip '0.0.0.0/0'
   option sticky '0'
   option use_policy 'wan_to_wan2'

make sure you have correct rules for wan and wan2 on your /etc/config/firewall:

config zone
   option name             wan
   list   network          'wan'
   option input            REJECT
   option output           ACCEPT
   option forward          REJECT
   option masq             1
   option mtu_fix          1

config forwarding
   option src              lan
   option dest             wan

config zone
   option name             wan2
   list   network          'wan2'
   option input            REJECT
   option output           ACCEPT
   option forward          REJECT
   option masq             1
   option mtu_fix          1

config forwarding
   option src              lan
   option dest             wan2

restart firewall to apply rules:

service firewall restart

restart mwan3 service to apply changes:

service mwan3 restart

to verify mwan3 status use:

mwan3 status

wifi pineapple nano

to flash the device continue holding the reset button for 10 seconds, then release:

the blue led will remain solid

set ip address to your usb ethernet interface:

ifconfig eth1 192.168.1.2 netmask 255.255.255.0 up

download openwrt firmware image:

wget https://mirror-03.infra.openwrt.org/snapshots/targets/ath79/generic/openwrt-ath79-generic-hak5_lan-turtle-squashfs-sysupgrade.bin

browse to the following address to flash the device with new firmware:

http://192.168.1.1

share internet with pineapple nano:

cat > /usr/local/bin/sharenetwlan << EOF
#!/bin/bash
echo "1" > /proc/sys/net/ipv4/ip_forward
iptables -I INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
iptables -I FORWARD  -m state --state RELATED,ESTABLISHED -j ACCEPT
iptables -t nat -I POSTROUTING -o wlan0 -j MASQUERADE
EOF

fix permissions and run script:

chmod +x /usr/local/bin/sharenetwlan
/usr/local/bin/sharenetwlan

access pineapple nano via ssh:

ssh root@192.168.1.1

fix nameservers:

cat > /etc/resolv.conf << EOF
nameserver 4.2.2.1
nameserver 4.2.2.2
EOF

install wireless drivers:

opkg install kmod-ath9k-htc kmod-ath9k-common ath9k-htc-firmware hostapd wireless-tools wpa-supplicant

install support por sdcard:

opkg install block-mount kmod-fs-ext4 e2fsprogs parted kmod-usb-storage kmod-mmc kmod-sdhci

default hak5 pineapple nano image:

https://downloads.hak5.org/api/devices/wifipineapplenano/firmwares/recovery

mikrotik 951g dumaos

when system boot press f to get shell then execute the following:

mount -o remount,rw /

edit ssh dropbear config to accept connections:

vi /etc/config/dropbear

change root user password:

passwd root

reboot router

reboot

connect to router using ssh:

ssh -oKexAlgorithms=+diffie-hellman-group1-sha1 -c 3des-cbc root@192.168.88.1 -p7777

backup configuration:

sysupgrade -b /tmp/backup-netdumaOS-$(date +%F).tar.gz

on receiver machine execute the following cmd:

nc -l -p 1234 > ./backup-netdumaOS-$(date +%F).tar.gz

on router execute the following to transfer backup to receiver machine:

nc 192.168.88.145 1234 < /tmp/backup-netdumaOS-2025-03-24.tar.gz

execute the following to list current partitions:

cat /proc/mtd

on receiver machine execute the following to received parttion mtd0:

nc -l -p 1234 > ./numaOS_sysbackup_mtd0_2025-03-24.bin

on router execute the following to backup and transfer the mtd0 output to receiver machine:

dd if=/dev/mtd0| nc 192.168.88.145 1234

on receiver machine execute the following to received parttion mtd1:

nc -l -p 1234 > ./numaOS_sysbackup_mtd1_2025-03-24.bin

on router execute the following to backup and transfer the mtd1 output to receiver machine:

dd if=/dev/mtd1| nc 192.168.88.145 1234

on receiver machine execute the following to received parttion mtd2:

nc -l -p 1234 > ./numaOS_sysbackup_mtd2_2025-03-24.bin

on router execute the following to backup and transfer the mtd2 output to receiver machine:

dd if=/dev/mtd2| nc 192.168.88.145 1234

download latest openwrt for mikrotik 951g on your machine:

wget https://downloads.openwrt.org/releases/24.10.0/targets/ath79/mikrotik/openwrt-24.10.0-ath79-mikrotik-mikrotik_routerboard-951g-2hnd-squashfs-sysupgrade.bin

start an http server using python:

python -m http.server

on router use wget to download image from http server:

wget http://192.168.88.145:8000/openwrt-24.10.0-ath79-mikrotik-mikrotik_routerboard-951g-2hnd-squashfs-sysupgrade.bin

install firmware using command line:

sysupgrade -v openwrt-24.10.0-ath79-mikrotik-mikrotik_routerboard-951g-2hnd-squashfs-sysupgrade.bin

if you bricked your router don't panic, config /etc/dnsmasq.conf with tftp:

cat > /etc/dnsmasq.conf << EOF
interface=eth0
dhcp-range=192.168.6.100,192.168.6.119,12
dhcp-host=e4:8d:8c:a0:67:96,192.168.6.101
enable-tftp
tftp-root=/tftproot
dhcp-boot=/tftproot/openwrt.bin,boothost,192.168.6.1
no-daemon
EOF

download the following image and rename it:

mkdir /tftproot
wget https://downloads.openwrt.org/releases/24.10.0/targets/ath79/mikrotik/openwrt-24.10.0-ath79-mikrotik-mikrotik_routerboard-951g-2hnd-initramfs-kernel.bin -O /tftproot/openwrt.bin

set your machine ip address to 192.168.6.1:

ip addr add 192.168.6.1/24 dev eth0

use screen to view your serial console:

screen /dev/ttyUSB0 115200

when system boot reflash your router, start http server with router image:

python -m http.server

download image to router:

wget http://192.168.6.1:8000/openwrt-24.10.0-ath79-mikrotik-mikrotik_routerboard-951g-2hnd-squashfs-sysupgrade.bin

install firmware using command line:

sysupgrade -v openwrt-24.10.0-ath79-mikrotik-mikrotik_routerboard-951g-2hnd-squashfs-sysupgrade.bin

references

references