原创 飞凌嵌入式 RK3399-C 开发板试用体验(.NET CORE的跨平台使用)

2020-10-29 21:01 12083 15 2 分类: MCU/ 嵌入式


飞凌嵌入式RK3399开发板心得分享,接上篇

在使用QT实现了三个自定义控件后,我又查找了QT环境下实现可视化图表的一些优秀开源方案,发现QCustomPlot是一个不错的开源库,移植后效果也还不错。后面会继续尝试把基本的自定义控件做完,整个界面的组态也会在后面继续做下去。

这一次本来是想尝试在RK3399-C上移植OpenVINO,刚好手里有一块Neural Compute Stick2可以做加速。奈何在开源版的OpenVINO移植过程中困难重重,各种依赖库缺乏,以及现有的软件版本冲突,反反复复的切换版本,配置环境,虽然最后编译和安装都成功了,但是在运行demo程序时,始终不能完成模型的下载。引用openvino库编写的python程序提示无法加载cv2模块,安装cv2提示找不到满足需求的版本,更难过的是NCS2的SDK在RK3399平台上也不支持,完全不能安装,真的是一次一次的打击信心,最终还是放弃了。

还是拥抱微软吧,做一个TCP Modbus通讯服务,服务程序通过json配置生成多线程模块,每路通讯的IO层,协议解析层,数据{link56}分离达到去耦合的目的。应用层数据最终发送到RabbitMQ消息队列服务器,局域网内以及路由的下一层网络中的设备可通过连接MQ获取所有通讯数据。源代码是基于windows下的.NET CORE开发的。可以轻松移植到linux系统下。

安装.NET CORE3.0,从微软官方https://dotnet.microsoft.com/download/dotnet-core/3.0获取SDK和runtime。这里以sdk-3.0.103和runtime3.0.3为例

获取dotnet-sdk-3.0.103-linux-arm64.tar.gzwget https://download.visualstudio.microsoft.com/download/pr/eb4ffaf1-b0a9-466d-8440-0220dca8f806/48df585d8d978c5418fa514da6a2bd9b/dotnet-sdk-3.0.103-linux-arm64.tar.gz


获取dotnet-runtime-3.0.3-linux-arm64.tar.gzwget https://download.visualstudio.microsoft.com/download/pr/24687337-74b3-4897-89e4-eec2a743fb70/e12c8e9decba2cadc31e6358c2dad9da/dotnet-runtime-3.0.3-linux-arm64.tar.gz


在/root目录下创建dotnet-arm64目录

mkdir /root/dotnet-arm64

解压上面的两个包至dotnet-arm64目录

tar zxf dotnet-runtime-3.0.3-linux-arm64.tar.gz -C $HOME/dotnet-arm64

tar zxf dotnet-sdk-3.0.103-linux-arm64.tar.gz -C $HOME/dotnet-arm64


将.NET Core加入环境变量

export DOTNET_ROOT=$HOME/dotnet-arm64

export PATH=$PATH:$HOME/dotnet-arm64


执行dotnet --info命令查看环境变量添加情况,出现以下信息说明配置成功。

在windows环境下搭建好项目工程,并通过NuGet安装好程序所需要的package,该项目工程用到的package有RabbitMQ.Client,Newtonsoft.Json。整个工程项目的windows搭建我是在visual studio code完成。

整个代码结构按照IO层,协议层,应用层结构进行功能解耦合。各层间数据通过队列进行数据交互,应用层数据最终进到MQ服务器。所有单元模块根据json配置文件生成一个独立线程。

Json配置文件目录结构

其中ApplicationserverConfig用来定位应用层模块的json配置路径,IOserverConfig用来定位IO层模块json配置路径,ProtocolserverConfig用来定位协议层模块的json配置路径。

在保证程序能在windows下正常运行的情况下,将工程移入OK3399-C开发板。进入到工程目录,通过.NET CORE命令运行程序。

dotnet run

远端modbus slave服务器我是放到了本地计算机,开了四个端口,RK3399端服务的四个IO层创建四个TCPClient连接到远端服务器。实际使用中根据需要可增加数量,增加的越多,cpu的使用率,内存,网络带宽占用也就越高。

RK3399数据到发送到MQ端,任何设备通过MQ声明队列绑定到RK3399的upexchange即可获取到modbus数据。

通过top命令可查看protocol程序运行状态



PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
我要评论
0
15
关闭 站长推荐上一条 /3 下一条