实战 WSL2.0 arm 交叉工具链 — 踩坑交叉编译不兼容问题

本文详细记录了在WSL2.0环境下进行ARM交叉编译遇到的不兼容问题,包括目标终端异常、CPU卡顿和用户权限问题。通过问题定位和解决,最终发现使用VMware Linux平台编译可以避免这些问题,推测可能与WSL2.0的Linux兼容性有关。
摘要由CSDN通过智能技术生成

实战 WSL2.0 arm 交叉工具链 — 踩坑交叉编译不兼容问题

环境

  • 交叉编译器: 在 VMware UBUNTU 18.04 x64WSL 2.0 UBUNTU 20.04 x64(非 docker 环境) 中安装的都是 arm-linux-gnueabihf-4.9.4-2017.01-linaro这款编译器,从官网下载的安装包 gcc-linaro-4.9.4-2017.01-x86_64_arm-linux-gnueabihf.tar.xz
  • 目标终端: 内核及文件系统,是平台组 VMware UBUNTU 18.04 x64 平台下 gcc-linaro-4.9-2016.02-x86_64_arm-linux-gnueabihf.tar.xz交叉编译的

问题描述

  • 绝大多数情况下,目标终端看起来正常,然而,总有少量的机器表现莫名其妙地异常
  • 在偶尔出现问题的终端中,起初没有发现有什么异常,仔细分析之后发现有低概率“CPU貌似卡顿”的现象
  • 模拟测试时,发现 WSL 2.0 (非 docker 环境) 中发布的安装包,以 root 用户远程升级之后的用户名和组居然不是 root 帐户
  • 加入进程内存、CPU运行状态跟踪监控代码,某些出现问题的终端每运行1小时会耗尽内存

问题解决

  • 从代码分析上找不到原因的情况下,试着从 root 帐户的问题入手,试着看看是不是平台的问题。从VMware UBUNTU 18.04 x64平台编译打包,居然发现 root 帐户问题神奇消失
  • VMware UBUNTU 18.04 x64交叉编译和打包发布,疑似的“CPU卡顿”问题消失

问题溯源

  • 删除临时文件,纯净交叉编译项目中的守护进程,然后arm-linux-gnueabihf-readelf导出 VMware UBUNTU 18.04 x64WSL 2.0 UBUNTU 20.04 x64编译的目标文件信息,发现些微差别

    VMware UBUNTU 18.04 x64平台

    Unwind table index '.ARM.exidx' at offset 0x12fc contains 8 entries:
    
    0x10e68: 0x1 [cantunwind]
    
    0x10f48: @0x112cc           // 仅 VMware UBUNTU 18.04 x64
      Compact model index: 1
      0x97      vsp = r7
      0x0d      vsp = vsp + 56
      0x84 0x08 pop {
         r7, r14}
      0xb0      finish
      0xb0      finish
    
    0x10fb4: 0x80978008          // 仅 VMware UBUNTU 18.04 x64
      Compact model index: 0
      0x97      vsp = r7
      0x80 0x08 pop {
         r7}
    
    0x10fcc: @0x112d8
      Compact model index: 1
      0x97      vsp = r7
      0x03      vsp = vsp + 16
      0x84 0x08 pop {
         r7, r14}
      0xb0      finish
      0xb0      finish
    
    0x10ff8: @0x112e4
      Compact model index: 1
      0x97      vsp = r7
      0x0a      vsp = vsp + 44
      0x84 0x09 pop {
         r4, r7, r14}
      0xb0      finish
      0xb0      finish
    
    0x1116c: @0x112f0          // 仅 VMware UBUNTU 18.04 x64
      Compact model index: 1
      0x97      vsp = r7
      0x01      vsp = vsp + 8
      0x84 0x08 pop {
         r7, r14}
      0xb0      finish
      0xb0      finish
    
    0x111b4: 0x80978408          // 仅 VMware UBUNTU 18.04 x64
      Compact model index: 0
      0x97      vsp = r7
      0x84 0x08 pop {
         r7, r14}
    
    0x111c4: 0x1 [cantunwind]
    
    
    Symbol table '.dynsym' contains 54 entries:
      Num:    Value  Size Type    Bind   Vis      Ndx Name
        0: 00000000     0 NOTYPE  LOCAL  DEFAULT  UND 
        1: 0001133c     0 NOTYPE  LOCAL  DEFAULT   17 __exidx_end
        2: 000112fc     0 NOTYPE  LOCAL  DEFAULT   16 __exidx_start
        3: 00021528     4 OBJECT  GLOBAL DEFAULT   25 g_sys_res_ctor
        4: 00000000     0 FUNC    GLOBAL DEFAULT  UND sync@GLIBC_2.4 (2)
        5: 00000000     0 FUNC    GLOBAL DEFAULT  UND __aeabi_atexit@CXXABI_ARM_1.3.3 (3)
        6: 00000000<
