blob: a7bd1a75e8ace3e0371010b093f078c450ff9445 [file] [log] [blame]
Bin Meng86589982019-07-18 00:34:18 -07001.. SPDX-License-Identifier: GPL-2.0+
2
3AX25-AE350
4==========
5
6AE350 is the mainline SoC produced by Andes Technology using AX25 CPU core
7base on RISC-V architecture.
8
9AE350 has integrated both AHB and APB bus and many periphals for application
10and product development.
11
12AX25-AE350 is the SoC with AE350 hardcore CPU.
13
14AX25 is Andes CPU IP to adopt RISC-V architecture.
15
16AX25 Features
17-------------
18
19CPU Core
20 - 5-stage in-order execution pipeline
21 - Hardware Multiplier
22 - radix-2/radix-4/radix-16/radix-256/fast
23 - Hardware Divider
24 - Optional branch prediction
25 - Machine mode and optional user mode
26 - Optional performance monitoring
27
28ISA
29 - RV64I base integer instructions
30 - RVC for 16-bit compressed instructions
31 - RVM for multiplication and division instructions
32
33Memory subsystem
34 - I & D local memory
35 - Size: 4KB to 16MB
36 - Memory subsyetem soft-error protection
37 - Protection scheme: parity-checking or error-checking-and-correction (ECC)
38 - Automatic hardware error correction
39
40Bus
41 - Interface Protocol
42 - Synchronous AHB (32-bit/64-bit data-width), or
43 - Synchronous AXI4 (64-bit data-width)
44
45Power management
46 - Wait for interrupt (WFI) mode
47
48Debug
49 - Configurable number of breakpoints: 2/4/8
50 - External Debug Module
51 - AHB slave port
52 - External JTAG debug transport module
53
54Platform Level Interrupt Controller (PLIC)
55 - AHB slave port
56 - Configurable number of interrupts: 1-1023
57 - Configurable number of interrupt priorities: 3/7/15/63/127/255
58 - Configurable number of targets: 1-16
59 - Preempted interrupt priority stack
60
61Configurations
62--------------
63
64CONFIG_SKIP_LOWLEVEL_INIT:
65 If you want to boot this system from SPI ROM and bypass e-bios (the
66 other boot loader on ROM). You should undefine CONFIG_SKIP_LOWLEVEL_INIT
67 in "include/configs/ax25-ae350.h".
68
69Build and boot steps
70--------------------
71
72Build:
73
741. Prepare the toolchains and make sure the $PATH to toolchains is correct.
752. Use `make ae350_rv[32|64]_defconfig` in u-boot root to build the image for
76 32 or 64 bit.
77
78Verification:
79
801. startup
812. relocation
823. timer driver
834. uart driver
845. mac driver
856. mmc driver
867. spi driver
87
88Steps
89-----
90
911. Define CONFIG_SKIP_LOWLEVEL_INIT to build u-boot which is loaded via gdb from ram.
922. Undefine CONFIG_SKIP_LOWLEVEL_INIT to build u-boot which is booted from spi rom.
933. Ping a server by mac driver
944. Scan sd card and copy u-boot image which is booted from flash to ram by sd driver.
955. Burn this u-boot image to spi rom by spi driver
966. Re-boot u-boot from spi flash with power off and power on.
97
98Messages of U-Boot boot on AE350 board
99--------------------------------------
100
101.. code-block:: none
102
103 U-Boot 2018.01-rc2-00033-g824f89a (Dec 21 2017 - 16:51:26 +0800)
104
105 DRAM: 1 GiB
106 MMC: mmc@f0e00000: 0
107 SF: Detected mx25u1635e with page size 256 Bytes, erase size 4 KiB, total 2 MiB
108 In: serial@f0300000
109 Out: serial@f0300000
110 Err: serial@f0300000
111 Net:
112 Warning: mac@e0100000 (eth0) using random MAC address - be:dd:d7:e4:e8:10
113 eth0: mac@e0100000
114
115 RISC-V # version
116 U-Boot 2018.01-rc2-00033-gb265b91-dirty (Dec 22 2017 - 13:54:21 +0800)
117
118 riscv32-unknown-linux-gnu-gcc (GCC) 7.2.0
119 GNU ld (GNU Binutils) 2.29
120
121 RISC-V # setenv ipaddr 10.0.4.200 ;
122 RISC-V # setenv serverip 10.0.4.97 ;
123 RISC-V # ping 10.0.4.97 ;
124 Using mac@e0100000 device
125 host 10.0.4.97 is alive
126
127 RISC-V # mmc rescan
128 RISC-V # fatls mmc 0:1
129 318907 u-boot-ae350-64.bin
130 1252 hello_world_ae350_32.bin
131 328787 u-boot-ae350-32.bin
132
133 3 file(s), 0 dir(s)
134
135 RISC-V # sf probe 0:0 50000000 0
136 SF: Detected mx25u1635e with page size 256 Bytes, erase size 4 KiB, total 2 MiB
137
138 RISC-V # sf test 0x100000 0x1000
139 SPI flash test:
140 0 erase: 36 ticks, 111 KiB/s 0.888 Mbps
141 1 check: 29 ticks, 137 KiB/s 1.096 Mbps
142 2 write: 40 ticks, 100 KiB/s 0.800 Mbps
143 3 read: 20 ticks, 200 KiB/s 1.600 Mbps
144 Test passed
145 0 erase: 36 ticks, 111 KiB/s 0.888 Mbps
146 1 check: 29 ticks, 137 KiB/s 1.096 Mbps
147 2 write: 40 ticks, 100 KiB/s 0.800 Mbps
148 3 read: 20 ticks, 200 KiB/s 1.600 Mbps
149
150 RISC-V # fatload mmc 0:1 0x600000 u-boot-ae350-32.bin
151 reading u-boot-ae350-32.bin
152 328787 bytes read in 324 ms (990.2 KiB/s)
153
154 RISC-V # sf erase 0x0 0x51000
155 SF: 331776 bytes @ 0x0 Erased: OK
156
157 RISC-V # sf write 0x600000 0x0 0x50453
158 device 0 offset 0x0, size 0x50453
159 SF: 328787 bytes @ 0x0 Written: OK
160
161 RISC-V # crc32 0x600000 0x50453
162 crc32 for 00600000 ... 00650452 ==> 692dc44a
163
164 RISC-V # crc32 0x80000000 0x50453
165 crc32 for 80000000 ... 80050452 ==> 692dc44a
166 RISC-V #
167
168 *** power-off and power-on, this U-Boot is booted from spi flash ***
169
170 U-Boot 2018.01-rc2-00032-gf67dd47-dirty (Dec 21 2017 - 13:56:03 +0800)
171
172 DRAM: 1 GiB
173 MMC: mmc@f0e00000: 0
174 SF: Detected mx25u1635e with page size 256 Bytes, erase size 4 KiB, total 2 MiB
175 In: serial@f0300000
176 Out: serial@f0300000
177 Err: serial@f0300000
178 Net:
179 Warning: mac@e0100000 (eth0) using random MAC address - ee:4c:58:29:32:f5
180 eth0: mac@e0100000
181 RISC-V #
182
183
184Boot bbl and riscv-linux via U-Boot on QEMU
185-------------------------------------------
186
1871. Build riscv-linux
1882. Build bbl and riscv-linux with --with-payload
1893. Prepare ae350.dtb
1904. Creating OS-kernel images
191
192.. code-block:: none
193
194 ./mkimage -A riscv -O linux -T kernel -C none -a 0x0000 -e 0x0000 -d bbl.bin bootmImage-bbl.bin
195 Image Name:
196 Created: Tue Mar 13 10:06:42 2018
197 Image Type: RISC-V Linux Kernel Image (uncompressed)
198 Data Size: 17901204 Bytes = 17481.64 KiB = 17.07 MiB
199 Load Address: 00000000
200 Entry Point: 00000000
201
2025. Copy bootmImage-bbl.bin and ae350.dtb to qemu sd card image
2036. Message of booting riscv-linux from bbl via u-boot on qemu
204
205.. code-block:: none
206
207 U-Boot 2018.03-rc4-00031-g2631273 (Mar 13 2018 - 15:02:55 +0800)
208
209 DRAM: 1 GiB
210 main-loop: WARNING: I/O thread spun for 1000 iterations
211 MMC: mmc@f0e00000: 0
212 Loading Environment from SPI Flash... *** Warning - spi_flash_probe_bus_cs() failed, using default environment
213
214 Failed (-22)
215 In: serial@f0300000
216 Out: serial@f0300000
217 Err: serial@f0300000
218 Net:
219 Warning: mac@e0100000 (eth0) using random MAC address - 02:00:00:00:00:00
220 eth0: mac@e0100000
221 RISC-V # mmc rescan
222 RISC-V # mmc part
223
224 Partition Map for MMC device 0 -- Partition Type: DOS
225
226 Part Start Sector Num Sectors UUID Type
227 RISC-V # fatls mmc 0:0
228 17901268 bootmImage-bbl.bin
229 1954 ae2xx.dtb
230
231 2 file(s), 0 dir(s)
232
233 RISC-V # fatload mmc 0:0 0x00600000 bootmImage-bbl.bin
234 17901268 bytes read in 4642 ms (3.7 MiB/s)
235 RISC-V # fatload mmc 0:0 0x2000000 ae350.dtb
236 1954 bytes read in 1 ms (1.9 MiB/s)
237 RISC-V # setenv bootm_size 0x2000000
238 RISC-V # setenv fdt_high 0x1f00000
239 RISC-V # bootm 0x00600000 - 0x2000000
240 ## Booting kernel from Legacy Image at 00600000 ...
241 Image Name:
242 Image Type: RISC-V Linux Kernel Image (uncompressed)
243 Data Size: 17901204 Bytes = 17.1 MiB
244 Load Address: 00000000
245 Entry Point: 00000000
246 Verifying Checksum ... OK
247 ## Flattened Device Tree blob at 02000000
248 Booting using the fdt blob at 0x2000000
249 Loading Kernel Image ... OK
250 Loading Device Tree to 0000000001efc000, end 0000000001eff7a1 ... OK
251 [ 0.000000] OF: fdt: Ignoring memory range 0x0 - 0x200000
252 [ 0.000000] Linux version 4.14.0-00046-gf3e439f-dirty (rick@atcsqa06) (gcc version 7.1.1 20170509 (GCC)) #1 Tue Jan 9 16:34:25 CST 2018
253 [ 0.000000] bootconsole [early0] enabled
254 [ 0.000000] Initial ramdisk at: 0xffffffe000016a98 (12267008 bytes)
255 [ 0.000000] Zone ranges:
256 [ 0.000000] DMA [mem 0x0000000000200000-0x000000007fffffff]
257 [ 0.000000] Normal empty
258 [ 0.000000] Movable zone start for each node
259 [ 0.000000] Early memory node ranges
260 [ 0.000000] node 0: [mem 0x0000000000200000-0x000000007fffffff]
261 [ 0.000000] Initmem setup node 0 [mem 0x0000000000200000-0x000000007fffffff]
262 [ 0.000000] elf_hwcap is 0x112d
263 [ 0.000000] random: fast init done
264 [ 0.000000] Built 1 zonelists, mobility grouping on. Total pages: 516615
265 [ 0.000000] Kernel command line: console=ttyS0,38400n8 earlyprintk=uart8250-32bit,0xf0300000 debug loglevel=7
266 [ 0.000000] PID hash table entries: 4096 (order: 3, 32768 bytes)
267 [ 0.000000] Dentry cache hash table entries: 262144 (order: 9, 2097152 bytes)
268 [ 0.000000] Inode-cache hash table entries: 131072 (order: 8, 1048576 bytes)
269 [ 0.000000] Sorting __ex_table...
270 [ 0.000000] Memory: 2047832K/2095104K available (1856K kernel code, 204K rwdata, 532K rodata, 12076K init, 756K bss, 47272K reserved, 0K cma-reserved)
271 [ 0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
272 [ 0.000000] NR_IRQS: 0, nr_irqs: 0, preallocated irqs: 0
273 [ 0.000000] riscv,cpu_intc,0: 64 local interrupts mapped
274 [ 0.000000] riscv,plic0,e4000000: mapped 31 interrupts to 1/2 handlers
275 [ 0.000000] clocksource: riscv_clocksource: mask: 0xffffffffffffffff max_cycles: 0x24e6a1710, max_idle_ns: 440795202120 ns
276 [ 0.000000] Calibrating delay loop (skipped), value calculated using timer frequency.. 20.00 BogoMIPS (lpj=40000)
277 [ 0.000000] pid_max: default: 32768 minimum: 301
278 [ 0.004000] Mount-cache hash table entries: 4096 (order: 3, 32768 bytes)
279 [ 0.004000] Mountpoint-cache hash table entries: 4096 (order: 3, 32768 bytes)
280 [ 0.056000] devtmpfs: initialized
281 [ 0.060000] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 7645041785100000 ns
282 [ 0.064000] futex hash table entries: 256 (order: 0, 6144 bytes)
283 [ 0.068000] NET: Registered protocol family 16
284 [ 0.080000] vgaarb: loaded
285 [ 0.084000] clocksource: Switched to clocksource riscv_clocksource
286 [ 0.088000] NET: Registered protocol family 2
287 [ 0.092000] TCP established hash table entries: 16384 (order: 5, 131072 bytes)
288 [ 0.096000] TCP bind hash table entries: 16384 (order: 5, 131072 bytes)
289 [ 0.096000] TCP: Hash tables configured (established 16384 bind 16384)
290 [ 0.100000] UDP hash table entries: 1024 (order: 3, 32768 bytes)
291 [ 0.100000] UDP-Lite hash table entries: 1024 (order: 3, 32768 bytes)
292 [ 0.104000] NET: Registered protocol family 1
293 [ 0.616000] Unpacking initramfs...
294 [ 1.220000] workingset: timestamp_bits=62 max_order=19 bucket_order=0
295 [ 1.244000] io scheduler noop registered
296 [ 1.244000] io scheduler cfq registered (default)
297 [ 1.244000] io scheduler mq-deadline registered
298 [ 1.248000] io scheduler kyber registered
299 [ 1.360000] Serial: 8250/16550 driver, 4 ports, IRQ sharing disabled
300 [ 1.368000] console [ttyS0] disabled
301 [ 1.372000] f0300000.serial: ttyS0 at MMIO 0xf0300020 (irq = 10, base_baud = 1228800) is a 16550A
302 [ 1.392000] console [ttyS0] enabled
303 [ 1.392000] ftmac100: Loading version 0.2 ...
304 [ 1.396000] ftmac100 e0100000.mac eth0: irq 8, mapped at ffffffd002005000
305 [ 1.400000] ftmac100 e0100000.mac eth0: generated random MAC address 6e:ac:c3:92:36:c0
306 [ 1.404000] IR NEC protocol handler initialized
307 [ 1.404000] IR RC5(x/sz) protocol handler initialized
308 [ 1.404000] IR RC6 protocol handler initialized
309 [ 1.404000] IR JVC protocol handler initialized
310 [ 1.408000] IR Sony protocol handler initialized
311 [ 1.408000] IR SANYO protocol handler initialized
312 [ 1.408000] IR Sharp protocol handler initialized
313 [ 1.408000] IR MCE Keyboard/mouse protocol handler initialized
314 [ 1.412000] IR XMP protocol handler initialized
315 [ 1.456000] ftsdc010 f0e00000.mmc: mmc0 - using hw SDIO IRQ
316 [ 1.464000] bootconsole [early0] uses init memory and must be disabled even before the real one is ready
317 [ 1.464000] bootconsole [early0] disabled
318 [ 1.508000] Freeing unused kernel memory: 12076K
319 [ 1.512000] This architecture does not have kernel memory protection.
320 [ 1.520000] mmc0: new SD card at address 4567
321 [ 1.524000] mmcblk0: mmc0:4567 QEMU! 20.0 MiB
322 [ 1.844000] mmcblk0:
323 Wed Dec 1 10:00:00 CST 2010
324 / #
325
326
Rick Chen8e9d1722019-11-14 13:52:30 +0800327Running U-Boot SPL
328------------------
329The U-Boot SPL will boot in M mode and load the FIT image which include
330OpenSBI and U-Boot proper images. After loading progress, it will jump
331to OpenSBI first and then U-Boot proper which will run in S mode.
332
333
334How to build U-Boot SPL
335-----------------------
336Before building U-Boot SPL, OpenSBI must be build first. OpenSBI can be
337cloned and build for AE350 as below:
338
339git clone https://github.com/riscv/opensbi.git
340cd opensbi
341make PLATFORM=andes/ae350
342
343Copy OpenSBI FW_DYNAMIC image (build\platform\andes\ae350\firmware\fw_dynamic.bin)
344into U-Boot root directory
345
346
347How to build U-Boot SPL booting from RAM
348----------------------------------------
349With ae350_rv[32|64]_spl_defconfigs:
350
351U-Boot SPL will be loaded by gdb or FSBL and runs in RAM in machine mode
352and then load FIT image from RAM device on AE350.
353
354
355How to build U-Boot SPL booting from ROM
356----------------------------------------
357With ae350_rv[32|64]_spl_xip_defconfigs:
358
359U-Boot SPL can be burned into SPI flash and run in flash in machine mode
360and then load FIT image from SPI flash or MMC device on AE350.
361
362
363Messages of U-Boot SPL boots Kernel on AE350 board
364--------------------------------------------------
365
366.. code-block:: none
367
368U-Boot SPL 2020.01-rc1-00292-g67a3313-dirty (Nov 14 2019 - 11:26:21 +0800)
369Trying to boot from RAM
370
371OpenSBI v0.5-1-gdd8ef28 (Nov 14 2019 11:08:39)
372 ____ _____ ____ _____
373 / __ \ / ____| _ \_ _|
374 | | | |_ __ ___ _ __ | (___ | |_) || |
375 | | | | '_ \ / _ \ '_ \ \___ \| _ < | |
376 | |__| | |_) | __/ | | |____) | |_) || |_
377 \____/| .__/ \___|_| |_|_____/|____/_____|
378 | |
379 |_|
380
381Platform Name : Andes AE350
382Platform HART Features : RV64ACIMSUX
383Platform Max HARTs : 4
384Current Hart : 0
385Firmware Base : 0x0
386Firmware Size : 84 KB
387Runtime SBI Version : 0.2
388
389PMP0: 0x0000000000000000-0x000000000001ffff (A)
390PMP1: 0x0000000000000000-0x00000001ffffffff (A,R,W,X)
391
392
393U-Boot 2020.01-rc1-00292-g67a3313-dirty (Nov 14 2019 - 11:26:21 +0800)
394
395DRAM: 1 GiB
396Flash: 64 MiB
397MMC: mmc@f0e00000: 0
398Loading Environment from SPI Flash... SF: Detected mx25u1635e with page size 256 Bytes, erase size 4 KiB, total 2 MiB
399OK
400In: serial@f0300000
401Out: serial@f0300000
402Err: serial@f0300000
403Net: no alias for ethernet0
404
405Warning: mac@e0100000 (eth0) using random MAC address - a2:ae:93:7b:cc:8f
406eth0: mac@e0100000
407Hit any key to stop autoboot: 0
4086455 bytes read in 31 ms (203.1 KiB/s)
40920421684 bytes read in 8647 ms (2.3 MiB/s)
410## Booting kernel from Legacy Image at 00600000 ...
411 Image Name:
412 Image Type: RISC-V Linux Kernel Image (uncompressed)
413 Data Size: 20421620 Bytes = 19.5 MiB
414 Load Address: 00200000
415 Entry Point: 00200000
416 Verifying Checksum ... OK
417## Flattened Device Tree blob at 20000000
418 Booting using the fdt blob at 0x20000000
419 Loading Kernel Image
420 Loading Device Tree to 000000001effb000, end 000000001efff936 ... OK
421
422Starting kernel ...
423
424OF: fdt: Ignoring memory range 0x0 - 0x200000
425Linux version 4.17.0-00253-g49136e10bcb2 (sqa@atcsqa07) (gcc version 7.3.0 (2019-04-06_nds64le-linux-glibc-v5_experimental)) #1 SMP PREEMPT Sat Apr 6 23:41:49 CST 2019
426bootconsole [early0] enabled
427Initial ramdisk at: 0x (ptrval) (13665712 bytes)
428Zone ranges:
429 DMA32 [mem 0x0000000000200000-0x000000003fffffff]
430 Normal empty
431Movable zone start for each node
432Early memory node ranges
433 node 0: [mem 0x0000000000200000-0x000000003fffffff]
434Initmem setup node 0 [mem 0x0000000000200000-0x000000003fffffff]
435software IO TLB [mem 0x3b1f8000-0x3f1f8000] (64MB) mapped at [ (ptrval)- (ptrval)]
436elf_platform is rv64i2p0m2p0a2p0c2p0xv5-0p0
437compatible privileged spec version 1.10
438percpu: Embedded 16 pages/cpu @ (ptrval) s28184 r8192 d29160 u65536
439Built 1 zonelists, mobility grouping on. Total pages: 258055
440Kernel command line: console=ttyS0,38400n8 debug loglevel=7
441log_buf_len individual max cpu contribution: 4096 bytes
442log_buf_len total cpu_extra contributions: 12288 bytes
443log_buf_len min size: 16384 bytes
444log_buf_len: 32768 bytes
445early log buf free: 14608(89%)
446Dentry cache hash table entries: 131072 (order: 8, 1048576 bytes)
447Inode-cache hash table entries: 65536 (order: 7, 524288 bytes)
448Sorting __ex_table...
449Memory: 944428K/1046528K available (3979K kernel code, 246K rwdata, 1490K rodata, 13523K init, 688K bss, 102100K reserved, 0K cma-reserved)
450SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=4, Nodes=1
451Preemptible hierarchical RCU implementation.
452 Tasks RCU enabled.
453NR_IRQS: 72, nr_irqs: 72, preallocated irqs: 0
454riscv,cpu_intc,0: 64 local interrupts mapped
455riscv,cpu_intc,1: 64 local interrupts mapped
456riscv,cpu_intc,2: 64 local interrupts mapped
457riscv,cpu_intc,3: 64 local interrupts mapped
458riscv,plic0,e4000000: mapped 71 interrupts to 8/8 handlers
459clocksource: riscv_clocksource: mask: 0xffffffffffffffff max_cycles: 0x1bacf917bf, max_idle_ns: 881590412290 ns
460sched_clock: 64 bits at 60MHz, resolution 16ns, wraps every 4398046511098ns
461Console: colour dummy device 40x30
462Calibrating delay loop (skipped), value calculated using timer frequency.. 120.00 BogoMIPS (lpj=600000)
463pid_max: default: 32768 minimum: 301
464Mount-cache hash table entries: 2048 (order: 2, 16384 bytes)
465Mountpoint-cache hash table entries: 2048 (order: 2, 16384 bytes)
466Hierarchical SRCU implementation.
467smp: Bringing up secondary CPUs ...
468CPU0: online
469CPU2: online
470CPU3: online
471smp: Brought up 1 node, 4 CPUs
472devtmpfs: initialized
473random: get_random_u32 called from bucket_table_alloc+0x198/0x1d8 with crng_init=0
474clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
475futex hash table entries: 1024 (order: 4, 65536 bytes)
476NET: Registered protocol family 16
477Advanced Linux Sound Architecture Driver Initialized.
478clocksource: Switched to clocksource riscv_clocksource
479NET: Registered protocol family 2
480tcp_listen_portaddr_hash hash table entries: 512 (order: 1, 8192 bytes)
481TCP established hash table entries: 8192 (order: 4, 65536 bytes)
482TCP bind hash table entries: 8192 (order: 5, 131072 bytes)
483TCP: Hash tables configured (established 8192 bind 8192)
484UDP hash table entries: 512 (order: 2, 16384 bytes)
485UDP-Lite hash table entries: 512 (order: 2, 16384 bytes)
486NET: Registered protocol family 1
487RPC: Registered named UNIX socket transport module.
488RPC: Registered udp transport module.
489RPC: Registered tcp transport module.
490RPC: Registered tcp NFSv4.1 backchannel transport module.
491Unpacking initramfs...
492workingset: timestamp_bits=62 max_order=18 bucket_order=0
493NFS: Registering the id_resolver key type
494Key type id_resolver registered
495Key type id_legacy registered
496nfs4filelayout_init: NFSv4 File Layout Driver Registering...
497io scheduler noop registered
498io scheduler cfq registered (default)
499io scheduler mq-deadline registered
500io scheduler kyber registered
501Console: switching to colour frame buffer device 40x30
502Serial: 8250/16550 driver, 4 ports, IRQ sharing disabled
503console [ttyS0] disabled
504f0300000.serial: ttyS0 at MMIO 0xf0300020 (irq = 20, base_baud = 1228800) is a 16550A
505console [ttyS0] enabled
506console [ttyS0] enabled
507bootconsole [early0] disabled
508bootconsole [early0] disabled
509loop: module loaded
510tun: Universal TUN/TAP device driver, 1.6
511ftmac100: Loading version 0.2 ...
512ftmac100 e0100000.mac eth0: irq 21, mapped at (ptrval)
513ftmac100 e0100000.mac eth0: generated random MAC address 4e:fd:bd:f3:04:fc
514ftsdc010 f0e00000.mmc: mmc0 - using hw SDIO IRQ
515mmc0: new SDHC card at address d555
516ftssp010 card registered!
517mmcblk0: mmc0:d555 SD04G 3.79 GiB
518NET: Registered protocol family 10
519 mmcblk0: p1
520Segment Routing with IPv6
521sit: IPv6, IPv4 and MPLS over IPv4 tunneling driver
522NET: Registered protocol family 17
523NET: Registered protocol family 15
524ALSA device list:
525 #0: ftssp_ac97 controller
526Freeing unused kernel memory: 13520K
527This architecture does not have kernel memory protection.
528Sysinit starting
529Sat Apr 6 23:33:53 CST 2019
530nfs4flexfilelayout_init: NFSv4 Flexfile Layout Driver Registering...
531
532~ #