LuatOS本着自身的开源特性,可以很轻松的嵌入到很多微处理器和微控制器。今天简要讲下如何移植这套系统,上手比较简单,看完基本就会了。

要想做移植,就要先了解需要移植芯片的SDK,LuatOS依赖于FreeRTOS/RTT这类RTOS系统。如果要移植的芯片SDK中用的有RTOS,那么恭喜你,可以很轻松的将LuatOS移植到芯片上。

我给大家准备了配套的移植模板,请根据Github/Gitee上的模板看这篇移植教程:

https://github.com/dreamcmi/luatos-bsp-example

https://gitee.com/dreamcmi/luatos-bsp-example

本教程主体分为初探、进阶两个部分,下面开始正式讲解。

第一部分:初探

01 编译环境的集成


这是最开始的一步,就是将Lua虚拟机部分集成进芯片,我们要做的就是Ctrl+C、Ctrl+V。要想运行LuatOS,就要把核心的Lua虚拟机部分集成进去。

下面就开始步骤讲解:

1)使用芯片的SDK建立一个空白的工程;

2)将LuatOS仓库里的lua文件夹和luat文件夹复制到新建好的工程里面。

这里根据上图再简要说明一下,lua文件夹里面的文件可以直接复制,luat文件夹里面要复制的有三个部分:

  • FreeRTOS或者RTT,这个是调用RTOS的接口,如果芯片使用的是这两种直接复制即可。

    如果是freertos, 使用现成的 luat/freertos 目录下的代码, 否则需要实现luat_msgbus.h 和 luat_timer.h;

  • include文件夹,这是头文件所在的地方;

  • modules文件夹,是和用户做交互用的源码所在(第一次集成不需要全部加入,只需加下图这些就够了)。

luat文件夹下的port文件夹,是做接口适配用的,后文会讲。

PS:packages里面的东西,不需要在第一次编译的时候加上,后续慢慢加功能的时候加上就行。(防止编译出错)

3)设置编译

其实就是写Makefile或者Cmake。

$LUATOS

- lua # Lua虚拟机

- luat/module # lua库实现

- luat/port # 接口层实现

以上目录内的.h文件需要加入include配置, .c文件加入到编译路径。以静态库的方式编译进目标就好啦,本文就不详细解释了,相信看这篇文章的都会写。

02 核心功能的适配


这里分两部分做适配,设置主入口和base.c。

1)设置主入口

打开工程的main.c(不同芯片叫法可能不一样),加入以下代码。手机浏览建议横屏查看:

#include "bget.h"

#include "luat\_base.h"

#define LUAT\_HEAP\_SIZE (64\*1024)

uint8\_t luavm\_heap\[LUAT\_HEAP\_SIZE\] = {0};

void app\_main(void)

{

 bpool(luavm\_heap, LUAT\_HEAP\_SIZE); 

    // lua vm需要一块内存用于内部分配, 给出首地址及大小.
luat_main();
// luat_main是LuatOS的主入口, 该方法通常不会返回.
}

这里做一下批注:

define LUAT_HEAP_SIZE () 这个定义是设置LuatOS可以使用的内存堆大小,要根据芯片可用的大小选择,单位是byte。

e.g.

define LUAT_HEAP_SIZE (16*1024)

//代表分配16k 给LuatOS使用

2)设置base.c

这里可以根据本工程配套的示例仓库做。

在ports文件夹内新建一个名为luat_base_xxx.c的文件,所有基础的实现都会在这个文件内找到。

这里简单说以下几个部分吧:

● 设置加载的库(手机浏览建议横屏查看)

