NanoPi NEO/zh

From FriendlyELEC WiKi
Revision as of 06:05, 4 July 2016 by Wuweidong (Talk | contribs)

Jump to: navigation, search

English

此页面目前仍处于编辑状态中,请稍后查看...

1 介绍

概览
正面
背面
  • NanoPi NEO(以下简称NEO)是友善之臂团队面向创客、嵌入式爱好者,电子艺术家、发烧友等群体推出的又一款完全开源的掌上创客神器。

2 资源特性

  • CPU:Allwinner H3, Quad-core Cortex-A7@1.2GHz

compact01

3 接口布局和尺寸

3.1 接口布局

File:NanoPi-NEO-if.png
NanoPi NEO接口布局
  • GPIO管脚定义
Pin# Name Linux gpio Pin# Name Linux gpio
  • Debug Port(UART0)
Pin# Name
1 GND
2 VDD_5V
3 UART_TXD0
4 UART_RXD0

3.2 机械尺寸

File:NanoPi-NEO-1603B-dimensions.png

详细尺寸:pcb的dxf文件


4 快速入门

4.1 准备工作

要开启你的NanoPi NEO新玩具,请先准备好以下硬件

  • NanoPi NEO主板
  • microSD卡/TF卡: Class10或以上的 8GB SDHC卡
  • 一个microUSB接口的外接电源,要求输出为5V/2A(可使用同规格的手机充电器)
  • 一台电脑,需要联网,建议使用Ubuntu 14.04 64位系统

4.2 经测试使用的TF卡

制作启动NanoPi NEO的TF卡时,建议Class10或以上的 8GB SDHC卡。以下是经友善之臂测试验证过的高速TF卡:

  • SanDisk闪迪 TF 8G Class10 Micro/SD 高速 TF卡:

SanDisk MicroSD 8G

  • SanDisk闪迪 TF128G 至尊高速MicroSDXC TF 128G Class10 48MB/S:

SanDisk MicroSD 128G

  • 川宇 8G手机内存卡 8GTF卡存储卡 C10高速class10 micro SD卡:

chuanyu MicroSD 8G

4.3 制作一张带运行系统的TF卡

4.3.1 下载系统固件

首先访问下载地址下载需要的固件文件(officail-ROMs目录)和烧写工具(tools目录):

使用以下固件:
nanopi-neo-core-qte-sd4g.img.zip Ubuntu-Core with Qt-Embedded系统固件
烧写工具:
win32diskimager.rar Windows平台下的系统烧写工具,Linux平台下可以用dd命令烧写系统

4.3.2 制作Ubuntu-Core with Qt-Embedded系统TF卡

  • 将固件nanopi-neo-core-qte-sd4g.img.zip和烧写工具win32diskimager.rar分别解压,在Windows下插入TF卡(限4G及以上的卡),以管理员身份运行 win32diskimager 工具,

在win32diskimager工具的界面上,选择你的TF卡盘符,选择系统固件,点击 Write 按钮烧写即可。

  • 当制作完成TF卡后,拔出TF卡插入NanoPi NEO的BOOT卡槽,上电启动(注意,这里需要5V/2A的供电),你可以看到绿灯常亮以及蓝灯闪烁,这时你已经成功启动 NanoPi NEO。

5 Ubuntu-Core with Qt-Embedded系统的使用

5.1 运行Ubuntu-Core with Qt-Embedded系统

  • 将制作好TF卡插入NanoPi NEO,使用USB供电(5V/2A),NanoPi NEO会上电自动开机,看到板上的蓝色LED闪烁,这说明系统已经开始启动了。

2)如果您需要进行内核开发,你最好选购一个串口配件,连接了串口,则可以通过串口终端对NanoPi NEO进行操作。

  • 以下是串口的接法,接上串口,即可调试。接上串口后你可以选择从串口模块的DC口或者从M1的MicroUSB口进行供电:

PSU-ONECOM-NEO

  • 如果提示输入密码,Ubuntu-Core的root和fa用户的默认密码都是两个字母fa。
  • 更新软件包:
sudo apt-get update

5.2 连接有线网络

NanoPi NEO在加电开机前如果已正确的连接网线,则系统启动时会自动获取IP地址,如果没有连接网线、没有DHCP服务或是其它网络问题,则会导致获取IP地址失败,同时系统启动会因此等待约15~60秒的时间。

  • 配置MAC地址

板子没有提供有效的Ethernet的MAC地址,系统在连接网络时会自动生成一个随机的MAC地址,您可以修改 /etc/network/interfaces.d/eth0 ,配置一个固定的MAC地址:

vi /etc/network/interfaces.d/eth0

以下是配置文件的具体内容:

auto eth0
allow-hotplug eth0
iface eth0 inet dhcp
hwaddress 76:92:d4:85:f3:0f

