Introduction
- Device : http://routerboard.com/RB493G
- Mission : Install FreeBSD on it to run it as home router.
- Reason : a) Energy consumption vs Performance: Low powered high specs device. b) Getting FreeBSD to run on MIPS based devices. c) Work with large amount of Ethernet ports.
Tech
- AR7161 MIPS 24k (mips32r2) 680MHz PCI, GMII/RGMII/MII (GigE), UART, USB 2.0, PCM, I2S
References
- http://wiki.freebsd.org/FreeBSD/mips
- http://loos.no-ip.org/routerboard/
- http://lists.freebsd.org/pipermail/freebsd-mips/2011-January/001371.html
Status
- 30/01/2012 - Board is not booting yet.
- 30/01/2012 - Building world/and kernel.
- 31/01/2012 - Make sure to set the Boot Options to DHCP
/root/build-mips.csh
Helper script I use to build
brahm# cat /root/build-mips.csh setenv SRCROOT /usr/src-head setenv TARGET mips setenv TARGET_ARCH mipseb setenv TARGET_CPUTYPE mips32 setenv KERNCONF AR71XX_BASE setenv MAKEOBJDIRPREFIX /usr/obj/mips set NFSROOT=/nfsroot/mipseb set TFTPBOOT=/tftpboot/ar71xx set MAKEFLAGS=(-DWITHOUT_CDDL \ -DWITHOUT_GAMES \ -DWITHOUT_DOCS \ -DWITHOUT_KERBEROS \ -DWITHOUT_ACPI \ -DWITHOUT_KERBEROS \ -DWITHOUT_RESCUE \ -DWITHOUT_MAN \ -DWITHOUT_PROFILE \ -DWITHOUT_BSNMP \ -DWITHOUT_NIS \ -DWITHOUT_IPX \ -DWITHOUT_ATM) cd ${SRCROOT} #make ${MAKEFLAGS} kernel-toolchain #make ${MAKEFLAGS} buildworld make ${MAKEFLAGS} buildkernel make ${MAKEFLAGS} DESTDIR=${TFTPBOOT} installkernel #make DESTDIR=${NFSROOT} ${MAKEFLAGS} installworld #make DESTDIR=${NFSROOT} ${MAKEFLAGS} distrib-dirs #make DESTDIR=${NFSROOT} ${MAKEFLAGS} distribution
your choice: p - boot protocol Choose which boot protocol to use: 1 - bootp protocol * 2 - dhcp protocol your choice: 2 - dhcp protocol
RouterBOOT booter 2.29 RouterBoard 493G CPU frequency: 680 MHz Memory size: 256 MB Press any key within 2 seconds to enter setup. RouterBOOT-2.29
Board Info: Board type: 493G Serial number: 25E001744DD7 Firmware version: 2.29 CPU frequency: 680 MHz Memory size: 256 MB Build time: 2010-12-09 15:21:33 eth1 MAC address: 00:0C:42:A9:15:60 eth2 MAC address: 00:0C:42:A9:15:61 eth3 MAC address: 00:0C:42:A9:15:62 eth4 MAC address: 00:0C:42:A9:15:63 eth5 MAC address: 00:0C:42:A9:15:64 eth6 MAC address: 00:0C:42:A9:15:65 eth7 MAC address: 00:0C:42:A9:15:66 eth8 MAC address: 00:0C:42:A9:15:67 eth9 MAC address: 00:0C:42:A9:15:68
RouterBOOT booter 2.29 RouterBoard 493G CPU frequency: 680 MHz Memory size: 256 MB Press any key within 2 seconds to enter setup.. trying dhcp protocol... OK resolved mac address 00:16:0A:24:DA:5F Gateway: 192.168.10.1 transfer started .......*....*......*.....*.......*.....*.......*. transfer ok, time=2.75s setting up elf image... OK jumping to kernel code CPU platform: Atheros AR7161 rev 2 CPU Frequency=680 MHz CPU DDR Frequency=340 MHz CPU AHB Frequency=170 MHz platform frequency: 680000000 arguments: a0 = 00000008 a1 = a0871c00 a2 = 00000000 a3 = 00000000 Cmd line: console=ttyS0,115200 gpio=4031 HZ=340000000 mem=256M kmac=00:0C:42:A9:15:60 board=493G boot=1 mlc=2 Environment: envp is invalid Cache info: picache_stride = 4096 picache_loopcount = 16 pdcache_stride = 4096 pdcache_loopcount = 8 cpu0: MIPS Technologies processor v116.147 MMU: Standard TLB, 16 entries L1 i-cache: 4 ways of 512 sets, 32 bytes per line L1 d-cache: 4 ways of 256 sets, 32 bytes per line Config1=0x9ee3519e<PerfCount,WatchRegs,MIPS16,EJTAG> Config3=0x20 KDB: debugger backends: ddb KDB: current backend: ddb Copyright (c) 1992-2012 The FreeBSD Project. Copyright (c) 1979, 1980, 1983, 1986, 1988, 1989, 1991, 1992, 1993, 1994 The Regents of the University of California. All rights reserved. FreeBSD is a registered trademark of The FreeBSD Foundation. FreeBSD 10.0-CURRENT #0 r230787: Tue Jan 31 07:55:06 CET 2012 root@brahm.vanderzwet.net:/usr/obj/mips/mips.mipseb/usr/src-head/sys/AR71XX_BASE mips WARNING: WITNESS option enabled, expect reduced performance. MEMGUARD DEBUGGING ALLOCATOR INITIALIZED: MEMGUARD map base: 0xc0400000 MEMGUARD map limit: 0xc1800000 MEMGUARD map size: 20480 KBytes real memory = 33554432 (32768K bytes) avail memory = 25202688 (24MB) random device not loaded; using insecure entropy nexus0: <MIPS32 root nexus> clock0: <Generic MIPS32 ticker> on nexus0 Timecounter "MIPS32" frequency 340000000 Hz quality 800 Event timer "MIPS32" frequency 340000000 Hz quality 800 apb0 at irq 4 on nexus0 uart0: <16550 or compatible> on apb0 uart0: console (115200,n,8,1) gpio0: <Atheros AR71XX GPIO driver> on apb0 gpio0: [GIANT-LOCKED] gpio0: gpio pinmask=0x0 gpioc0: <GPIO controller> on gpio0 gpiobus0: <GPIO bus> on gpio0 ehci0: <AR71XX Integrated USB 2.0 controller> at mem 0x1b000000-0x1bffffff irq 1 on nexus0 usbus0: set host controller mode usbus0: EHCI version 1.0 usbus0: set host controller mode usbus0: <AR71XX Integrated USB 2.0 controller> on ehci0 pcib0 at irq 0 on nexus0 pci0: <PCI bus> on pcib0 pci0: <old, non-VGA display device> at device 0.0 (no driver attached) arge0: <Atheros AR71xx built-in ethernet interface> at mem 0x19000000-0x19000fff irq 2 on nexus0 arge0: No PHY specified, using mask 16 miibus0: <MII bus> on arge0 ukphy0: <Generic IEEE 802.3u media interface> PHY 4 on miibus0 ukphy0: none, 10baseT, 10baseT-FDX, 100baseTX, 100baseTX-FDX, 1000baseT-FDX, 1000baseT-FDX-master, auto arge0: Ethernet address: 00:0c:42:a9:15:60 arge1: <Atheros AR71xx built-in ethernet interface> at mem 0x1a000000-0x1a000fff irq 3 on nexus0 arge1: No PHY specified, using mask 15 arge1: Ethernet address: 00:0c:42:a9:15:61 spi0: <AR71XX SPI> at mem 0x1f000000-0x1f00000f on nexus0 spibus0: <spibus bus> on spi0 mx25l0: <M25Pxx Flash Family> at cs 0 on spibus0 Unknown SPI flash device. Vendor: 00, device id: 0000 device_attach: mx25l0 attach returned 6 ar71xx_wdog0: <Atheros AR71XX watchdog timer> on nexus0 Timecounters tick every 1.000 msec usbus0: 480Mbps High Speed USB v2.0 WARNING: WITNESS option enabled, expect reduced performance. Root mount waiting for: usbus0 ugen0.1: <Atheros> at usbus0 uhub0: <Atheros EHCI root HUB, class 9/0, rev 2.00/1.00, addr 1> on usbus0 Root mount waiting for: usbus0 uhub0: 2 ports with 2 removable, self powered Loader variables: Manual root filesystem specification: <fstype>:<device> [options] Mount <device> using filesystem <fstype> and with the specified (optional) option list. eg. ufs:/dev/da0s1a zfs:tank cd9660:/dev/acd0 ro (which is equivalent to: mount -t cd9660 -o ro /dev/acd0 /) ? List valid disk boot devices . Yield 1 second (for background tasks) <empty line> Abort manual input mountroot>
Last modified
13 years ago
Last modified on Jan 31, 2012, 8:23:45 AM
Note:
See TracWiki
for help on using the wiki.