static const luaL\_Reg loadedlibs\[\] \= {
{"\_G", luaopen\_base}, // \_G
{LUA\_LOADLIBNAME, luaopen\_package}, // require
{LUA\_COLIBNAME, luaopen\_coroutine}, // coroutine协程库
{LUA\_TABLIBNAME, luaopen\_table}, // table库,操作table类型的数据结构
{LUA\_IOLIBNAME, luaopen\_io}, // io库,操作文件
{LUA\_OSLIBNAME, luaopen\_os}, // os库,已精简
{LUA\_STRLIBNAME, luaopen\_string}, // string库,字符串操作
{LUA\_MATHLIBNAME, luaopen\_math}, // math 数值计算
// {LUA\_UTF8LIBNAME, luaopen\_utf8},
{LUA\_DBLIBNAME, luaopen\_debug}, // debug库,已精简
#if defined(LUA\_COMPAT\_BITLIB)
{LUA\_BITLIBNAME, luaopen\_bit32}, // 不太可能启用
#endif
// 往下是RTT环境下加载的库
{"rtos", luaopen\_rtos}, // rtos底层库, 核心功能是队列和定时器
{"log", luaopen\_log}, // 日志库
{"timer", luaopen\_timer}, // 延时库
{NULL, NULL}};

● 设置bsp的名称

const char \*luat\_os\_bsp(void)

{ 

 return "example"; //example改成芯片的名字

}

● 设置log打印函数

void luat_nprint(char *s, size_t l)
{
printf("%s", s);
}

一般可以用printf()这个函数,如果芯片SDK不支持,请换成对应的或者自行实现。

03 FS的适配


单独把FS这一部分拿出来说一下,lua脚本是存放在FS里面的,所以说要实现luatos正常的运行,还需把FS做好适配。

这里需要在port文件夹内新建一个名为luat_fs_xxx.c的文件,把实现函数放在这个文件夹内。

根据芯片SDK,在芯片Flash中创建FS分区,常见的有spiffs、fatfs、littefs等等,关键函数是int luat_fs_init(void);

如果支持posix风格的,则自带实现;否则需要实现luat_fs.h。

04 开始编译


编译通过刷入芯片,打开串口就能看到LuatOS的log打印了。

ESP32成功编译示例:

如果编译失败,请根据报错查找原因。

本文将在DOC社区持续更新,文末【阅读原文】可直达,敬请关注:

https://doc.openluat.com/article/2973

第二部分:进阶

外设的的适配


外设通常指gpio/i2c/spi,实现对应的.h文件就可以了,然后在luat_openlibs加载。

加载示例 {“gpio”, luaopen_gpio};

{"rtos", luaopen\_rtos},  // rtos底层库, 核心功能是队列和定时器

 {"log", luaopen\_log},     // 日志库

 {"timer", luaopen\_timer}, // 延时库

 {"gpio", luaopen\_gpio}, // GPIO脚的操作

 {"adc", luaopen\_adc},     // ADC库

 {"i2c", luaopen\_i2c},    // I2C操作

 {"spi", luaopen\_spi},     // SPI操作

 {"uart",luaopen\_uart},   // UART操作

 {NULL, NULL}};

LuatOS BSP的基础移植,以上这些就够用了。

基础移植成功之后,后面的就是各类外设的适配了,这个过程必定是漫长的,还请各位大佬耐心搞一搞。

上海合宙通信模块 - 合宙Luat,让万物互联更简单

