2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉

2019-2020-1 20175204 《信息安全系统设计基础》实验一 开发环境的熟悉

实验小组成员 20175204张湲祯 20175202葛旭阳 20175216张雪原

《信息安全系统设计基础》实验一【开发环境的熟悉】

实验小组成员:20175202 葛旭阳 20175204 张湲祯 20175216 张雪原

任务一【交叉编译环境】

一、实验任务

  1. 可以使用自己的笔记本,也可以使用实验室台式机,使用实验室机器的不用做本题
  2. 安装老师提供的software目录中VMware-workstation-full-10.0.1-1379776.exe
  3. 解压老师提供的software目录中的Ubuntu1204.rar
  4. 用VMWare打开Ubuntu,用户名:linux,口令:1
  5. 建立实验目录mkdir linux_组员1学号_组员2学号_组员3学号
  6. 在实验目录中编写hello word程序,另外补充几行打印所有组员的学号姓名
  7. 参考bocsd目录中的脚本armc.sh, 分别用gcc和交叉编译器arm-none-linux-gnuenbi-gcc编译hello.c,用gcc编译的可执行文件命名linuxhello:gcc hello.c -o linuxhello; 用arm-none-linux-gnuenbi-gcc编译的命名为armhello: /usr/local/toolchain/toolchain4.3.2/bin/arm-none-linux-gnuenbi-gcc hello.c -o armhello
  8. 分别运行linuxhello,armhello,有什么结果?提交截图并用file命令分析原因。

二、实验步骤:
1.安装提供的software目录中的VMware-workstation-full-10.0.1-1379776.exe
2.解压老师提供的software目录中的Ubuntu1204.rar
3.用VMWare打开Ubuntu,用户名:linux,口令:1;
4.建立实验目录mkdir linux_20175202_20175204_20175216
5.在实验目录中编写“hello word”程序,另外补充几行打印所有组员的学号姓名。整体代码为:

#include 

int main()
{
    printf("hello word\n");
    printf("20175202葛旭阳\n");
    printf("20175203张湲桢\n");
    printf("20175216张雪原\n");
}

6.分别用gcc和交叉编译器编译hello.c,用gcc编译的可执行文件命名linuxhello:gcc hello.c -o linuxhello
;用arm-none-linux-gnuenbi-gcc编译的命名为armhello:
/usr/local/toolchain/toolchain-4.3.2/bin/arm-none-linux-gnueabi-gcc hello.c -o armhello
7.最后运行armhello和linuxhello

二、实验结果截图:
2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉_第1张图片

分别运行linuxhello,armhello,有什么结果?提交截图并用file命令分析原因?

运行linuxhello的时候,结果会正常打印出,而运行armhello的时候,就会显示“无法执行二进制文件”。用“file”命令分别执行了这两个文件,探求产生不同的原因 ,发现用gcc编译的文件支持的内核是X86-64,而用交叉编译器arm-none-linux-gnuenbi-gcc编译的文件支持的内核是ARM,在图中已标记出来,前者能在该Ubuntu系统上执行,而后者不能

任务二 【目标机宿主机联通】

一、实验任务:
1.打开试验箱,把“USB转串口线”的USB口插入自己的笔记本电脑,把串口连到实验箱的COM0,用网线连接笔记本电脑和ARM实验箱的网口NET1;
2.在终端中进行配置,将波特率设置为115200,其他均为默认值不改变;
3.用ifconfig命令在超级终端中查看实验箱IP(目标机),在Ubuntu中(宿主机)中用ifconfig在命令行查看IP,记录arm机的ip为192.168.0.232,ubuntu的ip为192.168.0.230;
4.最后使用ping命令测试目标机和宿主机之间是否能够成功联通。
二、实验结果截图:
2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉_第2张图片
2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉_第3张图片
2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉_第4张图片
2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉_第5张图片

任务三 【目标机运行程序】

一、实验任务:
1.打开虚拟机命令行终端,配置/etc/exports;
sudo vim /etc/exports
NFS允许挂载的目录及权限在文件/etc/exports中进行了定义。我们需要把/home/linux/Linux_20175202_20175204_20175216目录共享出来,那么我们只需要在/etc/exports文件末添加如下一行:
/home/linux/Linux_20175202_20175204_20175216 *(rw,sync,no_root_squash,no_subtree_check)
保存并推出,随后重启服务:
sudo /etc/init.d/nfs-kernel-server restart
2.在超级终端中建立实验箱中程序运行目录arm_20175202_20175204_20175216
3.在超级终端中运行mount -t nfs -o nolock 192.168.0.230(宿主机IP):/home/linux/Linux_20175202_20175204_20175216 /arm_20175202_20175204_20175216
4.超级终端中输入命令cd /arm_20175202_20175204_20175216
5.最后超级终端中运行./armhello
二、实验结果截图:
2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉_第6张图片

任务四 【开发化境的熟悉-4-目标机模块分解】(选作)

一、实验任务

  1. 在目标机上重现上周“系统调用版的myod”
  2. 以静态库或共享库的方式在目标机上重现上周“系统调用版的myod”
  3. 提交超级终端中的运行截图

任务五 【开发化境的熟悉-5-清理工作】(只有用实验室机器的小组做)

一、实验任务:
实验结束后,把实验室原来的网线插回,否则以后做实验的同学无法开机,提交插好网线的照片。
二、实验步骤:
实验结束后我们将实验箱整理好送回原来的位置
三、实验截图:
2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉_第7张图片

实验总结

本次实验首先遇到了很多问题,首先是实验箱的问题:一、实验箱接入电源后,显示灯不亮,更换数个实验箱才可以正常使用;
二、实验箱接入电源都无误后,实验箱和电脑ping不通;原因:网络环境应为桥连接,而不是nat连接;不同主机不同实验箱有的可以直接ping通,有的不可以,同一主机换了实验箱有时候也ping不通,但检查过后虚拟机网关是相同的,连接模式也为桥接,不知道什么原因ping不通,更换一个实验箱则可以正常进行实验。
三、在设置NFS进行挂载时,一定要注意/home/linux/Linux_20175202_20175204_20175216 *(rw,sync,no_root_squash,no_subtree_check)中不能丢掉目录/home/linux(不同目录位置不同)否则会导致后续在超级终端中复制失败。
本次实验很深刻的理解到娄老师曾在开学时告诉我们的“做中学,学中做”的重要性了,只有多实践,才能发现自己不足,才能在下一阶段更好的努力,更好的学习。

你可能感兴趣的:(2019-2020-1 20175204 20175202 20175216 《信息安全系统设计基础》实验一 开发环境的熟悉)