平台



硬件:TQ2440  64MB内存 256MB NandFlash



bootloader:U-Boot 2015.04



kernel:linux-4.9



Python: Python-3.6.0



工具链:arm-none-linux-gnueabi-gcc  4.8.3



概述



现在树莓派很火,在树莓派上面用户可以通过Python来控制板子上面的GPIO资源, 然后我想TQ2440也应该做到这一点。 将来根文件系统会通过NFS的方式挂载到开发板上面。



正文

一、工具链


登录这个网址:http://www.veryarm.com/arm-none-linux-gnueabi-gcc

我们这里使用的是最新的Linux解压版:arm-2014.05-29,由于TQ2440用的arm9属于armv4t架构,所以在编译运行于TQ2440上的程序的时候需要给工具链传递参数-march=armv4t,为了简单起见,我们可以用下面的办法:



1 ( pengdl@ubuntu | ~/Study/cross_compile/arm-2014.05/bin | Remote:True )
 2 $ls -l
 3 total 22581248
 4 lrwxrwxrwx 1 pengdl pengdl      32 Apr 19 19:53 arm-linux-addr2line -> arm-none-linux-gnueabi-addr2line*
 5 lrwxrwxrwx 1 pengdl pengdl      25 Apr 19 19:54 arm-linux-ar -> arm-none-linux-gnueabi-ar*
 6 lrwxrwxrwx 1 pengdl pengdl      25 Apr 19 19:54 arm-linux-as -> arm-none-linux-gnueabi-as*
 7 lrwxrwxrwx 1 pengdl pengdl      26 Apr 19 19:54 arm-linux-c++ -> arm-none-linux-gnueabi-c++*
 8 lrwxrwxrwx 1 pengdl pengdl      30 Apr 19 19:54 arm-linux-c++filt -> arm-none-linux-gnueabi-c++filt*
 9 lrwxrwxrwx 1 pengdl pengdl      26 Apr 19 19:54 arm-linux-cpp -> arm-none-linux-gnueabi-cpp*
