本帖最后由 picc745514 于 2019-10-1 09:11 编辑
/ P& K* j, r1 g/ a, o2 I" R3 D' u: X5 K9 @( V+ V, s6 f
违规没有?版主。。。。。! K& D% W: Q, z
原作者 hanwckf 原地址https://www.jianshu.com/p/77e529fb35f9
7 O2 J) l& W5 l0 I- C3 o简介猫盘又是一款矿难机,配置如下 - CPU: Marvell ARMADA A3720 1.0Ghz 2xCortex-A53
- RAM: 512M DDR3
- eMMC: 8G HS200
- 网络: Marvell 88e1512 千兆phy
- 外设: 原生SATA,主板引出USB2.0和TTL,带1个风扇和aw2013控制的三色LED
- 电源: 5V3A! H; f/ T2 I+ z) Z& O3 S a) X, Y
由于espressobin开发板的配置与本机器比较接近,所以内核是通用的,但是需要适配dts,适配好的dts请看参考资料里面的Github仓库 Marvell目前提供有4.4和4.14的bsp内核(猫盘原厂固件就是4.4bsp内核),另外linux主线内核对armada的支持也不错,espressobin的armbian固件就是采用主线内核(4.19 LTS),我会尽快更新build-catdrive加入4.19内核的armbian固件(此固件不重新编译内核,仅适配dtb,因此phy的LED不会闪烁,三色LED也不工作) 在build-catdrive中的其他固件均采用Marvell的4.14 bsp内核,已经加入了aw2013的驱动,LED正常工作,可以通过sysfs控制,在系统poweroff之后LED熄灭。另外网口的LED灯也会闪烁。 猫盘通过spi nor flash启动的,rootfs放在emmc中,若不慎刷砖,只需用编程器刷spi flash即可救砖 原厂的uboot无法保存环境变量(复位后自动恢复默认env),因此需要刷入新的uboot,然后在新uboot中启动U盘/硬盘的临时系统,最后将新的rootfs镜像写入emmc 资料下载(刮刮码)- flash-image.bin https://github.com/hanwckf/bl-armada-3720/releases/tag/v2019-07-22
- img镜像 https://github.com/hanwckf/build-catdrive/releases/tag/v2019-09-17
- 原厂资料备份,提取码: qc7c https://pan.baidu.com/s/1yikyr60_VpbHhOgpH8crgw
. y& }' z! v" L
准备工作- 空的2.5寸硬盘(需要移动硬盘盒或者易驱线)或U盘(需要将USB母座接到主板上的USB排针上,见下图)
- USB转TTL线,如ch340等,按下图接线,波特率为115200,注意千万别接VCC! ~) J3 s" n) j# i, F0 _
6 G/ Q- ~4 u* b$ r8 ], C
# \3 N$ o1 r$ ]& \+ VUART与USB排针
7 R& R- B/ x0 z! R$ h3 s
' h6 h/ J& |- ^7 n: ?, R 刷入uboot: 方法1- U盘/硬盘格式化为mbr的ext4或fat32分区,将flash-image.bin复制到其根目录下,然后插到猫盘上
8 V3 |2 O2 ?& N) q. p2 C; J; c- V接好TTL后上电,在倒计时结束前反复按回车进入原厂uboot
5 ]. s t. v3 F( o在uboot控制台依次输入以下命令:# E( m5 c3 J2 Q O; I& D O
setenv bootargs "console=ttyMV0,115200 root=/dev/mmcblk0p1 rootwait rw init=/bin/sh"ext4load mmc 0:1 0x1000000 boot/armada-3720-customer0.dtb- M: w" V2 v w: q
ext4load mmc 0:1 0x2000000 boot/Image
" H: H, A* V f2 mbooti 0x2000000 - 0x1000000" }* l' Q9 @1 _0 U3 ]# t2 b
|
等待系统启动完成进入无需登陆的shell - 进入shell后依次输入以下命令(这一步是把flash-image.bin复制到emmc的第2分区上)
0 c9 x1 f' F3 k' ?1 p+ a* p- l当同时插入U盘和硬盘的时候,有可能需要挂载/dev/sdb12 d9 ` \1 G0 `3 k* [
mount -t proc /proc
" M/ r! ]+ D& M3 ^9 y9 f, _mount /dev/mmcblk0p2 /media
' l" U4 J4 M' x5 Imount /dev/sda1 /mnt; \2 ~# U+ C! ]6 W" L$ ~3 d
cp -f /mnt/flash-image.bin /media
( n T, I* }4 g8 _% [" d$ jumount /media
7 J( B! Q- Q9 M8 \1 x9 {umount /mnt |
) |; f+ J/ V2 d* k$ ~然后直接拔电 - 上电,在倒计时结束前反复按回车再次进入原厂uboot
) |8 T1 }& ?- d' s* @2 l: b2 ]& f在uboot控制台依次输入以下命令 (切勿在uboot控制台中反复按回车)) h5 x: `7 \( e* j, q0 F
ext4load mmc 0:2 0x1000000 flash-image.bin& _& K/ Q8 l/ [3 N
sf probe
; M: Z7 W0 X' Zsf erase 0x0 0x200000
) R1 F# f( U! Y! t( |: O5 w. |3 asf write 0x1000000 0x0 0x200000
" [; v/ a/ O- o' k' E1 k% V1 ]2 J |
# n+ h2 w, {( {( S" e5 h) S8 N- 确保上一步的命令正常执行完毕之后,输入reset复位,然后在倒计时结束前反复按回车进入新uboot! {1 g z* E" |, N' S6 d- T7 k; l0 m
在uboot控制台依次输入以下命令,注意mac地址要改成你自己的
% `& _/ U0 N1 v0 B2 d
env default -a
+ A2 U' m: C( z( D; A2 ^9 Dsetenv ethaddr "4c:65:a8:10:e2:55"
3 x8 w3 U; W7 xsaveenv
+ U6 G' k I o此时新uboot已经部署完毕,可以直接拔电准备下一步操作 刷入uboot: 救砖如果在常规步骤中操作失误,导致上电后不能进入uboot控制台,则需要拆下板子上面的spi flash, 用编程器将flash-image.bin写入spi flash, 再焊回去, 之后按照常规操作的第4步恢复环境变量和mac地址即可
9 e8 F! y* [: \: t3 b: a4 ^除此之外,还可以使用A3700-utils中提供的wtptp串口工具救砖(需要Linux环境),具体操作请看参考资料 刷emmc确保已经正确刷入新uboot,将img镜像解压后用etcher或者其他工具写入硬盘或者U盘, 插回板子上 - 对于硬盘刷机:! a9 Z- U8 E9 G" n
上电,在倒计时结束前反复按回车进入新uboot9 _1 J6 W, A$ Q) _
在uboot控制台依次输入以下命令: setenv boot_targets "sata mmc0 usb"
% }/ F. F( C6 B; pboot |
2 x1 y' ?7 M# @1 n. c
- 对于U盘刷机:! ? i9 L* G5 l) k5 {; }0 W
插好U盘后直接上电即可
$ d* H$ ]& x- O, W1 q
进入U盘/硬盘的临时系统后(应该是一个alpine,用户名:root;密码:admin),运行 emmc-install.sh等待刷入完成,然后输入poweroff关机,输出示例如下:
. o: z9 m( w" K5 ~$ U8 ]alpine:~# emmc-install.sh flash emmc... 1000MiB 0:00:33 [29.8MiB/s] [================================>] 100% 7+7144 records in 7+7144 records out 1048576000 bytes (1.0 GB, 1000 MiB) copied, 34.5134 s, 30.4 MB/s flash done, please unplug USB drive and reboot now! alpine:~# poweroff % h6 ?. I* K/ Y* g# k
如果是用U盘刷机的话则需要拔掉U盘后再启动,即可进入新系统,而对于硬盘刷机则无需拔除硬盘,可在新系统中直接将其格式化 在刷好新uboot之后,若要刷入build-catdrive中的其他linux发行版,直接从刷emmc这一步开始即可
% H! s/ M8 s; C" s& w! d由于猫盘内存较小,建议设置1GB的swap,具体操作请看下面 系统相关设置- 设置swap
# _6 N3 b9 e$ n% T8 M) I3 B2 @
8 L% k7 F. I p9 z7 v$ K% I1 | l3 x' C4 `$ U+ x
' C' D' m6 j# }9 m5 M1 u5 b
dd if=/dev/zero of=/swapfile bs=1M count=1000 #创建1GB的swap
+ S. H+ L/ v$ {! i# _/ gchmod 600 /swapfile
0 D! R" e1 O) x) Fmkswap /swapfile
$ N2 y2 A7 ?8 w% a9 }' Fecho "/swapfile swap swap defaults 0 0" >> /etc/fstab- B: k; _/ m& X$ u
- E8 e& m8 u* ^! d; P
: b) I Y$ Y* N/ s6 ^) X2 E6 g- n
" [3 a: b6 q0 a9 N7 z) }- ^
8 T2 q- y* K- p0 t0 f8 Y
风扇控制(主线内核不可用)+ e1 r$ h0 G$ Y9 e/ n
' v+ E1 i) Z& H
. T) X& F4 i4 P: f+ b* h" C& C6 g# m5 c! U) }( a' h3 m+ o
echo 0 > /sys/class/thermal/cooling_device0/cur_state #关闭风扇
0 J( i/ t/ k/ r* {; l5 U1 s$ c+ p; _echo 1 > /sys/class/thermal/cooling_device0/cur_state #打开风扇
( f. ~( [& o {6 y& l1 Z6 p) i% j ?# K5 }2 p5 x. m2 g8 J' S
! ?$ B" I' J1 i- _- B! y, F- G1 L$ [6 i% [5 B, |; Q4 g5 ?
3 d7 g {2 `) m/ d* {LED灯控制(主线内核不可用)
U a9 o, C3 {( ^, V% |, @& z% l2 C& Z) H, q
- Z }7 A' O9 x9 |$ y% Techo 0 > /sys/class/leds/blue/brightness #关闭蓝灯
# a4 P+ t4 a; f" P; X. c# q" Becho 255 > /sys/class/leds/green/brightness #点亮最高亮度的绿灯& @ u) s' O6 {$ J/ p/ b
echo 128 > /sys/class/leds/red/brightness #点亮中等亮度的红灯
/ G9 j3 R' o6 X& C: aecho 2 > /sys/class/leds/red/blink #点亮红色呼吸灯,可设为其他值
0 ~. p4 @3 |) g" f( _0 Mecho 0 > /sys/class/leds/green/blink #关闭绿色呼吸灯. @& ?: ?; f" Y
) f1 d* H1 f$ W5 {6 b6 D2 {, t
! l$ U" b9 G3 ~2 i$ U& g0 Z
3 l. Y- v. w! ~& S/ }
' ?/ e- `2 h. f8 W5 s硬盘休眠
" k1 I7 a L2 L+ i8 I+ Ibuild-catdrive中的固件已经设置好10分钟无操作自动休眠硬盘,如果需要调整时长,请修改/etc/udev/rules.d/99-hdparm.rules里面的hdparm -S之后的参数,默认值是120(10分钟)
& |7 Q9 c) I" u3 l0 V) @) q+ [ ACTION=="add", SUBSYSTEM=="block", KERNEL=="sd*",ENV{ID_BUS}=="ata", ENV{DEVTYPE}=="disk", RUN+="/sbin/hdparm -S 120 $env{DEVNAME}"- 读写uboot环境变量/ D7 d4 b0 L: V u. `1 `
fw_setenv foo barfw_printenv uboot其他操作- 在新uboot里从U盘根目录中刷入uboot
5 x: U6 P1 o q( K5 \! A6 s4 C bubt flash-image.bin spi usb- 在新uboot里从tftp中刷入uboot
" C3 y5 a. N4 l" P3 p5 M- g setenv ipaddr 192.168.1.100 #设定本机9 {8 l' m9 {/ P
ipsetenv serverip 192.168.1.2 #设定tftp服务器* g% M4 ^' h8 O. `- C* _
ipbubt flash-image.bin spi tftp- 在新uboot里改变启动顺序7 v# J5 _+ C! E, Q @0 I. g+ n
setenv boot_targets "usb sata mmc0" #默认为usb->mmc0->satasaveenv 已知问题- 主线内核中无法控制风扇的gpio(会导致以太网phy重新复位),所以poweroff后风扇不停
, @0 k0 i7 S; R
! n* [* }" \3 J0 V# {9 P$ s$ ^ [0 V4 J+ Q) w
7 B$ p+ J! u/ _3 U, o& E
0 ]' I0 l& k2 K3 |, }" `6 b: C6 y; O$ e4 x7 V
! U+ M' \1 t* i+ ~$ x$ \
y0 a) D+ x1 C4 j; y& z
4 ~3 M" \3 c; k
|