首页 > 智能网

一文教你搭建国产嵌入式模拟器SkyEye开发环境

来源:智能网
时间:2021-08-03 14:00:14
热度:112

一文教你搭建国产嵌入式模拟器SkyEye开发环境作者:泽文i 准大四,热爱嵌入式、喜欢DIY,有兴趣可以关注他SkyEye介绍SkyEye是一个开源软件(OpenSource So

作者:泽文i 准大四,热爱嵌入式、喜欢DIY,有兴趣可以关注他

SkyEye介绍

SkyEye是一个开源软件(OpenSource Software)项目,中文名字是"天目"。SkyEye的目标是在通用的Linux和Windows平台上实现一个纯软件集成开发环境,模拟常见的嵌入式计算机系统(这里假定"仿真"和"模拟"的意思基本相同);可在SkyEye上运行μCLinux以及μC/OS-II等多种嵌入式操作系统和各种系统软件(如TCP/IP,图形子系统,文件子系统等),并可对它们进行源码级的分析和测试。

关于开源版本的更多介绍:点击我跳转

目前开源版本停留在1.3.5版本,后期版本由浙江迪捷软件科技有限公司开发和维护,点击我查看SkyEye的最新介绍。

访问这个地址,下载相关的安装包和工具包。

build教程 环境说明

本文介绍在操作系统 Ubuntu 16.04 中编译安装硬件仿真软件 SkyEye 1.3.5 的方法。

镜像版本:ubuntu-16.04.6-desktop-i386.iso为了保证顺利安装,可以选择与本文相同的Ubuntu来操作。同时你需要下载本仓库,release/skyeye-1.3.5中包含了我们需要的安装包和一些软件包。

安装依赖

由于SkyEye1.3.5引用了llvm3.0底层虚拟机、x11底层界面库等一些软件。如果是新安装的Ubuntu系统,这些软件可能就没有,因此在安装SkyEye之前需要把它们一起安装到机器上。

首先执行:

sudo apt-get update

然后执行以下命令:

sudo apt-get install git-core make automake autoconf libtool g++ python-dev libxft-dev libx11-dev libxpm-dev libncurses5-dev texi2html xterm texinfo x11proto-xext-dev libxext-dev python-numpy python-faulthandler python-wxtools libjson0-dev putty

主要涉及的库有:

名称说明git-core-make-automake-autoconf-libtool动态库加载工具g++-python-dev-libxft-dev-libx11-dev界面底层库依赖包libxpm-dev-libncurses5-dev-texi2html-xterm终端模拟器texinfo文档系统x11proto-xext-dev界面底层库libxext-dev-python-numpy-python-faulthandler-python-wxtools-libjson0-dev-putty终端工具

接着,我们还需要更新或安装一些依赖库,这些库ubuntu自带,但是保险起见,我们需要手动再安装一遍。

sudo apt-get install libgtk2.0-dev pkg-config libatk1.0-dev
sudo apt-get install libpango1.0-dev libfreetype6-dev libglib2.0-dev libx11-dev binutils-dev
sudo apt-get install libncurses5-dev libxpm-dev libltdl-dev
sudo apt-get install binutils-de
编译SkyEye

这里我在根目录新建一个文件夹

mkdir work

进入这个文件夹,从release/skyeye-1.3.5中拷贝安装包和软件包到这里,并对其解压。

cd work
unzip libiconv-1.12.zip
tar -zxvf llvm-3.0.tar.gz
tar -jxvf Python-2.7.tar.bz2
tar -jxvf skyeye-1.3.5_rc1.tar.bz2

简单介绍一下这些软件包的作用:

名称说明libiconv-1.14字符编码转换库llvm-3.0汇编虚拟机Python-2.7程序设计语言kyeye-1.3.5嵌入式系统仿真器

依次进入libiconv-1.12、Python-2.7文件夹,先安装libiconv:

./configure
make
sudo make install

期间make install若出现问题,make clean后重新make(不要使用sudo make),然后sudo make install。

再安装python-2.7:

./configure --enable-shared  --enable-unicode=ucs4
sudo make
sudo make install

以上步骤确认没有问题后进行SkyEye的编译安装,进入SkyEye源码目录,输入以下命令:

./configure
sudo make lib

若出现如下问题:

/home/tym/work/1.clone/skyeye-1.3.5_rc1/third-party/opcodes/cgen-ops.h:423:
multiple definition of `SUBWORDTFSI'

请按照下图指示操作:


接下来输入以下命令,完成编译和安装:

sudo make
sudo make install_lib
sudo make install

skyeye的安装路径在opt/skyeye,我们将它加入环境变量,就可以快捷操作:

先打开当前用户的全局设置:

vim ~/.bashrc

输入代码:

#skyeye 1.3.5
export PATH=/opt/skyeye/bin:$PATH

之后保存退出,输入命令更新设置:

source .bashrc

输入命令,看看能否启动skyeye:

skyeye

如果这个时候报错:

说明这个库不存在,我们需要拷贝一个系统的库到这里,并重新命名:

sudo cp //usr/lib/i386-linux-gnu/libbfd-2.26-system.so /usr/lib/libbfd-2.18.50.20070907.so

如果编译还出现类似错误,操作相同,直接找到系统下有的库,复制过来重命名即可。

现在我们进入skyeye根目录,利用提供的测试demo,验证skyeye是否正常工作:

cd //opt/skyeye/testsuite/arm_hello
skyeye -e arm_hello

出现上图所示,代表启动正常,现在我们输入两条命令,启动这个demo:

start
run

至此,我们的skyeye安装成功!