面向云技术架构 - 痴者工良

  • 首页
  • 工良写的电子书
    • kubernetes 教程
    • 从 C# 入门 Kafka
    • 多线程和异步
    • 动态编程-反射、特性、AOP
    • 表达式树
  • 本站文章导航
  • 隐私政策
愿有人陪你颠沛流离
遇到能让你付出的事物或者人,都是一种运气。
能遇到,就该珍惜。或许你们最终没能在一起,但你会切实地感受到力量。
正因为这样,那段相遇才变得有价值,才没有辜负这世间的每一段相遇。
  1. 首页
  2. .NET
  3. 正文

.NET Core 对龙芯的支持情况和对 .NET Core 开发嵌入式的思考

2019年12月15日 7629点热度 1人点赞 16条评论
内容纲要

.NET Core 对龙芯的支持情况和对 .NET Core 开发嵌入式的思考

[TOC]

一,遗憾的尝试

前些天看到了张队公众推送的《Asp.Net终于可以在龙芯服务器上运行啦:Jexus成功完成对国产系列CPU的适配》,联想到上一周与朋友在龙芯捣鼓 .NET Core,就想写一下关于 .NET Core 在龙芯下的资料。

Jexus Web Server 能够在龙芯服务器上跑,但是 ASP.NET 呢?.NET Core 呢?安装什么版本的 Mono ?Jexus 作者的文章表达有点模糊呀~

上一周与朋友在龙芯上面为了部署 .NET 项目,颇费心机。朋友公司中标政府项目,开发好 .NET Core 做的项目后,才发现要部署的服务器是龙芯的,.NET Core 无法在上面运行。

服务器有什么有 Mono 4.x,可以创建简单的 Proparm.cs ,编译出程序,使用 mono xx.exe 运行,可是把项目放进去编译不出来~想编译安装 Mono 6.x 也不行,中间有些过程报错。

.NET Core 自然不用想了,完全无法编译,通过 Google 查询资料,要重写 C++ 部分(移植),才能在 龙芯 下编译出 CoreCLR。

官方 CoreCLR 源码库,可以看到一些脚本和编译工具链。

https://github.com/dotnet/coreclr/

RISV-C 是精简指令集,MIPS 是指 基于 RISC-V 的 CPU 架构,龙芯服务器使用 MIPS 架构。

最终,无法部署 .NET 软件,朋友公司改用 Java 开发。。。

之前笔者为了在 Armel 的 CPU 下运行 .NET Core ,花了很多时间手动编译 .NET Core,最终还是失败。我将编译过程详细写了一篇文章,地址《瞎折腾实录:构建 Armel 版本的 .NET Core 教程和资料资源》。

二,.NET Core在嵌入式下的几点不足

18年7月张队来我校组织了大湾区 .NET 交流会,从那时起开始学习 .NET ,19 年三月月份进入敢为实习转正至此。

使用 .NET Core 开发半年的时间里,在嵌入式开发中,我个人总结当前 .NET Core 在嵌入式领域有几个问题/建议。

1,不支持前几年的CPU

.NET Core 无法在树莓派 Zero上运行(Arm v6);

无法在华为海思A9芯片上运行(Armel Armv7);

这两种芯片虽说是几年前出的芯片,但是 .NET Core 大张旗鼓的说要搞 IoT,却不兼容旧一些的 CPU,目前很多旧式设备依然会在未来一段时间内是主流的存在 。

微软官方也说了:

Note: .NET Core 2.1 is supported on Raspberry Pi 2+. It isn’t supported on the Pi Zero or other devices that use an ARMv6 chip. .NET Core requires ARMv7 or ARMv8 chips, like the ARM Cortex-A53.

Arm 方面的支持还是不够广。

2,测试的硬件设备较少

官方对嵌入式设备的测试,主要在 树莓派 2 / 3,还有很多开发板没有测试~

3,支持兼容的系统版本较少

.NET Core 支持很多 Linux 系统,但是对应这些系统的支持,都是以最新版本的系统为主,例如 .NET Core 3.0 在Ubuntu 上是支持 16.x、18.x,14.x 和 17.x 被无情的抛弃了。

.NET Core 3.0 支持的系统如下:

https://github.com/dotnet/core/blob/master/release-notes/3.0/3.0-supported-os.md

4,体积依然太大

对于嵌入式开发来说, .NET Core 的体积依然太大,.NET Core 3.0 也拯救不了。。。哪怕只有一行 Hello World,也要 70MB+ 以上。

5,依赖库比较伤脑筋

经常会出现 ICU、libssl、gcc 等依赖库版本不一致或没有安装这些库时的报错信息,石头哥曾经被这些问题搞得掉头发。

三,.NET Core 龙芯移植的进展和资料

根据大佬们的移植,在 11 月 9 号时,已经实现了 在龙芯上面运行 .NET Core 的 Hello World 实例,

The code base was upgraded to 3.0. Hello World and serveral tests in coreclr can run on MIPS64 now. 

这是对于 CoreCLR 的移植,还有很多问题等待大神解决。

对于 .NET Core 在 MIPS 上的移植讨论,可以到 Issue 查看

https://github.com/dotnet/coreclr/issues/969#issuecomment-550129085

不过,微软官方目前没有移植计划,只能靠社区去完成了。

Microsoft currently has no plans or work in progress to support MIPS. Of course, we would be willing to accept external contributions towards that goal as appropriate. Note that it is, certainly, a significant amount of work to port .NET Core to a new platform.

还有另一个大神的作品

https://github.com/reignstudios/IL2X

This project will focus on translating .NET IL for non-supported .NET targets. Portibility is a huge focus.

  • .NET Standard compatibility
  • Native C performance
  • C89: modern, legacy and embedded platforms (x86, MIPS, SPARK, RISC-V, PPC, AVR, etc)
  • CC65: 6502 platforms (Atari, C64, NES, Apple II, etc) [CS2X may be better suited]]
  • SDCC: Many targets (ColecoVision, etc) [CS2X may be better suited]
  • Assembly: CP1610 (Intellivision) [CS2X may be better suited]]
  • Retarget: Custom assembly targets via plugin system (FPGA CPU, 16bit bytes, etc)
  • Custom Standard lib(s) for various targets.
  • Documentation
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: core net 嵌入式 思考 龙芯
最后更新:2021年2月21日

痴者工良

高级程序员劝退师

点赞
< 上一篇
下一篇 >

文章评论

  • 笨瓜1号

    作为.net 开发者真的不容易啊 :lol:

    2020年6月24日
    回复
  • razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
    取消回复

    文章目录
    • .NET Core 对龙芯的支持情况和对 .NET Core 开发嵌入式的思考
      • 一,遗憾的尝试
      • 二,.NET Core在嵌入式下的几点不足
      • 三,.NET Core 龙芯移植的进展和资料

    COPYRIGHT © 2022 whuanle.cn. ALL RIGHTS RESERVED.

    Theme Kratos Made By Seaton Jiang

    粤ICP备18051778号

    粤公网安备 44030902003257号