其中"hwaddress" 就是用来指定MAC地址,"76:92:d4:85:f3:0f"是一个随机生成的地址,为防止冲突导致网络问题,请修改为一个不同的且有效的地址。
需要注意的一点是,MAC地址必须符合IEEE的规则,请不要随意指定,否则会出现无法获取IP地址、无法上网等问题。 修改完配置文件并保存后,可重启板子或直接下列命令重启网络服务:

systemctl restart networking

5.3 通过ssh登录NEO

NEO没有任何图形界面输出的接口,如果你没有串口模块,可以通过ssh协议登录NEO。假设通过路由器查看到NEO的ip地址为192.168.1.230,你可以在PC机上执行如下命令登录NEO:

ssh root@192.168.1.230

密码为fa。

5.4 扩展TF卡 文件系统

强烈建议做好系统运行卡之后立即进行文件系统 rootfs 分区的扩展,这将大大提升系统的性能,避免空间不足带来的各种繁琐问题。

  • 在PC机上扩展TF卡的文件系统 rootfs 分区:
sudo umount /dev/sdx?
sudo parted /dev/sdx unit % resizepart 2 100 unit MB print
sudo resize2fs -f /dev/sdx2

/dev/sdx请替换为实际的TF卡设备文件名。

  • 在NEO上扩展TF卡的文件系统 rootfs 分区,在NEO上运行Ubuntu-Core,然后执行命令:
sudo fs_resize

根据提示,输入 y 开始扩展文件系统,然后再输入 y 选择重启NEO。重启后执行下列命令查看新分区大小:

df -h

5.5 连接USB WiFi

Debian系统已经支持市面上众多常见的USB WiFi,想知道你的USB WiFi是否可用只需将其接在NEO上即可,已测试过的USB WiFi型号如下:

序号 型号
1 RTL8188CUS/8188EU 802.11n WLAN Adapter
2 RT2070 Wireless Adapter
3 RT2870/RT3070 Wireless Adapter
4 RTL8192CU Wireless Adapter
5 小米WiFi mt7601

5.6 查看CPU工作温度

获取CPU核心的当前温度值、运行频率等信息:

cpu_freq


6 如何编译Ubuntu-Core with Qt-Embedded系统

访问此处下载地址的sources目录,下载源码nanopi-H3-bsp。
使用7-Zip工具解压后得到两个目录:lichee和android,也可以从github上克隆lichee源码:

git clone https://github.com/friendlyarm/h3_lichee.git lichee

注:lichee是全志为其CPU的板级支持包所起的项目名称,里面包含了U-boot,Linux等源码和众多的编译脚本。

6.1 编译lichee源码

编译全志 H3 的BSP源码包必须使用64bit的Linux PC系统,并安装下列软件包,下列操作均基于Ubuntu-14.04 LTS-64bit:

sudo apt-get install gawk git gnupg flex bison gperf build-essential \
zip curl libc6-dev libncurses5-dev:i386 x11proto-core-dev \
libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-glx:i386 \
libgl1-mesa-dev g++-multilib mingw32 tofrodos \
python-markdown libxml2-utils xsltproc zlib1g-dev:i386

为Debian系统编译lichee源码包,进入lichee目录,执行命令:

cd lichee
./build.sh -p sun8iw7p1 -b nanopi-h3

该命令会为Debian系统一次性编译好U-boot、Linux内核和模块。
注:lichee目录里内置了交叉编译器,当使用build.sh脚本进行源码编译时,会自动使用该内置的编译器,所以无需手动安装编译器。

6.2 打包系统组件

./gen_script.sh nanopi-neo

该命令会将所有编译生成的可执行文件(包括U-boot、Linux内核)和系统配置文件拷贝到lichee/tools/pack/out/目录以便进行统一管理,并且会该目录下生成 script.bin文件。
script.bin是全志系列 CPU 的硬件板级配置文件,相关信息请查看script.bin

下列命令可用于更新TF卡上的U-boot:

./fuse_uboot.sh /dev/sdx

/dev/sdx请替换为实际的TF卡设备文件名。
uImage和内核模块均位于linux-3.4/output目录下,将uImage拷贝到TF卡的boot分区的根目录即可更新内核。

6.3 编译U-boot

如果你想单独编译U-boot,可以执行命令:

./build.sh -p sun8iw7p1 -b nanopi-h3 -m uboot

编译生成的可执行文件需打上全志系列CPU的硬件板级配置补丁后才能烧写到TF卡上运行,执行./build.sh pack能自动完成打补丁的操作。
如何手动为U-boot打补丁请查看H3_Manual_build_howto,执行下列命令更新TF卡上的U-boot:

./fuse_uboot.sh /dev/sdx

/dev/sdx请替换为实际的TF卡设备文件名。

6.4 编译Linux内核

如果你想单独编译Linux内核,可以执行命令:

./build.sh -p sun8iw7p1 -b nanopi-h3 -m kernel

编译完成后uImage和内核模块均位于linux-3.4/output目录下,将uImage拷贝到TF卡的boot分区的根目录即可。

6.5 清理lichee源码

./build.sh -p sun8iw7p1_linux -b nanopi-h3 -m clean