10 lrwxrwxrwx 1 pengdl pengdl      25 Apr 19 19:55 arm-linux-cs -> arm-none-linux-gnueabi-cs*
11 lrwxrwxrwx 1 pengdl pengdl      32 Apr 19 19:55 arm-linux-cs-daemon -> arm-none-linux-gnueabi-cs-daemon*
12 lrwxrwxrwx 1 pengdl pengdl      30 Apr 19 19:55 arm-linux-elfedit -> arm-none-linux-gnueabi-elfedit*
13 -rwxrwxr-x 1 pengdl pengdl      57 Apr 19 20:00 arm-linux-g++*
14 -rwxrwxr-x 1 pengdl pengdl      57 Apr 19 20:06 arm-linux-gcc*
15 -rwxrwxr-x 1 pengdl pengdl      63 Apr 19 20:02 arm-linux-gcc-4.8.3*
16 lrwxrwxrwx 1 pengdl pengdl      29 Apr 19 19:56 arm-linux-gcc-ar -> arm-none-linux-gnueabi-gcc-ar*
17 lrwxrwxrwx 1 pengdl pengdl      29 Apr 19 19:56 arm-linux-gcc-nm -> arm-none-linux-gnueabi-gcc-nm*
18 lrwxrwxrwx 1 pengdl pengdl      33 Apr 19 19:57 arm-linux-gcc-ranlib -> arm-none-linux-gnueabi-gcc-ranlib*
19 lrwxrwxrwx 1 pengdl pengdl      27 Apr 19 19:57 arm-linux-gcov -> arm-none-linux-gnueabi-gcov*
20 lrwxrwxrwx 1 pengdl pengdl      26 Apr 19 19:57 arm-linux-gdb -> arm-none-linux-gnueabi-gdb*
21 lrwxrwxrwx 1 pengdl pengdl      28 Apr 19 19:57 arm-linux-gprof -> arm-none-linux-gnueabi-gprof*
22 lrwxrwxrwx 1 pengdl pengdl      25 Apr 19 19:57 arm-linux-ld -> arm-none-linux-gnueabi-ld*
23 lrwxrwxrwx 1 pengdl pengdl      25 Apr 19 19:58 arm-linux-nm -> arm-none-linux-gnueabi-nm*
24 lrwxrwxrwx 1 pengdl pengdl      30 Apr 19 19:58 arm-linux-objcopy -> arm-none-linux-gnueabi-objcopy*
25 lrwxrwxrwx 1 pengdl pengdl      30 Apr 19 19:58 arm-linux-objdump -> arm-none-linux-gnueabi-objdump*
26 lrwxrwxrwx 1 pengdl pengdl      29 Apr 19 19:58 arm-linux-ranlib -> arm-none-linux-gnueabi-ranlib*
27 lrwxrwxrwx 1 pengdl pengdl      30 Apr 19 19:58 arm-linux-readelf -> arm-none-linux-gnueabi-readelf*
28 lrwxrwxrwx 1 pengdl pengdl      27 Apr 19 19:58 arm-linux-size -> arm-none-linux-gnueabi-size*
29 lrwxrwxrwx 1 pengdl pengdl      30 Apr 19 19:58 arm-linux-strings -> arm-none-linux-gnueabi-strings*
30 lrwxrwxrwx 1 pengdl pengdl      28 Apr 19 19:58 arm-linux-strip -> arm-none-linux-gnueabi-strip*
31 -rwxr-xr-x 1 pengdl pengdl  736300 May 30  2014 arm-none-linux-gnueabi-addr2line*
32 -rwxr-xr-x 2 pengdl pengdl  763504 May 30  2014 arm-none-linux-gnueabi-ar*
33 -rwxr-xr-x 2 pengdl pengdl 1253360 May 30  2014 arm-none-linux-gnueabi-as*
34 -rwxr-xr-x 2 pengdl pengdl  687056 May 30  2014 arm-none-linux-gnueabi-c++*
35 -rwxr-xr-x 1 pengdl pengdl  734604 May 30  2014 arm-none-linux-gnueabi-c++filt*
36 -rwxr-xr-x 1 pengdl pengdl  686128 May 30  2014 arm-none-linux-gnueabi-cpp*
37 -rwxr-xr-x 1 pengdl pengdl  186548 May 30  2014 arm-none-linux-gnueabi-cs*
38 -rwxr-xr-x 1 pengdl pengdl 2186780 May 30  2014 arm-none-linux-gnueabi-cs-daemon*
39 -rwxr-xr-x 1 pengdl pengdl   24692 May 30  2014 arm-none-linux-gnueabi-elfedit*
40 -rwxr-xr-x 2 pengdl pengdl  687056 May 30  2014 arm-none-linux-gnueabi-g++*
41 -rwxr-xr-x 2 pengdl pengdl  686128 May 30  2014 arm-none-linux-gnueabi-gcc*
42 -rwxr-xr-x 2 pengdl pengdl  686128 May 30  2014 arm-none-linux-gnueabi-gcc-4.8.3*
43 -rwxr-xr-x 1 pengdl pengdl   23608 May 30  2014 arm-none-linux-gnueabi-gcc-ar*
44 -rwxr-xr-x 1 pengdl pengdl   23576 May 30  2014 arm-none-linux-gnueabi-gcc-nm*
45 -rwxr-xr-x 1 pengdl pengdl   23576 May 30  2014 arm-none-linux-gnueabi-gcc-ranlib*
46 -rwxr-xr-x 1 pengdl pengdl  307000 May 30  2014 arm-none-linux-gnueabi-gcov*
47 -rwxr-xr-x 1 pengdl pengdl 4484452 May 30  2014 arm-none-linux-gnueabi-gdb*
48 -rwxr-xr-x 1 pengdl pengdl  805164 May 30  2014 arm-none-linux-gnueabi-gprof*
49 -rwxr-xr-x 2 pengdl pengdl 1200784 May 30  2014 arm-none-linux-gnueabi-ld*
50 -rwxr-xr-x 2 pengdl pengdl  747500 May 30  2014 arm-none-linux-gnueabi-nm*
51 -rwxr-xr-x 2 pengdl pengdl  912812 May 30  2014 arm-none-linux-gnueabi-objcopy*
52 -rwxr-xr-x 2 pengdl pengdl 1109932 May 30  2014 arm-none-linux-gnueabi-objdump*
53 -rwxr-xr-x 2 pengdl pengdl  763504 May 30  2014 arm-none-linux-gnueabi-ranlib*
54 -rwxr-xr-x 1 pengdl pengdl  420160 May 30  2014 arm-none-linux-gnueabi-readelf*
55 -rwxr-xr-x 1 pengdl pengdl  737260 May 30  2014 arm-none-linux-gnueabi-size*
56 -rwxr-xr-x 1 pengdl pengdl  736332 May 30  2014 arm-none-linux-gnueabi-strings*
57 -rwxr-xr-x 2 pengdl pengdl  912812 May 30  2014 arm-none-linux-gnueabi-strip*


