Miwifi
Kernel, Toolchain ... of Xiaomi Router R1D
Install / Use
/learn @comcat/MiwifiREADME
Xiaomi Router Board Support Package
- Overview ============
Chinese version please refer to the README.cn
Support Xiaomi R1D router (with 1T sata disk).
The Kernel version is 2.6.36 WLAN driver are binary object file from Broadcom located in 'drivers/net/wl'
This BSP is validated in following environment:
- CFE version: v1.0.4 / Build Date: Wed Apr 30 18:03:21 CST 2014
If you meet some kernel loading issue plase degrade the firmware to 0.4.85 which is with this CFE version.
- Change History ==================
- 2014/06: First version with kernel 2.6.36, support Xiaomi router R1D
- Features ===========
3.1 Supported Features
o General Platform + ARM Cortex A9 Dual-Core + 32 KB I-cache and 32 KB D-cache per core + 256 KB L2 Cache (shared) + 128-entry TLB + SMP
o Bus + DDR3: Broadcom BCM4709 On-Chip DDR3 interface + PCI-E: Broadcom BCM4709 On-Chip PCI-E Controller + USB: Broadcom BCM4709 On-Chip USB Controller + SPI: Broadcom BCM4709 On-Chip SPI Controller + SATA: ASMedia ASM1062 PCI-E SATA Controller
o Network + Ethernet: Broadcom On-Chip 010/100/1000M Ethernet Controller + WLAN: + 2.4GHz: BCM43217, 802.11b/g/n Transceiver, PCIe 2.0 interface, Radio + Baseband + MAC, 300Mbps + 5.0GHz: BCM4352, 2-Stream 802.11ac Transceiver (Support 802.11a/b/g/n) PCIe 2.0 interface, Radio + Baseband + MAC, 867Mbps
o Storage + NOR Flash: MXIC 25L12835F (16MB) + SATA Disk: Samsung 1T Sata disk
o MISC + Temp Sensor: TMP75 + LED: Three LEDs (red, yellow, blue), GPIO interface
3.2 Unsupported Features
Will be support in the furture:
o MISC + PWM
- Test Instructions =====================
We suggest you to try the kernel and rootfs through TFTP and NFS. These are not affect the original ROM system.
You can flush the kernel image into the flash and unpack the rootfs into the /dev/sda4 via following Section 5 instructions after you are sure that the system is OK.
4.1 Build
The following is validated in Ubuntu 12.04:
$ sudo apt-get install lzma
Please make sure the version of lzma is:
$ lzma --version LZMA command line tool 9.22 LZMA SDK 9.22
$ git clone git://github.com/comcat/miwifi.git $ cd miwifi/ $ make
The output kernel image is vmlinuz, you can load it in CFE via tftpboot directly
The rootfs is located at miwifi/rootfs/
The root password is 'admin'
The wireless SSID is 'Jarvis' and 'Jarvis_5G' and the password is 'qwer1234'
4.2 Prepare the NFS Rootfs
4.2.1 Prepare the NFS Server
If you want to use the NFS as the root fs. You need to setup a NFS server in you PC:
$ sudo apt-get install nfs-kernel-server
Config the nfs directory:
$ sudo mkdir -p /tftpboot/rootfs $ cat /etc/exports /tftpboot/rootfs *(async,rw,insecure,insecure_locks,no_root_squash)
Restart the nfs server:
$ sudo /etc/init.d/nfs-kernel-server restart
Testing the nfs server:
$ sudo mount -t nfs 192.168.31.2:/tftpboot/rootfs /mnt
4.2.2 Link the Rootfs
$ sudo rm -rf /tftpboot/rootfs $ sudo ln -sf /path/to/miwifi/rootfs /tftpboot/rootfs $ sudo /etc/init.d/nfs-kernel-server restart
4.2.3 Setup the nvram
Set the nvram varible 'rootfs' to 'nfs', then the kernel would be mount the 192.168.1.2:/tftpboot/rootfs as the root fs:
root@XiaoQiang:/# nvram get rootfs root@XiaoQiang:/# nvram set rootfs=nfs root@XiaoQiang:/# nvram commit
Then after the kernel bootup, it will be mount the /tftpboot/rootfs as the root fs.
4.3 Boot kernel
4.3.1 Prepare Network
Make sure the LAN port (black one) of the Router and your PC ethernet port are connected to the same Ethernet HUB.
Make sure the WAN port (blue one) of the Router is connected to the local network.
The default ip addr of the CFE is 192.168.1.1 and the default tftp server ip is 192.168.1.2. So we need to setup a new ip for your PC eth0 port something like:
$ sudo ifconfig eth0:0 192.168.1.2 $ sudo ifconfig eth0:1 192.168.31.2
4.3.2 Setup TFTP Server
We load the kernel through tftpboot. So we need to install a tftp server in your desktop PC:
$ sudo apt-get install tftpd tftp
Configure the tftp server via touching a file /etc/xinetd.d/tftp with following contents:
$ cat /etc/xinetd.d/tftp service tftp { socket_type = dgram protocol = udp wait = yes user = root server = /usr/sbin/in.tftpd server_args = -s /tftpboot disable = no per_source = 11 cps = 100 2 flags = IPv4 }
$ ls /etc/xinetd.d/ chargen daytime discard echo tftp time
$ sudo mkdir /tftpboot $ sudo chmod 777 /tftpboot
$ sudo /etc/init.d/xinetd restart
Now you can place your vmlinuz into the /tftpboot:
$ cp /path/to/miwifi/vmlinuz /tftpboot/
4.3.3 Load kernel in CFE
You need to set the nvram parameter 'flag_tftp_bootup' to 'on' to make the CFE to load the vmlinuz through tftp from tftp server:
root@XiaoQiang:/# nvram get flag_tftp_bootup off root@XiaoQiang:/# nvram set flag_tftp_bootup=on root@XiaoQiang:/# nvram commit root@XiaoQiang:/# nvram get flag_tftp_bootup on root@XiaoQiang:/# reboot
........... CFE version v1.0.4 BSP: 6.37.14.34 (r415984) based on BBP 1.0.37 for BCM947XX (32bit,SP,) Build Date: Wed Apr 30 18:03:21 CST 2014 (szy@shenzhiyong-ct)
...........
Device eth0: hwaddr 8C-BE-BE-20-B7-48, ipaddr 192.168.1.1, mask 255.255.255.0 gateway not set, nameserver not set ********** flag_tftp_bootup=on ********** tftp network: ifconfig eth0 -addr=192.168.1.1 -mask=255.255.255.0 -gw=192.168.1.1 Device eth0: hwaddr 8C-BE-BE-20-B7-48, ipaddr 192.168.1.1, mask 255.255.255.0 gateway 192.168.1.1, nameserver not set kernel: boot -raw -z -addr=0x8000 -max=0x800000 192.168.1.2:vmlinuz Loader:raw Filesys:tftp Dev:eth0 File:192.168.1.2:vmlinuz Options:(null) Loading: ........ 5704544 bytes read Entry at 0x00008000 Closing network. Starting program at 0x00008000 ...... ......
- Flush Instructions =======================
If the kernel and rootfs are stable (via TFTP and NFS to test) you can try to flush the kernel into the flash and deploy the rootfs into /dev/sda4
5.1 Build
The following is validated in Ubuntu 12.04:
$ sudo apt-get install lzma $ git clone git://github.com/comcat/miwifi.git $ cd miwifi/ $ make nonfs
The output kernel image is vmlinuz.trx less than 3MB. It can be flushed into the mtd1/mtd2
The rootfs is jarvis-rootfs.tgz
The root password is 'admin'
The wireless SSID is 'Jarvis' and 'Jarvis_5G' and the password is 'qwer1234'
5.2 Deploy kernel and rootfs
Copy the kernel and rootfs into the router:
$ scp vmlinuz.trx root@192.168.31.1:/userdisk/ root@192.168.31.1's password: vmlinuz
$ scp jarvis-rootfs.tgz root@192.168.31.1:/userdisk/ root@192.168.31.1's password: jarvis-rootfs.tgz
login in the router via SSH, and deploy the rootfs into sda4:
root@XiaoQiang:/# mount | grep userdisk /dev/sda4 on /userdisk type ext4 (rw,noatime,barrier=1,data=ordered)
root@XiaoQiang:/# tar zxpf /userdisk/jarvis-rootfs.tgz -C /userdisk/
Deply the kernel into /dev/mtd2 (flash.os2 in CFE):
root@XiaoQiang:/# cat /proc/mtd dev: size erasesize name mtd0: 00040000 00010000 "boot" mtd1: 00300000 00010000 "os" mtd2: 00300000 00010000 "os1" mtd3: 00890000 00010000 "squashfs" mtd4: 00010000 00010000 "crash" mtd5: 00100000 00010000 "overlay" mtd6: 00010000 00010000 "board_data" mtd7: 00010000 00010000 "nvram" mtd8: 00fe0000 00010000 "firmware" root@XiaoQiang:/# mtd write /userdisk/vmlinuz.trx os1 Unlocking os1 ...
Writing from /userdisk/vmlinuz.trx to os1 ...
5.3 Setup the nvram
The nvram variable 'flag_last_success' can affect the CFE loading kernel activity.
If the flag_last_success = 0, CFE would be load the kernel from flash.os1 (mtd1) If the flag_last_success = 1, CFE would be load the kernel from flash.os2 (mtd2)
root@XiaoQiang:/# nvram set flag_tftp_bootup=off # turn off the tftp root@XiaoQiang:/# nvram get flag_last_success 0 root@XiaoQiang:/# nvram set flag_last_success=1 # load kernel from mtd2 root@XiaoQiang:/# nvram set rootfs=sata root@XiaoQiang:/# nvram commit
- APP build ==============
Install an ARM basic debian on your x86 machine, The following is validated in Ubuntu 12.04:
$ sudo apt-get install qemu-user-static
And create the core rootfs with the included debootstrap wrapper script:
$ sudo qemu-debootstrap --arch armel stable rootfs I: Running command: debootstrap --arch armel --foreign stable rootfs I: Retrieving Release I: Retrieving Packages I: Validating Packages ... ... I: Base system installed successfully.
The basic debian successfully created in rootfs directory. Now you can chroot into the rootfs:
$ sudo chroot ./rootfs
ldd bin/bash
libtinfo.so.5 => /lib/arm-linux-gnueabi/libtinfo.so.5 (0xf67af000) libdl.so.2 => /lib/arm-linux-gnueabi/libdl.so.2 (0xf67a4000) libgcc_s.so.1 => /lib/arm-linux-gnueabi/libgcc_s.so.1 (0xf677a000) libc.so.6 => /lib/arm-linux-gnueabi/libc.so.6 (0xf6642000) /lib/ld-linux.so.3 (0xf6fda000)
cd bin
ls -l sh
lrwxrwxrwx 1 root root 4 Mar 1 2012 sh -> dash
ln -sf bash sh
ls -l sh
lrwxrwxrwx 1 root root 4 Jul 2 11:59 sh -> bash
cat etc/apt/sources.list
deb http://mirrors.ustc.edu.cn/debian wheezy main contrib non-free
apt-get update
Get:1 http://mirrors.ustc.edu.cn wheezy Release.gpg [1672 B] ...... ......
Now you can install the essential development packages:
apt-get install build-essential debhelper
Now you can use gcc with -static to build a 'hello world' app and then run the app in the route
