【网站源码商业版】【访滴滴源码】【commons net 源码】git源码编译 arm

来源:昨日涨停排序源码

1.嵌入式开发软件有哪些
2.qemu-system-arm安装和基本使用
3.Travis让你的源译代码运行在ARM平台上
4.GitLab ARM64源码在信创统信UOS下的搭建
5.如何编译arm linux的go

git源码编译 arm

嵌入式开发软件有哪些

       嵌入式开发软件主要包括以下几种:

1. 编译器

       编译器是嵌入式开发的核心工具之一,它负责将高级语言编写的码编源代码转换为嵌入式系统可执行的机器代码。常见的源译嵌入式编译器有GCC、ARM编译器等。码编这些编译器支持多种编程语言和处理器架构,源译为嵌入式开发者提供了便捷的码编网站源码商业版开发环境。

2. 集成开发环境

       IDE是源译嵌入式开发的重要工具,它集成了代码编辑、码编编译、源译调试和仿真等功能。码编常见的源译嵌入式IDE包括Keil MDK、IAR Embedded Workbench等。码编这些IDE为开发者提供了统一的源译开发平台,提高了开发效率和便捷性。码编

3. 调试工具

       调试工具是源译嵌入式软件开发过程中必不可少的部分,用于检测和修复代码中的错误。常见的调试工具有逻辑分析仪、仿真器等。逻辑分析仪可以捕获和分析嵌入式系统在运行时的行为,帮助开发者定位问题。仿真器则可以模拟嵌入式系统的运行环境,让开发者在没有硬件的情况下进行代码调试。

4. 版本控制工具

       在嵌入式软件开发过程中,版本控制工具用于管理代码的访滴滴源码版本和变更。最常见的版本控制工具是Git,它可以帮助开发者记录代码的每一次修改,方便版本管理和协作开发。

       除了以上几种主要软件,嵌入式开发还可能涉及到其他辅助工具,如代码分析工具、性能优化工具等。这些工具在提高开发效率、保证代码质量、优化系统性能等方面发挥着重要作用。总之,嵌入式开发软件种类繁多,开发者需要根据具体的项目需求和开发环境选择合适的工具进行开发。

qemu-system-arm安装和基本使用

       安装OpenBMC维护的qemu:

       使用git clone从github.com/openbmc/qemu克隆代码。

       切换目录至qemu文件夹。

       执行git submodule update --init dtc更新依赖。

       创建build目录并切换至该目录。

       执行../configure --target-list=arm-softmmu配置arm-softmmu目标。

       根据可能遇到的错误提示删除qemu文件夹并重复步骤1-6,安装所需依赖库。

       执行make编译qemu-system-arm。

       编译后的qemu-system-arm位于arm-softmmu目录下,查看支持的commons net 源码机器。

       使用sudo ln -s /home/master/qemu/build/arm-softmmu/qemu-system-arm /usr/bin创建全局软链接,方便调用。

       本地启动romulus镜像,使用命令sudo qemu-system-arm -m -M romulus-bmc -nographic -drive file=path,format=raw,if=mtd -net nic -net user,hostfwd=:.0.0.1:-:,hostfwd=:.0.0.1:-:,hostname=qemu。

       解释镜像参数:为内存大小,romulus-bmc为机型,nographic为无窗口运行,path为镜像文件路径,raw为格式,mtd为执行文件类型,-net nic添加虚拟网卡。

       具体操作指南见:ubuntu下qemu使用:图文详解_ubuntu qemu_MasterHu的博客-CSDN博客。

       遇到网络后端报错,原因可能是使用了旧版qemu,slirp被移除。

       解决方法为:安装slirp库,删除build目录,重新配置qemu时加入--enable-slirp参数。

       如果出现与ninja有关的错误,安装ninja-build库。

       成功后,使用qemu-system-arm命令即可启动romulus镜像,无需指定路径。gdb源码 使用

       登录系统,以root用户身份进入OpenBMC界面,访问.0.0.1:/redfish/...,通过ssh -p root@.0.0.1连接。