干货 | LuatOS BSP移植教程,简单到复制粘贴!!!的更多相关文章

  1. 个人永久性免费-Excel催化剂功能第44波-可见区域复制粘贴不覆盖隐藏内容

    Excel的复制粘贴操作,每天都在进行,若其中稍能提升一点效率,长久来说,实在是很可观的效率提升. Excel自带的复制粘贴功能,若复制的数据源或粘贴的目标位置中有隐藏的行列内容,简单一个复制粘贴充满 ...

  2. 为了不复制粘贴,我被逼着学会了JAVA爬虫

    整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 本文作者:程序员内点事 更多精选 技术部突然宣布:JAVA开发人 ...

  3. BAT脚本编写教程简单入门篇

    BAT脚本编写教程简单入门篇 批处理文件最常用的几个命令: echo表示显示此命令后的字符 echo on  表示在此语句后所有运行的命令都显示命令行本身 echo off 表示在此语句后所有运行的命 ...

  4. 移植QT5.6到嵌入式开发板(史上最详细的QT移植教程)

    目前网上的大多数 QT 移植教程还都停留在 qt4.8 版本,或者还有更老的 Qtopia ,但是目前 Qt 已经发展到最新的 5.7 版本了,我个人也已经使用了很长一段时间的 qt5.6 for w ...

  5. ASP.NET Core 登录登出 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 登录登出 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 登录登出 上一章节我们总算完善了注册的功能,而且也添加了一个用户,现 ...

  6. ASP.NET Core Razor 布局视图 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core Razor 布局视图 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core Razor 布局视图 上一章节中我们学习了如何使用 EF ...

  7. Jmeter教程 简单的压力测试

    Jmeter教程 简单的压力测试:http://www.cnblogs.com/TankXiao/p/4059378.html

  8. jmeter教程--简单的做压力测试

    Jmeter是一个非常好用的压力测试工具.  Jmeter用来做轻量级的压力测试,非常合适,只需要十几分钟,就能把压力测试需要的脚本写好. 什么是压力测试 顾名思义:压力测试,就是  被测试的系统,在 ...

  9. MAVLink功能开发,移植教程。

    MAVLink功能开发 -----------------本文由"智御电子"提供,同时提供视频移植教程,以便电子爱好者交流学习.---------------- 1.MAVLink ...

随机推荐

  1. 【BUAA软工】Beta阶段事后分析

    设想与目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 解决的问题 总体解决的问题:新手编程者配置编程环境难.本地编写的代码跨设备同步难.本地ide安装使用过程 ...

  2. 基于深度学习的回声消除系统与Pytorch实现

    文章作者:凌逆战 文章代码(pytorch实现):https://github.com/LXP-Never/AEC_DeepModel 文章地址(转载请指明出处):https://www.cnblog ...

  3. 发现数据结构与算法之美的第n次重新学习 ——— 初遇数据结构与算法(了解)

    你的数据结构怎么学的?提起数据结构,计算机与软件,it行业内无人不知,无人不晓.但是,当你真正的去通过数据结构与算法内容去实践内容时,真的能联系起来吗?那肯定的 不管是考研还是做项目,数据结构都是必学 ...

  4. jQ的隐式迭代和设置样式属性

    jQ中的隐式迭代 意义:不需要原生迭代了,在jQ内部自动帮你实现了循环 代码实现: let arr = document.querySelectorAll('li') for(let i = 0;i ...

  5. [Python] 基本概念

    1.基本概念 三大特性:封装.继承.多态 继承:派生类继承基类的字段和方法 多态:对不同类型的变量进行相同的操作,却表现出不同的行为(例如对数字和字符做"+"运算) 封装:将数据和 ...

  6. [刷题] 226 Invert Binary Tree

    要求 翻转一棵二叉树 实现 翻转左右子树,交换左右子树的根节点 1 class Solution { 2 public: 3 TreeNode* invertTree(TreeNode* root) ...

  7. Java中日志组件详解

    avalon-logkit Java中日志组件详解 lanhy 发布于 2020-9-1 11:35 224浏览 0收藏 作为开发人员,我相信您对日志记录工具并不陌生. Java还具有功能强大且功能强 ...

  8. 关于jmeter线程组和循环次数的设置

    初始设置:设置线程数 n = 80,循环次数a = 1,ramp-up period=5 一 计算最后一个线程的生成时间(last) 总共生成80个线程,总共需要5秒,每秒钟会启动16个线程,所以,第 ...

  9. 搭建LAMP环境部署Ecshop电商网站

    实战-部署Ecshop电商网站 实验环境 Centos7 ip:192.168.121.17 一.关闭防火墙和selinux [root@localhost ~]# systemctl stop fi ...

  10. 用于监视Linux上的内存使用情况的Bash脚本

    用于监视Linux上的内存使用情况的Bash脚本 2019-06-17 11:32:45作者:戴进稿源:云网牛站 在本文中,我们添加了两个shell脚本来监视Linux操作系统上的内存利用率,即用于监 ...