forked from xuos/xiuos
176 lines
7.2 KiB
Markdown
176 lines
7.2 KiB
Markdown
# 从零开始构建矽璓工业物联操作系统:使用ARM架构的ok1052-c
|
||
|
||
# ok1052-c
|
||
|
||
[XiUOS](http://xuos.io/) (X Industrial Ubiquitous Operating System) 矽璓XiUOS是一款面向智慧车间的工业物联网操作系统,主要由一个极简的微型实时操作系统内核和其上的工业物联框架构成,通过高效管理工业物联网设备、支撑工业物联应用,在生产车间内实现智能化的“感知环境、联网传输、知悉识别、控制调整”,促进以工业设备和工业控制系统为核心的人、机、物深度互联,帮助提升生产线的数字化和智能化水平。
|
||
|
||
## 1. 简介
|
||
|
||
| 硬件 | 描述 |
|
||
| -- | -- |
|
||
|芯片型号| MIMXRT1052DVL6A |
|
||
|架构| cortex-m7 |
|
||
|主频| 600MHz |
|
||
|片内SRAM| 512KB shared with TCM |
|
||
|外设支持| UART GPIO I2C RTC SDIO SEMC SPI USB ADC|
|
||
|
||
XiUOS板级当前支持使用UART、GPIO、I2C、RTC、SDIO、SEMC、SPI、USB、ADC。
|
||
|
||
## 2. 开发环境搭建
|
||
|
||
### 推荐使用:
|
||
|
||
**操作系统:** ubuntu18.04 [https://ubuntu.com/download/desktop](https://ubuntu.com/download/desktop)
|
||
|
||
更新`ubuntu 18.04`源的方法:(根据自身情况而定,可以不更改)
|
||
|
||
第一步:打开sources.list文件
|
||
|
||
```c
|
||
sudo vim /etc/apt/sources.list
|
||
```
|
||
|
||
第二步:将以下内容复制到sources.list文件
|
||
|
||
```c
|
||
deb http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse
|
||
deb http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse
|
||
deb http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse
|
||
deb http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse
|
||
deb http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse
|
||
deb-src http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse
|
||
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse
|
||
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse
|
||
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse
|
||
deb-src http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse
|
||
```
|
||
|
||
第三步:更新源和系统软件
|
||
|
||
```c
|
||
sudo apt-get update
|
||
sudo apt-get upgrade
|
||
```
|
||
|
||
**开发工具推荐使用 VSCode ,VScode下载地址为:** VSCode [https://code.visualstudio.com/](https://code.visualstudio.com/),推荐下载地址为 [http://vscode.cdn.azure.cn/stable/3c4e3df9e89829dce27b7b5c24508306b151f30d/code_1.55.2-1618307277_amd64.deb](http://vscode.cdn.azure.cn/stable/3c4e3df9e89829dce27b7b5c24508306b151f30d/code_1.55.2-1618307277_amd64.deb)
|
||
|
||
### 依赖包安装:
|
||
|
||
```
|
||
$ sudo apt install build-essential pkg-config git
|
||
$ sudo apt install gcc make libncurses5-dev openssl libssl-dev bison flex libelf-dev autoconf libtool gperf libc6-dev
|
||
```
|
||
|
||
**XiUOS操作系统源码下载:** XiUOS [https://www.gitlink.org.cn/xuos/xiuos](https://www.gitlink.org.cn/xuos/xiuos)
|
||
|
||
新建一个空文件夹并进入文件夹中,并下载源码,具体命令如下:
|
||
|
||
```c
|
||
mkdir test && cd test
|
||
git clone https://gitlink.org.cn/xuos/xiuos.git
|
||
```
|
||
|
||
1、打开XiUOS源码文件包可以看到以下目录:
|
||
| 名称 | 说明 |
|
||
| -- | -- |
|
||
| APP_Framework | 应用代码 |
|
||
| Ubiquitous | 板级支持包,支持NuttX、RT-Thread和XiZi内核 |
|
||
|
||
2、打开XiZi内核源码文件包可以看到以下目录:
|
||
| 名称 | 说明 |
|
||
| -- | -- |
|
||
| arch | 架构代码 |
|
||
| board | 板级支持包 |
|
||
| fs | 文件系统 |
|
||
| kernel | 内核源码 |
|
||
| lib | 第三方库源码 |
|
||
| resources | 驱动文件 |
|
||
| tool | 系统工具 |
|
||
|
||
使用VScode打开代码,具体操作步骤为:在源码文件夹下打开系统终端,输入`code .`即可打开VScode开发环境,如下图所示:
|
||
|
||
<div align= "center">
|
||
<img src = ./img/vscode.jpg width =1000>
|
||
</div>
|
||
|
||
### 裁减配置工具的下载
|
||
|
||
裁减配置工具:
|
||
|
||
**工具地址:** kconfig-frontends [https://www.gitlink.org.cn/xuos/kconfig-frontends](https://www.gitlink.org.cn/xuos/kconfig-frontends),下载与安装的具体命令如下:
|
||
|
||
```c
|
||
mkdir kfrontends && cd kfrontends
|
||
git clone https://gitlink.org.cn/xuos/kconfig-frontends.git
|
||
```
|
||
|
||
下载源码后按以下步骤执行软件安装:
|
||
|
||
```c
|
||
cd kconfig-frontends
|
||
./xs_build.sh
|
||
```
|
||
|
||
### 编译工具链:
|
||
|
||
ARM: arm-none-eabi(`gcc version 6.3.1`),默认安装到Ubuntu的/usr/bin/arm-none-eabi-,使用如下命令行下载和安装。
|
||
|
||
```shell
|
||
$ sudo apt install gcc-arm-none-eabi
|
||
```
|
||
|
||
## 编译说明
|
||
|
||
### 编辑环境:`Ubuntu18.04`
|
||
|
||
### 编译工具链:`arm-none-eabi-gcc`
|
||
使用`VScode`打开工程的方法有多种,本文介绍一种快捷键,在项目目录下将`code .`输入linux系统命令终端即可打开目标项目
|
||
|
||
|
||
编译步骤:
|
||
|
||
1.在VScode命令终端中执行以下命令,生成配置文件
|
||
|
||
```c
|
||
cd ./Ubiquitous/XiZi
|
||
make BOARD=ok1052-c distclean
|
||
make BOARD=ok1052-c menuconfig
|
||
```
|
||
|
||
2.在menuconfig界面配置需要关闭和开启的功能,按回车键进入下级菜单,按Y键选中需要开启的功能,按N键选中需要关闭的功能,配置结束后保存并退出(本例旨在演示简单的输出例程,所以没有需要配置的选项,双击快捷键ESC退出配置)
|
||
|
||

|
||
|
||
退出时选择`yes`保存上面所配置的内容,如下图所示:
|
||
|
||

|
||
|
||
3.继续执行以下命令,进行编译
|
||
|
||
```
|
||
make BOARD=ok1052-c
|
||
```
|
||
|
||
4.如果编译正确无误,会产生XiZi-ok1052-c.elf、XiZi-ok1052-c.bin文件。
|
||
|
||
## 3. 烧写及运行
|
||
|
||
### 3.1 烧写
|
||
1、烧写工具:NXP MCU Boot Utility,可参考[https://github.com/JayHeng/NXP-MCUBootUtility](https://github.com/JayHeng/NXP-MCUBootUtility)
|
||
|
||
2、ok1052-c开发板支持micro usb口烧写程序,打开NXP MCU Boot Utility后,选择好芯片类型为i.MXRT105x,开发板上电,使用usb线将开发板和PC连接,拨码开关设置为1 on 2 on 3 off 4 off,按下复位键K1后,若连接成功,可见Vendor ID和Product ID均有数字显示,点击reconnect,等待NXP MCU Boot Utility中红色显示变成蓝色显示,则表示已正确识别并连接到了开发板。如下图所示:
|
||

|
||
|
||
3、同时需要匹配ok1052-c开发板所使用的Flash型号,点击Boot Device Configuration,在Use Typical Device中选择Winbond_W25QxxxJV,然后点击ok。如下图所示:
|
||

|
||
|
||
4、选择编译生成的XiZi-ok1052-c.elf或bin文件路径,按照图示步骤,将文件烧写至Flash中(link.lds中已构造Flash Bootable image,如有修改Flash相关配置需求,可修改/xip目录内相关文件,无需NXPBootUtility再次构造),若烧写无误,则下列绿色进度条会执行到底。如下图所示:
|
||

|
||
|
||
### 3.2 运行结果
|
||
|
||
1、开发板支持rs232串口连接,使用rs232串口线或rs232转usb线将开发板和PC连接,使用串口终端工具可识别并连接开发板
|
||
|
||
2、按照3.1烧写步骤执行后,将拨码开关设置为1 off 2 off 3 off 4 off,按下复位键K1后,若程序正常,则串口终端上会显示启动信息打印输出。如下图所示:
|
||

|