Travis让你的代码运行在ARM平台上

       TravisCI的CI(Continuous Integration)功能允许我们持续对代码进行部署和测试,无需等到代码有大量修改后一次性进行。这是一个托管的分布式CI服务,用于构建和测试托管在Github上的软件项目。它能自动同步你的Github项目,并根据你的配置要求分配虚拟机或容器进行部署和测试。从今年月初开始,TravisCI支持在不同CPU架构(x、arm)的机器上编译和测试代码。以下以hello world为例,介绍如何在ARM平台上部署和运行代码。(本文假设读者熟悉git的基本命令,了解如何将代码提交到github,如不熟悉,请自行了解相关内容)

       1. 准备条件

       首先,创建一个仓库。在仓库目录右上角,点击“new”按钮,开始新建一个仓库。Hashmap hash 源码给新仓库命名为TestTravisCI,写一些简短的描述,并选择“Initialize this repository with a README”。点击“Create repository”。

       2. 授权TravisCI

       给TravisCI授权后,它才能看到你在github上创建的仓库,并可以监控你的仓库提交。一旦有新的代码提交,TravisCI就会按照你的配置运行部署和测试代码。具体配置方法请参考yaml文件介绍。

       2.1 打开网站,点击“Sign up with GitHub”,用你的github账号登录。

       2.2 授权TravisCI,点击下图的“Authorize travis-pro”进行授权。

       2.3 现在你的dashboard里可以看到你刚才创建的仓库。

       3. 在TravisCI上部署并运行测试代码

       3.1 Clone仓库到本地,进入该目录。

       3.2 编写代码。

       3.3 编写简单的Makefile。

       3.4 编写.travis.yml,注意这里的arch配置有两种:amd和arm。表示将在这两种配置的机器上进行代码部署和测试。

       3.5 将编写的代码提交到github上你的仓库,TravisCI会监控到新提交的代码,并运行.travis.yml中的script里的命令,这里会运行“make test”。

       3.6 在TravisCI网站查看是否代码正确部署和运行。从下图中可以看到代码已经成功在amd和arm两类机器上部署并运行。

       3.7 点击job 1.2可以看到详细的log输出。

       至此,我们已经成功创建了一个仓库,并通过添加hello world的代码和yaml文件,使代码成功部署在ARM机器上,并成功运行了测试脚本。下面简单介绍一下yaml文件各个字段的含义。

       4.1 language c:表示你的仓库的代码使用的那种语言,Travis支持以下语言。

       4.2 compiler:指定编译器,可以指定多个,那么你的代码将被多个编译器分别编译并运行。

       4.3 matrix:Travis.yml实际定义了一个矩阵的测试环境,通过matrix,我们可以指定只对某些配置进行测试。这里我们用的include,表示我们将对include中的配置组合进行测试。即在(linux,amd,gcc)和(linux,arm,gcc)两种配置的环境里测试。除了include,还有exclude,表示排除这些配置。具体参看/us...

       4.4 script:在之前定义的配置环境里运行的脚本,这里将分别在matrix定义的两种环境里分别运行make test。

       以上内容能帮助用户快速理解TravisCI的应用和配置方法,以及如何让代码在ARM机器上部署和测试。