即在原来的工具链上面做一些软连接,对arm-linux-gcc/g++/gcc-4.8.3做一些特殊处理:


1 $cat arm-linux-gcc
 2 #!/bin/bash
 3 arm-none-linux-gnueabi-gcc -march=armv4t $*
 4 
 5 $cat arm-linux-g++
 6 #!/bin/bash
 7 arm-none-linux-gnueabi-g++ -march=armv4t $*
 8 
 9 $cat arm-linux-gcc-4.8.3 
10 #!/bin/bash
11 arm-none-linux-gnueabi-gcc-4.8.3 -march=armv4t $*



此外, 还需要注意的是, 将来在制作用于TQ2440的根文件系统的时候拷贝的工具链的lib库的位置:


arm-2014.05/arm-none-linux-gnueabi/libc/armv4t/lib


而不是:


arm-2014.05/arm-none-linux-gnueabi/libc/lib



这个用于高于armv4t架构的平台,如exynos4412用的是armv7架构。

二、Bootloader

使用的uboot可以到https://github.com/pengdonglin137/u-boot下载,


将来的分区稍有变化:



1MB  SPL    


1MB UBOOT    


1MB PARAMS    


5MB KERNEL    

1MB DTB

247MB ROOTFS


由于将来采用NFS挂载根文件系统启动的方式,下面是bootargs以及bootcmd:

bootargs:

noinitrd root=/dev/nfs rw nfsroot=192.168.1.101:/nfsroot/rootfs ethmac=1C:6F:65:34:51:7E ip=192.168.1.6:192.168.1.101:192.168.1.1:255.255.255.0::eth0:off init=/linuxrc console=ttySAC0,115200n



这里板子的IP是192.168.1.6,HOST的IP是192.168.1.101, 当然由于采用了设备树的方式, 所以也可以不在uboot里设置bootargs,而是放到设备树的chosen节点当中。


bootcmd:

nand read 0x300080000x3000000x500000; nand read 0x320000000x8000000x100000; bootm 0x30008000-0x32000000


这里会了加快启动速度, 提前把uImage和dtb文件少些到的nandflash中


三、kernel


可以到 https://github.com/pengdonglin137/linux-4.9下载, tq2440_dt分支, 使用方法参考  讓TQ2440也用上設備樹(1)

烧写kernel和dtb到nand中:



1 烧写kernel:
 2 mw.b 0x30008000 0xff 0x500000
 3 tftp 0x30008000 uImage
 4 nand erase 0x300000 0x500000
 5 nand write 0x30008000 0x300000 0x500000
 6 
 7 烧写dtb:
 8 mw.b 0x30008000 0xff 0x100000
 9 tftp 0x30008000 dtb
10 nand erase 0x800000 0x100000
11 nand write 0x30008000 0x800000 0x100000



四、Python

参考 

交叉编译Python-2.7.13到ARM(aarch32)平台 交叉编译Python-2.7.13到ARM(aarch32)—— 支持sqlite3

交叉编译Python-3.6.0到aarch64/aarch32 —— 支持sqlite3

