From a51ef1c41fdf5593095d4af82af82fefdce8af4f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=B6=82=E7=85=9C=E6=B4=8B?= <1163589503@qq.com> Date: Tue, 8 Aug 2023 11:06:34 +0800 Subject: [PATCH 1/6] Fix edu-arm32 UDPSend bug. --- .../XiZi_IIoT/resources/ethernet/cmd_lwip/lwip_udp_demo.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Ubiquitous/XiZi_IIoT/resources/ethernet/cmd_lwip/lwip_udp_demo.c b/Ubiquitous/XiZi_IIoT/resources/ethernet/cmd_lwip/lwip_udp_demo.c index 0456aa419..71c6bc703 100755 --- a/Ubiquitous/XiZi_IIoT/resources/ethernet/cmd_lwip/lwip_udp_demo.c +++ b/Ubiquitous/XiZi_IIoT/resources/ethernet/cmd_lwip/lwip_udp_demo.c @@ -20,10 +20,10 @@ #include "board.h" #include "sys_arch.h" #include "lwip/udp.h" -#include "lwip/sockets.h" #include #include #include +#include "lwip/sockets.h" #define PBUF_SIZE 27 @@ -102,8 +102,8 @@ void *LwipUdpSendTest(int argc, char *argv[]) udp_interval = 100; } else { strncpy(udp_demo_msg, argv[1], strlen(argv[1])); - strncat(udp_demo_msg, "\r\n", 2); - if(argc == 3) { + strncat(udp_demo_msg, "\r\n", 3); + if(argc >= 3) { sscanf(argv[2], "%d.%d.%d.%d:%d", &udp_server_ip[0], &udp_server_ip[1], &udp_server_ip[2], &udp_server_ip[3], &udp_server_port); } if(argc > 3) { @@ -119,7 +119,7 @@ void *LwipUdpSendTest(int argc, char *argv[]) sys_thread_new("udp send", LwipUDPSendTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO); } -SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(3), +SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(5), UDPSend, LwipUdpSendTest, UDPSend msg [ip:port [num [interval]]]); void LwipUdpRecvTest(void) From 87a57d0db0a6b54cea5b6d1ae0cca3d817ec5b77 Mon Sep 17 00:00:00 2001 From: chenyh Date: Wed, 9 Aug 2023 10:59:04 +0800 Subject: [PATCH 2/6] Delete 'Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md' --- .../board/cortex-m4-emulator/README.md | 208 ------------------ 1 file changed, 208 deletions(-) delete mode 100644 Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md diff --git a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md deleted file mode 100644 index f8d004f9a..000000000 --- a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md +++ /dev/null @@ -1,208 +0,0 @@ -# 从零开始构建矽璓工业物联操作系统:使用ARM架构的cortex-m4 emulator - -[XiUOS](http://xuos.io/) (X Industrial Ubiquitous Operating System) 矽璓XiUOS是一款面向智慧车间的工业物联网操作系统,主要由一个极简的微型实时操作系统内核和其上的工业物联框架构成,通过高效管理工业物联网设备、支撑工业物联应用,在生产车间内实现智能化的“感知环境、联网传输、知悉识别、控制调整”,促进以工业设备和工业控制系统为核心的人、机、物深度互联,帮助提升生产线的数字化和智能化水平。 - - - -## 1. 简介 - -Q‎EMU 是一个通用的开源模拟器和虚拟化工具。目前Q‎EMU已经可以较完整的支持ARM cortex-m4架构。XiUOS同样支持运行在Q‎EMU上 - -| 硬件 | 描述 | -| -------- | ------------- | -| 芯片型号 | netduinoplus2 | -| 架构 | cortex-m4 | -| 主频 | 168MHz | -| 片内SRAM | 100+KB | -| 外设支持 | UART、GPIO | - - - -## 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开发环境,如下图所示: - -
- -
- - -### 裁减配置工具的下载 - -裁减配置工具: - -**工具地址:** 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 -``` - - - -## 3. 编译说明 - -### 编辑环境:`Ubuntu18.04` - -### 编译工具链:`arm-none-eabi-gcc` - -使用`VScode`打开工程的方法有多种,本文介绍一种快捷键,在项目目录下将`code .`输入linux系统命令终端即可打开目标项目 - - -编译步骤: - -1.在VScode命令终端中执行以下命令,生成配置文件 - -```c -cd ./Ubiquitous/XiZi -make BOARD=cortex-m4-emulator distclean -make BOARD=cortex-m4-emulator menuconfig -``` - -2.在menuconfig界面配置需要关闭和开启的功能,按回车键进入下级菜单,按Y键选中需要开启的功能,按N键选中需要关闭的功能,配置结束后保存并退出(本例旨在演示简单的输出例程,所以没有需要配置的选项,双击快捷键ESC退出配置) - -
- -
- -退出时选择`yes`保存上面所配置的内容,如下图所示: - -
- -
- -3.继续执行以下命令,进行编译 - -``` -make BOARD=cortex-m4-emulator -``` - -4.如果编译正确无误,会产生XiZi-cortex-m4-emulator.elf、XiZi-cortex-m4-emulator.bin文件。 - - - -## 4. 运行 - -### 4.1 安装Q‎EMU - -``` -sudo apt install qemu-system-arm -``` - -### 4.2 运行结果 - -通过以下命令启动Q‎EMU并加载XiUOS ELF文件 - -``` -qemu-system-arm -machine netduinoplus2 -nographic -kernel build/XiZi-cortex-m4-emulator.elf -``` - -QEMU运行起来后将会在终端上看到信息打印输出 - -
- -
- -### 4.3 调试 - -通过Q‎EMU可以方便的对XiUOS进行调试,首先安装gdb调试工具 - -``` -sudo apt install gdb-multiarch -``` - -并通过以下命令启动Q‎EMU - -``` -qemu-system-arm -machine netduinoplus2 -nographic -kernel build/XiZi-cortex-m4-emulator.elf -s -S -``` - -然后要重新开启另一个linux系统终端一个终端,执行`riscv-none-embed-gdb`命令 - -``` -gdb-multiarch build/XiZi-cortex-m4-emulator.elf -ex "target remote localhost:1234" -``` \ No newline at end of file From 6a2a006a3fd6973282a7f039386aa66b24a03160 Mon Sep 17 00:00:00 2001 From: xxq250 Date: Wed, 9 Aug 2023 11:03:52 +0800 Subject: [PATCH 3/6] revert 87a57d0db0a6b54cea5b6d1ae0cca3d817ec5b77 revert Delete 'Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md' --- .../board/cortex-m4-emulator/README.md | 208 ++++++++++++++++++ 1 file changed, 208 insertions(+) create mode 100644 Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md diff --git a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md new file mode 100644 index 000000000..17f1ca1f7 --- /dev/null +++ b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md @@ -0,0 +1,208 @@ +# 从零开始构建矽璓工业物联操作系统:使用ARM架构的cortex-m4 emulator + +[XiUOS](http://xuos.io/) (X Industrial Ubiquitous Operating System) 矽璓XiUOS是一款面向智慧车间的工业物联网操作系统,主要由一个极简的微型实时操作系统内核和其上的工业物联框架构成,通过高效管理工业物联网设备、支撑工业物联应用,在生产车间内实现智能化的“感知环境、联网传输、知悉识别、控制调整”,促进以工业设备和工业控制系统为核心的人、机、物深度互联,帮助提升生产线的数字化和智能化水平。 + + + +## 1. 简介 + +Q‎EMU 是一个通用的开源模拟器和虚拟化工具。目前Q‎EMU已经可以较完整的支持ARM cortex-m4架构。XiUOS同样支持运行在Q‎EMU上 + +| 硬件 | 描述 | +| -------- | ------------- | +| 芯片型号 | netduinoplus2 | +| 架构 | cortex-m4 | +| 主频 | 168MHz | +| 片内SRAM | 100+KB | +| 外设支持 | UART、GPIO | + + + +## 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开发环境,如下图所示: + +
+ +
+ + +### 裁减配置工具的下载 + +裁减配置工具: + +**工具地址:** 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 +``` + + + +## 3. 编译说明 + +### 编辑环境:`Ubuntu18.04` + +### 编译工具链:`arm-none-eabi-gcc` + +使用`VScode`打开工程的方法有多种,本文介绍一种快捷键,在项目目录下将`code .`输入linux系统命令终端即可打开目标项目 + + +编译步骤: + +1.在VScode命令终端中执行以下命令,生成配置文件 + +```c +cd ./Ubiquitous/XiZi +make BOARD=cortex-m4-emulator distclean +make BOARD=cortex-m4-emulator menuconfig +``` + +2.在menuconfig界面配置需要关闭和开启的功能,按回车键进入下级菜单,按Y键选中需要开启的功能,按N键选中需要关闭的功能,配置结束后保存并退出(本例旨在演示简单的输出例程,所以没有需要配置的选项,双击快捷键ESC退出配置) + +
+ +
+ +退出时选择`yes`保存上面所配置的内容,如下图所示: + +
+ +
+ +3.继续执行以下命令,进行编译 + +``` +make BOARD=cortex-m4-emulator +``` + +4.如果编译正确无误,会产生XiZi-cortex-m4-emulator.elf、XiZi-cortex-m4-emulator.bin文件。 + + + +## 4. 运行 + +### 4.1 安装Q‎EMU + +``` +sudo apt install qemu-system-arm +``` + +### 4.2 运行结果 + +通过以下命令启动Q‎EMU并加载XiUOS ELF文件 + +``` +qemu-system-arm -machine netduinoplus2 -nographic -kernel build/XiZi-cortex-m4-emulator.elf +``` + +QEMU运行起来后将会在终端上看到信息打印输出 + +
+ +
+ +### 4.3 调试 + +通过Q‎EMU可以方便的对XiUOS进行调试,首先安装gdb调试工具 + +``` +sudo apt install gdb-multiarch +``` + +并通过以下命令启动Q‎EMU + +``` +qemu-system-arm -machine netduinoplus2 -nographic -kernel build/XiZi-cortex-m4-emulator.elf -s -S +``` + +然后要重新开启另一个linux系统终端一个终端,执行`riscv-none-embed-gdb`命令 + +``` +gdb-multiarch build/XiZi-cortex-m4-emulator.elf -ex "target remote localhost:1234" +``` \ No newline at end of file From d6e7637128a5fbb10a25ebe7a110a1b6c733401e Mon Sep 17 00:00:00 2001 From: xxq250 Date: Wed, 9 Aug 2023 11:09:00 +0800 Subject: [PATCH 4/6] =?UTF-8?q?=E6=9B=B4=E6=96=B0=20'Ubiquitous/XiZi=5FIIo?= =?UTF-8?q?T/board/cortex-m4-emulator/README.md'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md index 17f1ca1f7..c97db99d1 100644 --- a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md +++ b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md @@ -92,7 +92,7 @@ git clone https://gitlink.org.cn/xuos/xiuos.git 使用VScode打开代码,具体操作步骤为:在源码文件夹下打开系统终端,输入`code .`即可打开VScode开发环境,如下图所示:
- +
From 55101230984a23dc46ff5b5b4ad20d0af41d551d Mon Sep 17 00:00:00 2001 From: xxq250 Date: Wed, 9 Aug 2023 11:09:53 +0800 Subject: [PATCH 5/6] =?UTF-8?q?=E6=9B=B4=E6=96=B0=20'Ubiquitous/XiZi=5FIIo?= =?UTF-8?q?T/board/cortex-m4-emulator/README.md'?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md index c97db99d1..b6c7d0d51 100644 --- a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md +++ b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md @@ -92,7 +92,7 @@ git clone https://gitlink.org.cn/xuos/xiuos.git 使用VScode打开代码,具体操作步骤为:在源码文件夹下打开系统终端,输入`code .`即可打开VScode开发环境,如下图所示:
- +
From 8c1ad40f8197e426a6b7d2f1e71d380476ce502d Mon Sep 17 00:00:00 2001 From: xxq250 Date: Wed, 9 Aug 2023 11:13:42 +0800 Subject: [PATCH 6/6] Update README.md --- Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md index b6c7d0d51..b5b89263b 100644 --- a/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md +++ b/Ubiquitous/XiZi_IIoT/board/cortex-m4-emulator/README.md @@ -146,13 +146,13 @@ make BOARD=cortex-m4-emulator menuconfig 2.在menuconfig界面配置需要关闭和开启的功能,按回车键进入下级菜单,按Y键选中需要开启的功能,按N键选中需要关闭的功能,配置结束后保存并退出(本例旨在演示简单的输出例程,所以没有需要配置的选项,双击快捷键ESC退出配置)
- +
退出时选择`yes`保存上面所配置的内容,如下图所示:
- +
3.继续执行以下命令,进行编译 @@ -184,7 +184,7 @@ qemu-system-arm -machine netduinoplus2 -nographic -kernel build/XiZi-cortex-m4- QEMU运行起来后将会在终端上看到信息打印输出
- +
### 4.3 调试