GitLab ARM源码在信创统信UOS下的搭建

       GitLab是一个基于Ruby on Rails语言开发的开源应用,提供私有化的Git项目仓库,可通过Web界面进行访问和管理。GitLab官方提供了多种安装方式,包括通过操作系统软件源安装、Docker容器部署以及源代码自编译安装。然而,GitLab官方构建的软件包和镜像主要针对X架构,并未提供针对ARMv8的版本。UOS操作系统支持多种CPU架构(AMD、ARM、MIPS、SW)和六种国产CPU平台(鲲鹏、龙芯、申威、海光、兆芯、飞腾)以及Intel/AMD的主流CPU,UOSV基于Debian stable,内核为4.,支持多种架构。由于GitLab官方Omnibus安装包并未支持arm架构,因此需要通过源码编译来安装GitLab-ce .1-stable在UOSV arm架构上。

       在部署GitLab-ce .1-stable之前,首先需要搭建编译环境,包括Ruby 2.7.4、redis 6.2.4、git 2..0、Go:.、Postgres: 、Node: .x、Nginx:1..1。编译过程较为平顺,但安装Ruby、Node和Go时需要注意选择国内镜像源以确保顺利编译。GitLab-ce:-1-stable版本要求Git2..x或以上版本,推荐使用Gitaly提供的git版本。UOSV 版本若选择调试工具包,则系统自带的git版本不符合要求,需要手动安装Gitaly所提供的git版本,确保版本满足GitLab要求。安装完成后,系统会显示版本为2..0,满足要求。此外,还需安装GraphicsMagick支持GitLab引入的自定义图标功能,以及安装Postfix邮件服务器和exiftool以支持GitLab Workhorse功能。Ruby的安装也非常重要,更换国内Ruby Gem源能够提高编译过程的稳定性。

       在完成编译环境搭建后,需为GitLab创建一个名为git的用户。GitLab .1及以后版本仅支持PostgreSQL数据库,GitLab-ce .1-stable需要PostgreSQL 或以上版本,并且需要pg_trgm扩展和btree_gist扩展。GitLab .0及以后版本要求Redis版本4.0或以上,推荐使用6.0或以上版本。部署GitLab-ce .1-stable需要编译三个部分:gitLab核心代码、gitlab-shell和GitLab-Workhorse。编译完成后,主要目录结构会根据部署环境进行相应调整。

       配置GitLab的各个组件时,需要将源码配置调整为已搭建环境的配置。主要修改数据库配置为已安装的PostgreSQL 版本。安装过程中可能会遇到一些小问题,如使用sudo执行某些命令时的超时错误。解决这类问题通常需要检查和调整环境变量,确保git账号的环境变量能够正常工作。例如,通过修改/etc/sudoers文件,确保在执行sudo命令时保留所需的环境变量,如GOPROXY。安装完成后,GitLab及其环境应已正确配置,系统架构识别为arm,GitLab版本为.1,redis版本未读取但不影响使用。至此,GitLab在UOSV arm架构上成功部署完毕。