由于上面两篇博文采用的是qemu模拟的cortex-a9平台,属于armv7架构,而我们的tq2440是armv4架构,所以需要做一些修改。


SQlite

1 #!/bin/bash
 2 
 3 ../sqlite-autoconf-3170000/configure --host=arm-none-linux-gnueabi \
 4         --prefix=`pwd` \
 5         CFLAGS="-march=armv4t" \
 6         CPPFLAGS="-march=armv4t" \
 7         LDFLAGS="-march=armv4t"
 8 
 9 make -j4
10 make install



Readline

1 #!/bin/bash
 2 
 3 ../readline-7.0/configure --host=arm-none-linux-gnueabi \
 4         --prefix=`pwd` \
 5         CFLAGS="-march=armv4t" \
 6         CPPFLAGS="-march=armv4t" \
 7         LDFlAGS="-march=armv4t"
 8 
 9 make -j4
10 make install



Termcap

配置:



1 #!/bin/bash
2 
3 ../termcap-1.3.1/configure --host=arm-none-linux-gnueabi \
4         --prefix=`pwd`



修改Makefile:



1 CC = arm-none-linux-gnueabi-gcc
2 AR = arm-none-linux-gnueabi-ar
3 RANLIB = arm-none-linux-gnueabi-ranlib
4 ... ...
5 CFLAGS = -g -march=armv4t



然后 make && make install



Python3

配置:



1 #!/bin/bash
 2 
 3 ../Python-3.6.0/configure \
 4         --host=arm-linux \
 5         --build=armv4 \
 6         --prefix=`pwd` \
 7         --enable-ipv6 \
 8         --enable-shared \
 9         ac_cv_file__dev_ptmx="yes" \
10         ac_cv_file__dev_ptc="no" \
11         LDFLAGS="-L/home/pengdl/Study/tq2440/Python/SQlite/tq2440/lib \
12         -L/home/pengdl/Study/tq2440/Python/Readline/tq2440/lib \
13         -L/home/pengdl/Study/tq2440/Python/Termcap/tq2440" \
14         CPPFLAGS="-I/home/pengdl/Study/tq2440/Python/SQlite/tq2440/include \
15         -I/home/pengdl/Study/tq2440/Python/Readline/tq2440/include"



别忘了修改Modules/Setup文件,然后执行 make && make install即可。



五、根文件系统

arm 部署python环境 arm移植python_linux


 


下面是制作根文件系统的脚本:


