Notice: Radxa Wiki is no longer maintained and content is for reference only. Please visit the latest Radxa Documentation site:
docs.radxa.com
Rock/Linux Mainline
Contents
Status
Kernel 3.17
Build Linux Mainline
WARNING: this Linux kernel is intended for developers only. A lot of things are not working yet: I2C, SPI, USB, framebuffer, HDMI driver, SD/MMC, NAND Flash, etc.
Download
Get linux-next kernel tree, default config and initramfs.cpio.
git clone --depth 1 git://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git cd linux-next wget http://www.sntech.de/rockchip/rockchip_defconfig -O arch/arm/configs/rockchip_defconfig wget http://www.sntech.de/rockchip/initramfs.cpio
Build
export ARCH=arm && export CROSS_COMPILE=arm-linux-gnueabihf- make rockchip_defconfig make -j8 rk3188-radxarock.dtb make -j8 zImage
Flash boot image
cat arch/arm/boot/zImage arch/arm/boot/dts/rk3188-radxarock.dtb > kernel.img mkbootimg --kernel kernel.img --ramdisk initramfs.cpio -o boot.img upgrade_tool di -b boot.img upgrade_tool rd
The device will reboot and you will see the linux kernel booting with GPIO, UART and SMP support.
Boot log
In
3 3 DDR3
222MHz
Bus Width=32 Col=10 Bank=8 Row=16 CS=1 Die Bus-Width=8 Size=2048MB
Memory OK
OUT
BUILD=====2
No.1 FLASH ID:2c 64 44 4b a9 0
OK! 267026
unsigned!
SecureBootEn = 0 0
Boot ver: 2014-03-03#2.13
RECOVERY key is pressed
UsbBoot 272418
UsbHook ...926685
powerOn 926711
1198166 UsbConnected
1270413 UsbConnected
1352808 UsbConnected
DDR Version 1.04 20140217
In
SRX
DDR3
3 222MHz
Bus Width=32 Col=10 Bank=8 Row=16 CS=1 Die Bus-Width=8 Size=2048MB
OUT
BUILD=====3
No.1 FLASH ID:2c 64 44 4b a9 0
No.2 FLASH ID:7f ff ff ff ff ff
OK! 273294
unsigned!
SecureBootEn = 0 0
Boot ver: 2014-03-03#2.13
start_linux=====278869
2046791 Starting kernel...@0x60408000
Uncompressing Linux... done, booting the kernel.
[ 0.000000] Booting Linux on physical CPU 0x0
[ 0.000000] Linux version 3.15.0-rc1-next-20140414 (julien@pandora) (gcc version 4.8.1 (Ubuntu/Linaro 4.8.1-10ubuntu7) ) #2 SMP Mon Apr 14 16:10:50 CEST 2014
[ 0.000000] CPU: ARMv7 Processor [413fc090] revision 0 (ARMv7), cr=10c53c7d
[ 0.000000] CPU: PIPT / VIPT nonaliasing data cache, VIPT aliasing instruction cache
[ 0.000000] Machine model: Radxa Rock
[ 0.000000] bootconsole [earlycon0] enabled
[ 0.000000] Memory policy: Data cache writealloc
[ 0.000000] PERCPU: Embedded 7 pages/cpu @ee7c6000 s7680 r8192 d12800 u32768
[ 0.000000] Built 1 zonelists in Zone order, mobility grouping on. Total pages: 522768
[ 0.000000] Kernel command line: console=ttyS2,115200 earlyprintk init=/init
[ 0.000000] PID hash table entries: 4096 (order: 2, 16384 bytes)
[ 0.000000] Dentry cache hash table entries: 131072 (order: 7, 524288 bytes)
[ 0.000000] Inode-cache hash table entries: 65536 (order: 6, 262144 bytes)
[ 0.000000] Memory: 2074088K/2097152K available (2551K kernel code, 131K rwdata, 740K rodata, 2019K init, 209K bss, 23064K reserved, 1318912K highmem)
[ 0.000000] Virtual kernel memory layout:
[ 0.000000] vector : 0xffff0000 - 0xffff1000 ( 4 kB)
[ 0.000000] fixmap : 0xfff00000 - 0xfffe0000 ( 896 kB)
[ 0.000000] vmalloc : 0xf0000000 - 0xff000000 ( 240 MB)
[ 0.000000] lowmem : 0xc0000000 - 0xef800000 ( 760 MB)
[ 0.000000] pkmap : 0xbfe00000 - 0xc0000000 ( 2 MB)
[ 0.000000] modules : 0xbf000000 - 0xbfe00000 ( 14 MB)
[ 0.000000] .text : 0xc0008000 - 0xc033eeec (3292 kB)
[ 0.000000] .init : 0xc033f000 - 0xc0537e00 (2020 kB)
[ 0.000000] .data : 0xc0538000 - 0xc0558e90 ( 132 kB)
[ 0.000000] .bss : 0xc0558e98 - 0xc058d594 ( 210 kB)
[ 0.000000] Hierarchical RCU implementation.
[ 0.000000] NR_IRQS:16 nr_irqs:16 16
[ 0.000021] sched_clock: 64 bits at 150MHz, resolution 6ns, wraps every 1832519401472ns
[ 0.009620] Console: colour dummy device 80x30
[ 0.014626] Calibrating delay loop... 1196.85 BogoMIPS (lpj=5984256)
[ 0.102253] pid_max: default: 32768 minimum: 301
[ 0.107648] Mount-cache hash table entries: 2048 (order: 1, 8192 bytes)
[ 0.115059] Mountpoint-cache hash table entries: 2048 (order: 1, 8192 bytes)
[ 0.123874] CPU: Testing write buffer coherency: ok
[ 0.130006] Setting up static identity map for 0x60283ea8 - 0x60283f00
[ 0.141348] CPU1: Booted secondary processor
[ 0.180620] CPU2: Booted secondary processor
[ 0.220659] CPU3: Booted secondary processor
[ 0.259308] Brought up 4 CPUs
[ 0.277018] SMP: Total of 4 processors activated.
[ 0.282303] CPU: All CPU(s) started in SVC mode.
[ 0.288319] devtmpfs: initialized
[ 0.297250] VFP support v0.3: implementor 41 architecture 3 part 30 variant 9 rev 4
[ 0.306337] pinctrl core: initialized pinctrl subsystem
[ 0.312800] regulator-dummy: no parameters
[ 0.320519] NET: Registered protocol family 16
[ 0.326502] DMA: preallocated 256 KiB pool for atomic coherent allocations
[ 0.334756] cpuidle: using governor ladder
[ 0.339400] cpuidle: using governor menu
[ 0.343959] L310 cache controller enabled
[ 0.348460] l2x0: 16 ways, CACHE_ID 0x4100c0c8, AUX_CTRL 0x76050001, Cache size: 512 kB
[ 0.360943] hw-breakpoint: found 5 (+1 reserved) breakpoint and 1 watchpoint registers.
[ 0.369844] hw-breakpoint: maximum watchpoint size is 4 bytes.
[ 0.380991] SCSI subsystem initialized
[ 0.386198] Switched to clocksource arm_global_timer
[ 0.403056] NET: Registered protocol family 2
[ 0.408724] TCP established hash table entries: 8192 (order: 3, 32768 bytes)
[ 0.416680] TCP bind hash table entries: 8192 (order: 4, 65536 bytes)
[ 0.424023] TCP: Hash tables configured (established 8192 bind 8192)
[ 0.431211] TCP: reno registered
[ 0.434859] UDP hash table entries: 512 (order: 2, 16384 bytes)
[ 0.441509] UDP-Lite hash table entries: 512 (order: 2, 16384 bytes)
[ 0.448859] NET: Registered protocol family 1
[ 0.583624] futex hash table entries: 1024 (order: 4, 65536 bytes)
[ 0.591714] bounce pool size: 64 pages
[ 0.596430] msgmni has been set to 1474
[ 0.601430] Block layer SCSI generic (bsg) driver version 0.4 loaded (major 253)
[ 0.609689] io scheduler noop registered
[ 0.614088] io scheduler deadline registered (default)
[ 0.620105] Serial: 8250/16550 driver, 4 ports, IRQ sharing disabled
[ 0.628965] 10124000.serial: ttyS0 at MMIO 0x10124000 (irq = 66, base_baud = 1500000) is a 16550A
[ 0.661593] dw-apb-uart 10126000.serial: Couldn't set LCR to 0
[ 0.670018] dw-apb-uart 10126000.serial: Couldn't set LCR to 0
[ 0.676568] 10126000.serial: ttyS1 at MMIO 0x10126000 (irq = 67, base_baud = 1500000) is a 16550A
[ 0.687132] console [ttyS2] disabled
[ 0.711313] 20064000.serial: ttyS2 at MMIO 0x20064000 (irq = 68, base_baud = 1500000) is a 16550A
[ 0.721192] console [ttyS2] enabled
[ 0.721192] console [ttyS2] enabled
[ 0.728603] bootconsole [earlycon0] disabled
[ 0.728603] bootconsole [earlycon0] disabled
[ 0.761298] dw-apb-uart 20068000.serial: Couldn't set LCR to 0
[ 0.770043] dw-apb-uart 20068000.serial: Couldn't set LCR to 0
[ 0.775903] 20068000.serial: ttyS3 at MMIO 0x20068000 (irq = 69, base_baud = 1500000) is a 16550A
[ 0.785905] brd: module loaded
[ 0.789367] mousedev: PS/2 mouse device common for all mice
[ 0.795010] Synopsys Designware Multimedia Card Interface Driver
[ 0.801361] TCP: cubic registered
[ 0.804699] NET: Registered protocol family 17
[ 0.810545] input: gpio-keys.1 as /devices/soc.0/gpio-keys.1/input/input0
[ 0.826727] Freeing unused kernel memory: 2016K (c033f000 - c0537000)
mount: mounting /dev/mmcblk0p1 on /mnt failed: No such device or address
total 0
drwxr-xr-x 2 1000 1000 40 May 30 2013 .
drwxr-xr-x 13 1000 1000 280 Jun 9 2013 ..
umount: can't umount /mnt: Invalid argument
processor : 0
model name : ARMv7 Processor rev 0 (v7l)
Features : swp half thumb fastmult vfp edsp neon vfpv3 tls vfpd32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x3
CPU part : 0xc09
CPU revision : 0
processor : 1
model name : ARMv7 Processor rev 0 (v7l)
Features : swp half thumb fastmult vfp edsp neon vfpv3 tls vfpd32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x3
CPU part : 0xc09
CPU revision : 0
processor : 2
model name : ARMv7 Processor rev 0 (v7l)
Features : swp half thumb fastmult vfp edsp neon vfpv3 tls vfpd32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x3
CPU part : 0xc09
CPU revision : 0
processor : 3
model name : ARMv7 Processor rev 0 (v7l)
Features : swp half thumb fastmult vfp edsp neon vfpv3 tls vfpd32
CPU implementer : 0x41
CPU architecture: 7
CPU variant : 0x3
CPU part : 0xc09
CPU revision : 0
Hardware : Rockchip Cortex-A9 (Device Tree)
Revision : 0000
Serial : 0000000000000000
BusyBox v1.20.2 (Debian 1:1.20.0-8) built-in shell (ash)
Enter 'help' for a list of built-in commands.
/bin/sh: can't access tty; job control turned off
/ #
/ # ps
PID USER COMMAND
1 0 {init} /bin/sh /init
2 0 [kthreadd]
3 0 [ksoftirqd/0]
4 0 [kworker/0:0]
5 0 [kworker/0:0H]
6 0 [kworker/u8:0]
7 0 [rcu_sched]
8 0 [rcu_bh]
9 0 [migration/0]
10 0 [migration/1]
11 0 [ksoftirqd/1]
12 0 [kworker/1:0]
13 0 [kworker/1:0H]
14 0 [migration/2]
15 0 [ksoftirqd/2]
16 0 [kworker/2:0]
17 0 [kworker/2:0H]
18 0 [migration/3]
19 0 [ksoftirqd/3]
20 0 [kworker/3:0]
21 0 [kworker/3:0H]
22 0 [khelper]
23 0 [kdevtmpfs]
24 0 [netns]
25 0 [writeback]
26 0 [bioset]
27 0 [kblockd]
28 0 [kworker/0:1]
29 0 [kswapd0]
30 0 [fsnotify_mark]
31 0 [kworker/u8:1]
34 0 [kworker/1:1]
35 0 [deferwq]
38 0 [kworker/2:1]
57 0 /bin/sh
58 0 [kworker/3:1]
59 0 {busybox} ps
/ # cat /proc/interrupts
CPU0 CPU1 CPU2 CPU3
27: 0 0 0 0 GIC 27 gt
29: 36951 36928 36931 36927 GIC 29 twd
68: 205 0 0 0 GIC 68 serial
160: 0 0 0 0 rockchip_gpio_irq 4 GPIO Key Power
IPI0: 0 0 0 0 CPU wakeup interrupts
IPI1: 0 0 0 0 Timer broadcast interrupts
IPI2: 99 116 30 22 Rescheduling interrupts
IPI3: 1 53 54 54 Function call interrupts
IPI4: 0 0 0 0 Single function call interrupts
IPI5: 0 0 0 0 CPU stop interrupts
IPI6: 10 5 6 0 IRQ work interrupts
IPI7: 0 0 0 0 completion interrupts
Err: 0
/ #
