Ubuntu 12.04下SimpleScalar_PISA 的安装

Ubuntu 12.04下SimpleScalar_PISA 的安装(1)首先准备需要的安装文件,如果没有可到以下地址下载:simpletools‐2v0.tgz:http://www.simplescalar.com/tools.htmlsimplesim‐3v0d‐with‐cheetah.tar.gz:http://www.ict.kth.se/courses/IS2202/softwaresimpleutils‐990811.tar.

大家好,又见面了,我是你们的朋友全栈君。

(1)首先准备需要的安装文件,如果没有可到以下地址下载:

simpletools‐2v0.tgz:

http://www.simplescalar.com/tools.html

simplesim‐3v0d‐with‐cheetah.tar.gz:

http://www.ict.kth.se/courses/IS2202/software

simpleutils‐990811.tar.gz:

http://www.eecs.umich.edu/mirv/software

gcc‐2.7.2.3.ss.tar.gz:

http://american.cs.ucdavis.edu/RAD/gcc‐2.7.2.3.ss.tar.gz

(2)打开终端,设置环境变量为:

(安装目录)

$ exportIDIR=/home/student/simplescalar

(主机)

$ export HOST=i686‐pc‐linux

(目标机)

$ export TARGET=sslittle‐na‐sstrix

(3)student主目录下创建目录simplescalar,并将4个安装包移动至该目录:

$ mkdir $IDIR

$ mv simplesim‐3v0d‐with‐cheetah.tar.gz$IDIR

$ mv simpletools‐2v0.tgz $IDIR

$ mv simpleutils‐990811.tar.gz $IDIR

$ mv gcc‐2.7.2.3.ss.tar.gz $IDIR

(4)使用命令更新Ubuntu下的软件包build‐essential,flex,bison:

$ sudo apt‐get installbuild‐essential flex bison

ubuntu12.04里还需要gcc-multilib

$ sudo apt-get install gcc-multilib

(5)安装SimpleTools:

解压包文件,并移除旧的gcc文件夹:

$ cd $IDIR

$ tar xvfz simpletools‐2v0.tgz

$ rm ‐rf gcc‐2.6.3

(6)安装SimpleUtils:

首先解压包文件。

$ cd $IDIR

$ tar xvfz simpleutils‐990811.tar.gz

$ cd simpleutils‐990811

编译前需要修改一处代码错误:

在目录simpleutils‐990811/ld下找到文件ldlex.l并将所有

yy_current_buffer替换为YY_CURRENT_BUFFER.

接下来开始配置,编译:

$ ./configure ‐‐host=$HOST‐‐target=$TARGET ‐‐with‐gnu‐as ‐‐with‐gnu‐ld‐‐prefix=$IDIR

$ make CFLAGS=‐O

$ make install

(7)安装模拟器:

$ cd $IDIR

$ tar xvfzsimplesim‐3v0d‐with‐cheetah.tar.gz

$ cd simplesim‐3.0

$ make config‐pisa

$ make

测试:

$ ./sim‐safetests/bin.little/test‐math

(8)安装gcc交叉编译器:

解压源代码,并配置安装,修改代码文件读写权限:

$ cd $IDIR

$ tar xvfz gcc‐2.7.2.3.ss.tar.gz

$ cd gcc‐2.7.2.3

$ ./configure ‐‐host=$HOST‐‐target=$TARGET ‐‐with‐gnu‐as ‐‐with‐gnu‐ld‐‐prefix=$IDIR

$ chmod ‐R +w .

接下来,为使编译顺利进行,需要做以下修改:

修改Makefile的第130,行末添加‐I/usr/include;

修改protoize.c的第60,将“#include<varargs.h>”替换为“#include<stdarg.h>”;

1.为了解决decl.c的一处错误信息,名为“invalidlvalue in increment”,做以下修改:

编辑obstack.h的第341行并将:

*((void**)__o‐>next_free)++=((void *)datum);\

替换为:

*((void**)__o‐>next_free++)=((void *)datum);\

并运行以下命令:

$ cp ./patched/sys/cdefs.h../sslittle‐na‐sstrix/include/sys/cdefs.h

$ cp ../sslittle‐na‐sstrix/lib/libc.a../lib/

$ cp ../sslittle‐na‐sstrix/lib/crt0.o../lib/

接下来构建(build)编译器:

$ make LANGUAGES=c CFLAGS=‐O CC=”gcc‐m32″

这个命令执行后会产生错误信息,可能还需要作如下修改:

追加 ‘\’insn‐output.c675, 750823行末尾;

2.再次执行“make LANGUAGES…”,碰到错误“buffer overflow”,这是由于Ubuntu版本

较新造成的。

下载以下文件,放在$IDIR/sslittle‐na‐sstrix/bin:

‐http://www.ict.kth.se/courses/IS2202/ar