1 #!/bin/bash
 2 
 3 sudo rm -rf rootfs
 4 sudo rm -rf tmpfs
 5 sudo rm -rf ramdisk*
 6 
 7 sudo mkdir rootfs
 8 sudo cp ../busybox-1.24.2/_install/*  rootfs/ -raf
 9 
10 sudo mkdir -p rootfs/proc/
11 sudo mkdir -p rootfs/sys/
12 sudo mkdir -p rootfs/tmp/
13 sudo mkdir -p rootfs/root/
14 sudo mkdir -p rootfs/var/
15 sudo mkdir -p rootfs/mnt/
16 
17 sudo cp etc rootfs/ -arf
18 sudo mkdir -p rootfs/lib
19 
20 sudo cp -arf /home/pengdl/Study/cross_compile/arm-2014.05/arm-none-linux-gnueabi/libc/armv4t/lib/*.so* rootfs/lib
21 
22 #Python3
23 sudo mkdir -p rootfs/usr
24 pushd rootfs/usr
25 sudo cp  -raf /home/pengdl/Study/tq2440/Python/Python3/tq2440/lib .
26 sudo cp  -raf /home/pengdl/Study/tq2440/Python/Python3/tq2440/include .
27 sudo cp  -raf /home/pengdl/Study/tq2440/Python/Python3/tq2440/bin .
28 sudo cp  -raf /home/pengdl/Study/tq2440/Python/Python3/tq2440/share .
29 sudo arm-none-linux-gnueabi-strip lib/python*
30 popd
31 
32 #sqlite3
33 sudo cp -raf /home/pengdl/Study/tq2440/Python/SQlite/tq2440/bin/* rootfs/bin
34 sudo cp -raf /home/pengdl/Study/tq2440/Python/SQlite/tq2440/include/* rootfs/include
35 sudo cp -raf /home/pengdl/Study/tq2440/Python/SQlite/tq2440/lib/* rootfs/lib
36 sudo cp -raf /home/pengdl/Study/tq2440/Python/SQlite/tq2440/share/* rootfs/usr/share
37 sudo arm-linux-strip rootfs/bin/sqlite3
38 
39 #readline
40 sudo cp -raf /home/pengdl/Study/tq2440/Python/Readline/tq2440/include/* rootfs/include
41 sudo cp -raf /home/pengdl/Study/tq2440/Python/Readline/tq2440/lib/* rootfs/lib
42 
43 sudo rm -f rootfs/lib/libwv* rootfs/lib/libuniconf*
44 sudo rm -f rootfs/lib/*.a
45 sudo rm -f rootfs/lib/*.la
46 sudo arm-none-linux-gnueabi-strip rootfs/lib/*
47 
48 sudo mkdir -p rootfs/dev/
49 sudo mknod rootfs/dev/tty1 c 4 1
50 sudo mknod rootfs/dev/tty2 c 4 2
51 sudo mknod rootfs/dev/tty3 c 4 3
52 sudo mknod rootfs/dev/tty4 c 4 4
53 sudo mknod rootfs/dev/console c 5 1
54 sudo mknod rootfs/dev/null c 1 3
55 
56 sudo rm /nfsroot/rootfs_bak -rf
57 sudo mv /nfsroot/rootfs /nfsroot/rootfs_bak
58 sudo cp ./rootfs /nfsroot/ -raf


六、测试


启动log

1 U-Boot 2015.04-g5095150 (Dec 21 2015 - 06:17:05)
  2 CPUID: 32440001
  3 FCLK:      400 MHz
  4 HCLK:      100 MHz
  5 PCLK:       50 MHz
  6 I2C:   ready
  7 DRAM:  64 MiB
  8 WARNING: Caches not enabled
  9 Flash: 0 Bytes
 10 NAND:  256 MiB
 11 In:    serial
 12 Out:   serial
 13 Err:   serial
 14 Net:   dm9000
 15 Hit any key to stop autoboot:  0 
 16 NAND read: device 0 offset 0x300000, size 0x500000
 17  5242880 bytes read: OK
 18 NAND read: device 0 offset 0x800000, size 0x100000
 19  1048576 bytes read: OK
 20 ## Booting kernel from Legacy Image at 30008000 ...
 21    Image Name:   Linux-4.9.0+
 22    Created:      2017-04-19   9:51:19 UTC
 23    Image Type:   ARM Linux Kernel Image (uncompressed)
 24    Data Size:    3503832 Bytes = 3.3 MiB
 25    Load Address: 30008000
 26    Entry Point:  30008000
 27    Verifying Checksum ... OK
 28 ## Flattened Device Tree blob at 32000000
 29    Booting using the fdt blob at 0x32000000
 30    Loading Kernel Image ... OK
 31    Loading Device Tree to 33aa6000, end 33aaa62c ... OK
 32 Starting kernel ...
 33 Uncompressing Linux... done, booting the kernel.
 34 [    0.000000] Booting Linux on physical CPU 0x0
 35 [    0.000000] Linux version 4.9.0+ (pengdl@ubuntu) (gcc version 4.8.3 20140320 (prerelease) (Sourcery CodeBench Lite 2014.05-29) ) #1 Wed Apr 19 02:51:06 PDT 2017
 36 [    0.000000] CPU: ARM920T [41129200] revision 0 (ARMv4T), cr=c000717f
 37 [    0.000000] CPU: VIVT data cache, VIVT instruction cache
 38 [    0.000000] OF: fdt:Machine model: TQ2440
 39 [    0.000000] Memory policy: Data cache writeback
 40 [    0.000000] DT missing boot CPU MPIDR[23:0], fall back to default cpu_logical_map
 41 [    0.000000] Built 1 zonelists in Zone order, mobility grouping on.  Total pages: 16256
 42 [    0.000000] Kernel command line: noinitrd root=/dev/nfs rw nfsroot=192.168.1.101:/nfsroot/rootfs ethmac=1C:6F:65:34:51:7E ip=192.168.1.6:192.168.1.101:192.168.1.1:255.255.255.0::eth0:off init=/linuxrc console=ttySAC0,115200n
 43 [    0.000000] PID hash table entries: 256 (order: -2, 1024 bytes)
 44 [    0.000000] Dentry cache hash table entries: 8192 (order: 3, 32768 bytes)
 45 [    0.000000] Inode-cache hash table entries: 4096 (order: 2, 16384 bytes)
 46 [    0.000000] Memory: 57900K/65536K available (4729K kernel code, 234K rwdata, 1376K rodata, 204K init, 262K bss, 7636K reserved, 0K cma-reserved)
 47 [    0.000000] Virtual kernel memory layout:
 48 [    0.000000]     vector  : 0xffff0000 - 0xffff1000   (   4 kB)
 49 [    0.000000]     fixmap  : 0xffc00000 - 0xfff00000   (3072 kB)
 50 [    0.000000]     vmalloc : 0xc4800000 - 0xff800000   ( 944 MB)
 51 [    0.000000]     lowmem  : 0xc0000000 - 0xc4000000   (  64 MB)
 52 [    0.000000]     modules : 0xbf000000 - 0xc0000000   (  16 MB)
 53 [    0.000000]       .text : 0xc0008000 - 0xc04a67f0   (4730 kB)
 54 [    0.000000]       .init : 0xc0627000 - 0xc065a000   ( 204 kB)
 55 [    0.000000]       .data : 0xc065a000 - 0xc0694840   ( 235 kB)
 56 [    0.000000]        .bss : 0xc0694840 - 0xc06d60a8   ( 263 kB)
 57 [    0.000000] SLUB: HWalign=32, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
 58 [    0.000000] NR_IRQS:103
 59 [    0.000000] irq: clearing pending status 00000002
 60 [    0.000000] _get_rate: could not find clock xti
 61 [    0.000131] sched_clock: 16 bits at 1000kHz, resolution 1000ns, wraps every 32767500ns
 62 [    0.000254] clocksource: samsung_clocksource_timer: mask: 0xffff max_cycles: 0xffff, max_idle_ns: 29163075 ns
 63 [    0.001154] Console: colour dummy device 80x30
 64 [    0.001358] Calibrating delay loop... 199.47 BogoMIPS (lpj=498688)
 65 [    0.035124] pid_max: default: 32768 minimum: 301
 66 [    0.035715] Mount-cache hash table entries: 1024 (order: 0, 4096 bytes)
 67 [    0.035803] Mountpoint-cache hash table entries: 1024 (order: 0, 4096 bytes)
 68 [    0.039125] CPU: Testing write buffer coherency: ok
 69 [    0.041720] Setting up static identity map for 0x30008200 - 0x30008258
 70 [    0.067396] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 9556302231375000 ns
 71 [    0.068020] pinctrl core: initialized pinctrl subsystem
 72 [    0.071279] NET: Registered protocol family 16
 73 [    0.074528] DMA: preallocated 256 KiB pool for atomic coherent allocations
 74 [    0.096698] cpuidle: using governor ladder
 75 [    0.097401] No ATAGs?
 76 [    0.357763] SCSI subsystem initialized
 77 [    0.359225] usbcore: registered new interface driver usbfs
 78 [    0.359894] usbcore: registered new interface driver hub
 79 [    0.360865] usbcore: registered new device driver usb
 80 [    0.364272] Advanced Linux Sound Architecture Driver Initialized.
 81 [    0.395750] clocksource: Switched to clocksource samsung_clocksource_timer
 82 [    0.462505] NET: Registered protocol family 2
 83 [    0.466700] TCP established hash table entries: 1024 (order: 0, 4096 bytes)
 84 [    0.466838] TCP bind hash table entries: 1024 (order: 0, 4096 bytes)
 85 [    0.466899] TCP: Hash tables configured (established 1024 bind 1024)
 86 [    0.467514] UDP hash table entries: 256 (order: 0, 4096 bytes)
 87 [    0.467638] UDP-Lite hash table entries: 256 (order: 0, 4096 bytes)
 88 [    0.468746] NET: Registered protocol family 1
 89 [    0.547937] RPC: Registered named UNIX socket transport module.
 90 [    0.548047] RPC: Registered udp transport module.
 91 [    0.548062] RPC: Registered tcp transport module.
 92 [    0.548076] RPC: Registered tcp NFSv4.1 backchannel transport module.
 93 [    0.556526] futex hash table entries: 256 (order: -1, 3072 bytes)
 94 [    0.565590] workingset: timestamp_bits=30 max_order=14 bucket_order=0
 95 [    0.699034] NFS: Registering the id_resolver key type
 96 [    0.699281] Key type id_resolver registered
 97 [    0.699297] Key type id_legacy registered
 98 [    0.699372] nfs4filelayout_init: NFSv4 File Layout Driver Registering...
 99 [    0.699649] jffs2: version 2.2. (NAND) © 2001-2006 Red Hat, Inc.
100 [    0.709262] romfs: ROMFS MTD (C) 2007 Red Hat, Inc.
101 [    0.730545] io scheduler noop registered
102 [    0.730657] io scheduler deadline registered
103 [    0.732323] io scheduler cfq registered (default)
104 [    0.947381] 50000000.serial: ttySAC0 at MMIO 0x50000000 (irq = 32, base_baud = 0) is a S3C2440
105 [    1.387359] random: fast init done
106 [    1.611283] console [ttySAC0] enabled
107 [    1.767633] brd: module loaded
108 [    1.772241] s3c24xx-nand 4e000000.nand: Tacls=1, 10ns Twrph0=3 30ns, Twrph1=1 10ns
109 [    1.774282] s3c24xx-nand 4e000000.nand: NAND ECC disabled
110 [    1.780114] nand: device found, Manufacturer ID: 0xec, Chip ID: 0xda
111 [    1.786112] nand: Samsung NAND 256MiB 3,3V 8-bit
112 [    1.790528] nand: 256 MiB, SLC, erase size: 128 KiB, page size: 2048, OOB size: 64
113 [    1.798195] nand: NAND_ECC_NONE selected by board driver. This is not recommended!
114 [    1.805811] Scanning device for bad blocks
115 [    1.835095] Bad eraseblock 364 at 0x000002d80000
116 [    1.835485] Bad eraseblock 369 at 0x000002e20000
117 [    1.848196] Bad eraseblock 558 at 0x0000045c0000
118 [    1.884281] Bad eraseblock 1291 at 0x00000a160000
119 [    1.909046] Bad eraseblock 1792 at 0x00000e000000
120 [    1.909215] Bad eraseblock 1793 at 0x00000e020000
121 [    1.925484] Creating 6 MTD partitions on "tq2440-0":
122 [    1.925650] 0x000000000000-0x000000100000 : "SPL"
123 [    1.934143] ftl_cs: FTL header not found.
124 [    1.941575] 0x000000100000-0x000000200000 : "U-BOOT"
125 [    1.949569] ftl_cs: FTL header not found.
126 [    1.954926] 0x000000200000-0x000000300000 : "PARAMS"
127 [    1.963831] ftl_cs: FTL header not found.
128 [    1.969370] 0x000000300000-0x000000600000 : "KERNEL"
129 [    1.978445] ftl_cs: FTL header not found.
130 [    1.984058] 0x000000600000-0x000000700000 : "DTB"
131 [    1.993049] ftl_cs: FTL header not found.
132 [    1.998630] 0x000000700000-0x000010000000 : "ROOTFS"
133 [    2.010883] ftl_cs: FTL header not found.
134 [    2.023036] eth0: dm9000e at c4932000,c4934004 IRQ 7 MAC: 00:00:de:ad:be:ef (platform data)
135 [    2.026768] ohci_hcd: USB 1.1 'Open' Host Controller (OHCI) Driver
136 [    2.032382] ohci-s3c2410: OHCI S3C2410 driver
137 [    2.039610] s3c2410-ohci 49000000.usb_ohci: OHCI Host Controller
138 [    2.042708] s3c2410-ohci 49000000.usb_ohci: new USB bus registered, assigned bus number 1
139 [    2.051552] s3c2410-ohci 49000000.usb_ohci: irq 26, io mem 0x49000000
140 [    2.124944] hub 1-0:1.0: USB hub found
141 [    2.127292] hub 1-0:1.0: 2 ports detected
142 [    2.133433] usbcore: registered new interface driver usb-storage
143 [    2.136449] mousedev: PS/2 mouse device common for all mice
144 [    2.141909] s3c-rtc 57000000.rtc: rtc disabled, re-enabling
145 [    2.145961] rtc rtc0: alarm rollover not handled
146 [    2.149532] rtc rtc0: invalid alarm value: 1900-2-1 0:0:0
147 [    2.156227] s3c-rtc 57000000.rtc: rtc core: registered s3c as rtc0
148 [    2.162236] i2c /dev entries driver
149 [    2.168574] s3c2410-wdt 53000000.watchdog: watchdog inactive, reset disabled, irq disabled
150 [    2.175323] sdhci: Secure Digital Host Controller Interface driver
151 [    2.178802] sdhci: Copyright(c) Pierre Ossman
152 [    2.185919] hidraw: raw HID events driver (C) Jiri Kosina
153 [    2.197719] usbcore: registered new interface driver usbhid
154 [    2.197849] usbhid: USB HID core driver
155 [    2.206738] NET: Registered protocol family 17
156 [    2.207505] Key type dns_resolver registered
157 [    2.272831] s3c-rtc 57000000.rtc: setting system clock to 2000-04-11 20:01:10 UTC (955483270)
158 [    2.305173] dm9000 20000000.ethernet eth0: link down
159 [    4.410138] dm9000 20000000.ethernet eth0: link up, 100Mbps, full-duplex, lpa 0xCDE1
160 [    4.412435] IP-Config: Complete:
161 [    4.415784]      device=eth0, hwaddr=00:00:de:ad:be:ef, ipaddr=192.168.1.6, mask=255.255.255.0, gw=192.168.1.1
162 [    4.425577]      host=192.168.1.6, domain=, nis-domain=(none)
163 [    4.431373]      bootserver=192.168.1.101, rootserver=192.168.1.101, rootpath=
164 [    4.439728] ALSA device list:
165 [    4.441430]   No soundcards found.
166 [    4.489327] VFS: Mounted root (nfs filesystem) on device 0:12.
167 [    4.491287] Freeing unused kernel memory: 204K (c0627000 - c065a000)
168 [    4.496048] This architecture does not have kernel memory protection.
169 Please press Enter to activate this console. 
170 [root@tq2440 ]# 
171 [root@tq2440 ]# 
172 [root@tq2440 ]# ls
173 bin      etc      lib      mnt      root     sys      usr
174 dev      include  linuxrc  proc     sbin     tmp      var


测试1


1 [root@tq2440 ]# python3
2 Python 3.6.0 (default, Apr 19 2017, 20:20:18) 
3 [GCC 4.8.3 20140320 (prerelease)] on linux
4 Type "help", "copyright", "credits" or "license" for more information.
5 >>> print("Hello World")
6 Hello World
7 >>> import sqlite3
8 >>>


测试2

1 [root@tq2440 ]# python3 /usr/lib/python3.6/test/test___all__.py 
 2 __phello__.foo
 3 _bootlocale
 4 _collections_abc
 5 _compat_pickle
 6 _compression
 7 _dummy_thread
 8 _markupbase
 9 _osx_support
10 ... ...
11 .
12 ----------------------------------------------------------------------
13 Ran 1 test in 97.391s
14 OK