如何编译arm linux的go

       Golang也就是Go语言,现在已经发行到1.4.1版本了,语言特性优越性和背后Google强大靠山什么的就不多说了。Golang的官方提供了多个平台上的二进制安装包,遗憾的是并非没有发布ARM平台的二进制安装包。ARM平台没办法直接从官网下载二进制安装包来安装,好在Golang是支持多平台并且开源的语言,因此可以通过直接在ARM平台上编译源代码来安装。整个过程主要包括编译工具配置、获取Golang源代码、设置Golang编译环境变量、编译、配置Golang行环境变量等步骤。

       æ³¨ï¼šæœ¬æ–‡é€‰ç”¨æ ‘莓派做测试,因为树莓派是基于ARM平台的。

       1、编译工具配置

       æ®è¯´ä¸‹ä¸ªç‰ˆæœ¬çš„golang编译工具要使用golang自己来写,但目前还是使用C编译工具的。因此,首先要配置好C编译工具:

       1.1 在Ubuntu或Debian平台上可以使用sudo apt-get install gcc libc6-dev命令安装,树莓派的RaspBian系统是基于Debian修改的,所以可以使用这种方法安装。

       1.2 在RedHat或CentOS 6平台上可以使用sudo yum install gcc libc-devel命令安装。

       å®‰è£…完成后可以输入 gcc --version命令验证是否成功安装。

       2、获取golang源代码

       2.1 直接从官网下载源代码压缩包。

       golang官网提供golang的源代码压缩包,可以直接下载,最新的1.4.1版本源代码链接:/golang/go1.4.1.src.tar.gz

       2.2 使用git工具获取。

       golang使用git版本管理工具,也可以使用git获取golang源代码。推荐使用这个方法,因为以后可以随时获取最新的golang源代码。

       2.2.1 首先确认ARM平台上已经安装了git工具,可以使用git --version命令确认。一般linux平台都安装了git,没有的话可以自行安装,不同平台的安装方法可以参考:/download/linux

       2.2.2 克隆远程golang的git仓库到本地

       åœ¨ç»ˆç«¯cd到你想要安装golang的目录,确保该目录下没有名为go的目录。然后以下命令获取代码仓库:

       git clone /go

       å¤§é™†åœ°åŒºå¯èƒ½ä¼šèŽ·å–失败,在不翻墙的情况下我试了几次都没成功,原因大家都懂的。好在google已经将golang也托管到github上面,所以也可以通过下面命令获取:

       git clone /golang/go.git

       è§†ç½‘络情况,下载可能需要不少时间。我2M的带宽花了将近两个小时才下载完,虽然整个项目不过几十兆= =

       ä¸‹è½½å®ŒæˆåŽï¼Œå¯ä»¥çœ‹åˆ°ç›®å½•ä¸‹å¤šäº†ä¸€ä¸ªgo目录,里面即为golang的源代码,在终端上执行cd go命令进入该目录。

       æ‰§è¡Œä¸‹é¢å‘½ä»¤æ£€å‡ºgo1.4.1版本的源代码,因为现在已经有新的代码提交上去了,最新的代码可能不是最稳定的:

       git checkout go1.4.1

       è‡³æ­¤ï¼Œæœ€æ–°1.4.1发行版的源代码获取完毕

       3、设置golang的编译环境变量

       ä¸»è¦æœ‰GOROOT、GOOS、GOARCH、GOARM四个环境变量需要设置,先解释四个环境变量的意义。

       3.1 GOROOT

       ä¸»è¦ä»£è¡¨golang树结构目录的路径,也就是上面git检出的go目录。一般可以不用设置这个环境变量,因为编译的时候默认会以go目录下src子目录中的all.bash脚本运行时的父目录作为GOROOT的值。为了保险起见,可以直接设置为go目录的路径。

       3.2 GOOS和GOARCH

       åˆ†åˆ«ä»£è¡¨ç¼–译的目标系统和平台,可选值如下:

       GOOS GOARCH

       darwin

       darwin amd

       dragonfly

       dragonfly amd

       freebsd

       freebsd amd

       freebsd arm

       linux

       linux amd

       linux arm

       netbsd

       netbsd amd

       netbsd arm

       openbsd

       openbsd amd

       plan9

       plan9 amd

       solaris amd

       windows

       windows amd

       éœ€è¦æ³¨æ„çš„是这两个值代表的是目标系统和平台,而不是编译源代码的系统和平台。树莓派的RaspBian是linux系统,所以这些GOOS设置为linux,GOARCH设置为arm。

       3.3 GOARM

       è¡¨ç¤ºä½¿ç”¨çš„浮点运算协处理器版本号,只对arm平台有用,可选值有5,6,7。如果是在目标平台上编译源代码,这个值可以不设置,它会自动判断需要使用哪一个版本。

       æ€»ç»“下来,在树莓派上设置golang的编译环境变量,可编辑$HOME/.bashrc文件,在末尾添加下面内容:

       export GOROOT=你的go目录路径

       export GOOS=linux

       export GOARCH=arm

       ç¼–辑完后保存,执行source ~/.bashrc命令让修改生效。

       4、编译源代码

       çŽ¯å¢ƒå˜é‡é…ç½®å®Œæˆè‡ªåŽå°±å¯ä»¥å¼€å§‹ç¼–译源代码。在go目录下的src子目录中,主要有all.bash和make.bash两个脚本(另外还有两个all.bat和make.bat脚本适用于window平台)。编译实际上就是执行其中一个脚本,两者的区别在于all.bash在编译完成后还会执行一些测试套件。如果希望只编译不测试,可以运行make.bash脚本。使用cd命令进入go下src目录,执行./all.bash或者./make.bash命令即可开始编译。由于硬件情况不同,编译耗费的时间不同。在我的B型树莓派编译过程花费了将近半个小时,编译完成后执行的测试套件又花费了差不多一个小时,总共花费了一个半小时左右。

       5、配置golang运行环境变量

       ç¼–译完成后,go目录下会生成bin目录,里面就是go的运行脚本。为了以后使用方法,可以将这个bin路径添加到PATH环境变量中。同样编辑~/.bashrc文件,因为前面设置过GOROOT环境变量指向go目录了,所以只需要在末尾加上

       export PATH=$PATH:$GOROOT/bin

       ä¿å­˜åŽåŒæ ·æ‰§è¡Œsource ~/.bashrc命令让环境变量生效。

       è‡³æ­¤ï¼Œgolang源代码编译安装成功。执行go version应该就能看到当前golang的版本信息,表示编译安装成功。

文章所属分类:知识频道,点击进入>>