‐http://www.ict.kth.se/courses/IS2202/ranlib

然后,请修改arranlib的权限为可执行,不然会提示“Permissiondenied”!

使用命令:

$ chmod +x ar ranlib

或在arranlib的属性中修改。

3.再次执行“makeLANGUAGES…”,提示缺少文件stubs-32.h

$ apt-file update

$ apt-file search stubs-32.h

libc6-dev:/usr/include/i386-linux-gnu/gnu/stubs-32.h

新版的ubuntu更改了stubs-32.h的存放位置。可执行

$ sudo cp/usr/include/i386-linux-gnu/gnu/stubs-32.h /usr/include/gnu/stubs-32.h

4.再次执行“makeLANGUAGES…”,如果需要则删除cxxmain.c2978‐2979行。

现在,运行:

$ make LANGUAGES=c CFLAGS=‐OCC=”gcc ‐m32″

$ make enquire

$ ../simplesim‐3.0/sim‐safe./enquire ‐f > float.h‐cross

$ make LANGUAGES=c CFLAGS=‐OCC=”gcc ‐m32″ install

5.这时可能会有错误“sendmsg.c:36:parse error”

在文件objc/sendmsg.c的第35行加上“#defineSTRUCT_VALUE 0”

这时再makeinstall应该就没有问题了。

测试:新建hello.c,内容为:

#include<stdio.h>

int main(int argc, char* argv)

{

printf(“HelloWorld!\n”);

return 0;

}

然后用如下命令编译:

$ $IDIR/bin/sslittle‐na‐sstrix‐gcc ‐o hello hello.c

生成文件hello,可用如下方式运行:

$ $IDIR/simplesim‐3.0/sim‐safe hello

如果输出“HelloWorld!”,说明安装成功!  

本文章参考《山东大学软件学院 计算机系统结构实验指导书》

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135063.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • HBase实战:记一次Safepoint导致长时间STW的踩坑之旅

    HBase实战:记一次Safepoint导致长时间STW的踩坑之旅本文记录了HBase中Safepoint导致长时间STW此问题的解决思路及办法。上篇文章回顾:HBaseReplication详解过程记录现象:小米有一个比较大的公共离线HBase集群,用户很多,每天有大量的MapReduce或Spark离线分析任务在进行访问,同时有很多其他在线集群Replication过来的数据写入,集群因为读写压力较大,且离线分析任务对延迟不…

    2025年5月25日
    0
  • LoopBox 用于包装循环的盒子

    LoopBox 用于包装循环的盒子LoopBox 用于包装循环的盒子

    2022年4月22日
    54
  • HttpCanary下载_Http是

    HttpCanary下载_Http是前言首先,我们无论学习哪个框架,都要带着问题,带着思考去学习思考1:HttpRunner是什么?思考2:HttpRunner的设计模式是什么?思考3:为什么我们要学习HttpRunner?他的

    2022年7月29日
    6
  • 关于WiFi密码破解的一些心得

    关于加密方式  目前无线网络加密形式常见的有两种:WEP和WPA/WPA2。  WEP破解方法相对简单,这种加密方式由于不安全现在基本上没有使用了。这里对其破解方法不做讨论。  WPA/WPA2破解的主流方法有Pin码破解、抓包破解。Pin码  Pin码破解最简单成功率最高,(需要路由器开启wps才行),使用QSS很快即可破解。  常用的pin码软件有幻影Pin、水…

    2022年4月14日
    155
  • 进程调度程序设计实验报告_进程调度模拟程序设计实验报告

    进程调度程序设计实验报告_进程调度模拟程序设计实验报告进程调度的设计与实现中文摘要无论是在批处理系统还是分时系统中,用户进程数一般都多于处理机数、这将导致它们互相争夺处理机。另外,系统进程也同样需要使用处理机。这就要求进程调度程序按一定的策略,动态地把处理机分配给处于就绪队列中的某一个进程,以使之执行。关键词进程调度C++优先级生命周期pidstatus前言实验目的1、综合应用下列知识点设计并实现操作系统的进程调度:邻接表,布…

    2022年9月29日
    0
  • WiFi安全漏洞KRACK深度解读

    WiFi安全漏洞KRACK深度解读前段时间爆出的WiFi安全漏洞KRACK,波及了全球的WLAN设备,无人幸免,也就是说wifi用户连接网络,不论是在公司,家里,还是咖啡馆,都有可能遭受攻击,问题时发现了一个,还有没有发现的,也许还更严重的问题,又该怎么办呢,如何规避协议层面的安全隐患,恐怕又是普通群众力所不及的。今天偶然看到一篇文章,文章对KRACK事件的技术缘由的进行了一番梳理剖析,纯技术系风格,看完后对此次爆出的安全漏洞有了

    2022年6月10日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号