### 回答1: WSL2和Docker都是开发者常用的工具,用于在Windows操作系统上进行开发和容器化部署。而在WSL2中使用Docker时,可能需要进行交叉编译,以便在WSL2环境下构建和运行适用于不同操作系统的程序。下面是关于WSL2和Docker交叉编译的一些重要信息: 1. WSL2是一种提供在Windows操作系统上运行Linux发行版的功能强大的子系统。它提供了更好的Linux内核兼容性和更高的性能。 2. Docker是一种用于将应用程序打包为独立的容器并进行部署的开源平台。它能够在不同的操作系统上运行,如Linux、Windows和Mac。 3. 在WSL2中使用Docker进行交叉编译时,可以通过设置适当的环境变量来指定编译目标操作系统。例如,可以使用`export GOOS=linux`来指定编译目标为Linux操作系统。 4. 此外,还可以使用Docker的多阶段构建功能来进行交叉编译。通过在Dockerfile中定义多个构建阶段,并在不同的阶段中设置不同的编译环境和目标操作系统,可以实现更灵活和高效的交叉编译过程。 5. 在交叉编译时,还需要注意程序依赖的库和组件是否与目标操作系统兼容。可以使用Docker镜像中的适当环境来构建和验证编译结果。 总之,WSL2和Docker的结合为开发者提供了更好的跨平台开发和部署体验。通过正确设置环境变量和使用Docker的多阶段构建功能,可以在WSL2中轻松实现交叉编译,并将应用程序部署到不同的操作系统中。 ### 回答2: WSL2是Windows Subsystem for Linux 2的缩写,它是Windows 10中的一个子系统,允许用户在Windows操作系统上运行Linux二进制文件。Docker是一个容器平台,可以提供快速、可靠和可重复部署的环境。交叉编译是指将代码从一种操作系统或体系结构编译为另一种操作系统或体系结构的过程。 在WSL2中使用Docker进行交叉编译可以方便地将代码编译成其他平台上可运行的二进制文件。下面是一些步骤: 1. 确保已经在WSL2中安装了Docker。可以通过在终端中运行`docker version`命令来检查Docker是否正确安装和配置。 2. 在WSL2中创建一个目录,用于存放交叉编译的代码。可以使用`mkdir`命令创建一个新目录。 3. 进入该目录,并将需要交叉编译的代码复制到该目录中。可以使用`cp`命令复制文件或文件夹。 4. 在WSL2中运行Docker容器。可以使用`docker run`命令来启动一个容器,并指定所需的镜像。例如,可以使用`docker run -it ubuntu`命令来启动一个Ubuntu的容器。 5. 在Docker容器中安装所需的交叉编译工具。可以使用容器的包管理工具,如apt-get或yum,来安装所需的工具。 6. 使用安装在容器中的交叉编译工具来编译代码。可以在容器的终端中运行适当的编译命令,例如`gcc`或`make`命令。 7. 将交叉编译后的二进制文件复制到WSL2主机上。可以使用`docker cp`命令将文件从容器复制到WSL2文件系统中。例如,可以使用`docker cp <容器ID>:/path/to/binary /path/on/host`命令。 通过以上步骤,我们可以在WSL2中使用Docker进行交叉编译,并将编译后的二进制文件复制回到WSL2主机上使用。这样可以方便地进行跨平台开发和部署。 ### 回答3: WSL2是Windows Subsystem for Linux的第二代版本,它允许在Windows系统上运行Linux操作系统和应用程序。 Docker是一个开源的容器化平台,可以通过容器来打包应用程序及其所有的依赖项,实现简化部署和跨平台运行。 交叉编译是在一种平台上为另一种平台生成可执行文件或库的过程。在使用WSL2和Docker进行交叉编译时,我们可以利用WSL2提供的Linux环境来进行编译,从而为其他平台生成可执行文件或库。 首先,我们需要在WSL2中安装Docker,并确保WSL2和Windows主机之间的网络连接正常。然后,我们可以使用WSL2中的Linux终端,使用Docker命令来拉取相应的交叉编译镜像,例如x86_64-w64-mingw32-gcc镜像用于编译Windows平台的可执行文件。 接下来,我们可以在WSL2中创建一个工作目录,并将需要交叉编译的源代码和相关的依赖项复制到该目录中。然后,使用Docker命令来运行交叉编译镜像,并在容器中进行编译。 在容器中,我们可以使用适当的交叉编译工具来编译源代码,生成针对目标平台的可执行文件或库。编译完成后,我们可以将生成的可执行文件或库从容器中复制到WSL2主机上。 在整个交叉编译过程中,我们可以充分利用WSL2和Docker的优势,使用更多的Linux工具和环境,并保持与Windows主机的良好集成和通信。 总结起来,通过使用WSL2和Docker进行交叉编译,我们可以方便地在Windows系统上为其他平台生成可执行文件或库,并提高开发和部署的灵活性和效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值