zoukankan      html  css  js  c++  java
  • 2017-2018-1 20155201 20155313 实验一 开发环境的熟悉

    2017-2018-1 20155201 20155313 实验一 开发环境的熟悉

    一、实验内容

    1. 交叉编译环境
    2. 目标机宿主机联通
    3. 目标机运行程序
    4. 目标机模块分解
    5. 清理工作

    二、实验步骤

    1. 交叉机编译环境

      • 开机时进入系统BIOS中,开启虚拟化功能
      • 用VMware打开Ubuntu
      • 建立实验目录mkdir linux_20155201_20155313
      • 在实验目录中编写hello world程序,打印所有组员的学号姓名
      #include <stdio.h>
      int main(){
          printf("HelloWorld!
      ");
          printf("20155201_20155313
      ");
          return 0;
      }
      
      • 用gcc编译hello.c
      gcc -o linuxhello hello.c
      
      • 用交叉编译器arm-none-linux-gnuenbi-gcc编译hello.c
      /usr/local/toolchain/toolchain4.3.2/bin/arm-none-linux-gnuenbi-gcc hello.c -o armhello
      
    2. 目标机宿主机联通

      • 到实验室把“USB转串口线”的USB插入实验室电脑
      • 用超级终端作为实验箱的显示终端
      • ifconfig在超级终端中查看实验箱IP(目标机):192.168.0.232,在Ubuntu中(宿主机)中用ifconfig在命令行中查看IP192.168.0.230
      • 用网线连接实验室台式机和ARM实验箱的网口NET1
      • 在超级终端中输入ping 192.168.0.230(ping UbuntuIP),在Ubuntu命令行中输入ping 192.168.0.232(ping 超级终端IP),用ping命令保证目标机和宿主机能互相ping通。
    3. 目标机运行程序

      • 在超级终端中运行mount -t nfs -o nolock 192.168.0.230:/home/linux/exp /exp通过NFS把宿主机中的/home/linux/exp 映射到目标机中的/exp
      • 在超级终端中cd /exp
      • 在超级终端中./armhello运行armhello
    4. 目标机模块分解

      • 在目标机上重现系统调用版myod
      • 以静态库或共享库的方式在目标机上重现myod
    5. 清理工作

      • 实验结束后,把实验室原来的网线插回。

    三、实验过程中遇到的问题和解决方案

      • 问题1:目标机与宿主机ping不通
      • 问题1解决方案:更换实验箱,顺利ping通目标机和宿主机,与另外一组合作完成本次试验。另一组同学学号:20155207、20155211、20155223

    四、实验体会与总结

    本次实验学习了新的知识点和命令

    1. 交叉编译:
      • 搭建交叉编译环境,即安装、配置交叉编译工具链。在该环境下编译出嵌入式Linux系统所需的操作系统、应用程序等,然后再上传到目标机上。
      • 交叉编译工具链是为了编译、链接、处理和调试跨平台体系结构的程序代码。
      • 简单来说,就是在一个平台上生成另一个平台上的可执行代码。
      • 本次实验中gccarm-linux-gcc的区别是:gcc是linux下的C语言编译器,编译出来的程序在Ubuntu虚拟机上执行,而arm-linux-gcc用来在linux下跨平台的C语言编译器,编译出来的程序在目标机(如ARM平台)上执行,嵌入式开发应使用嵌入式交叉编译工具链。
    2. 宿主机与目标机
      • 在嵌入式开发过程中,宿主机是执行编译、链接嵌入式软件的计算机。
      • 目标机是运行嵌入式软件的硬件平台。通常我们用的PC机就是宿主机,而我们本次实验用的ARM实验箱则是目标机。
      • 我们在宿主机上编译链接生成的可执行程序需要放到目标机上运行通过串口、网络、USB下载到目标机上,运行程序armhello
    3. NFS
      • NFS是Network File system的缩写,即网络文件系统。
      • 使我们能够达到文件在不同系统间的共享。当用户想使用远程文件时只要用“mount”命令就可把远程文件系统挂接在自己的文件系统之下,使远程的文件与使用本地计算机上的文件一样。
      • 在计算机A上,想要把计算机B上的/home/linux/exp挂接到A上的/exp,执行命令mount B的IP地址:/home/linux/exp /exp
      • 当客户机挂接一个目录或文件时,并不是说复制服务器上的这一个目录或文件到本地的计算机上,而是在使用时从服务器上读取文件到本地的内存中,因此,可以用cd进入这一个挂接到的目录,就如同进入本地的目录一样。
    4. 超级终端
      • 计算机显示终端,是计算机系统的输入、输出设备。
    5. file命令
      • ````file用来探测指定文件的类型,如下图,我在终端中输入file exe.c```:

      • 语法file (选项) (参数)

      • 选项:

      -b:列出辨识结果时,不显示文件名称;
      -c:详细显示指令执行过程,便于排错或分析程序执行的情形;
      -f<名称文件>:指定名称文件,其内容有一个或多个文件名称时,让file依序辨识这些文件,格式为每列一个文件名称;
      -L:直接显示符号连接所指向的文件类别;
      -m<魔法数字文件>:指定魔法数字文件; 
      -v:显示版本信息;
      -z:尝试去解读压缩文件的内容。
      
      • 参数:要确定类型的文件列表,多个文件之间使用空格分开,可以使用shell通配符匹配多个文件。

    五、参考资料

  • 相关阅读:
    详细解释:nginx中ChsHttpProxyModule模块各项配置及其含义
    详细解释:nginx中ngx_http_headers_module模块配置及各个参数含义
    java生成UUID通用唯一识别码 (Universally Unique Identifier)
    详细解释:nginx中gzip的各项配置以及配置参数的意思详解
    详细解释:nginx中ChsHttpUpstreamModule模块配置及各个参数含义
    linux下jdk、tomcat的安装及项目的部署和去掉项目名访问详细总结
    ORACLE中的序列和触发器
    详解之:linux下tomcat、nginx的负载均衡及memcached对session共享的实现配置详细总结
    ASp.net 剖析三层架构
    asp.net简单的注册或者登陆三层架构的例子
  • 原文地址:https://www.cnblogs.com/zhuohua/p/7687778.html
Copyright © 2011-2022 走看看