简短的问题:如何在任何 Linux 发行版上可靠地区分mips、mipsel、mips64和mips64el ?
更长的解释:
我们为许多架构提供静态构建/分发独立的二进制文件(用于 TeX)。安装脚本通常运行uname -s
并uname -m
确定操作系统和体系结构。然后根据该决定从服务器获取二进制文件,因此它需要可靠地工作。它确实如此。几乎无处不在,除了 Mac OS X 10.6 和 Debian。Mac 会在运行 64 位应用程序的操作系统上报告i386 ,而 Debian 会在 32 位操作系统上报告mips64 。
mips64上的 Debian正确报告处理器类型,但这对我没有帮助,至少有两个原因:
- 操作系统是 32 位的,而不是顾名思义的 64 位。
- 它以小端模式运行。Debian 称之为mipsel,而不是mips。它通常可以切换,但操作系统只能运行在一种模式下,mips 软件通常与 mipsel 不兼容。
以下是系统命令的一些输出:
$ file my_binary_name
my_binary_name: ELF 32-bit LSB executable, MIPS, MIPS-I version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.18, with unknown capability 0xf41 = 0x756e6700, with unknown capability 0x70100 = 0x1040000, stripped
$ dpkg-architecture
DEB_BUILD_ARCH=mipsel
DEB_BUILD_ARCH_OS=linux
DEB_BUILD_ARCH_CPU=mipsel
DEB_BUILD_ARCH_BITS=32
DEB_BUILD_ARCH_ENDIAN=little
DEB_BUILD_GNU_CPU=mipsel
DEB_BUILD_GNU_SYSTEM=linux-gnu
DEB_BUILD_GNU_TYPE=mipsel-linux-gnu
DEB_HOST_ARCH=mipsel
...
dpkg-architecture 将非常适合该任务,除了它不存在于其他 Linux 发行版上。
第一个问题已经在这里解决了:如何确定给定的 Linux 是 32 位还是 64 位?
命令
getconf LONG_BIT
在我的系统上正确报告 32。
但是我如何确定它是大端还是小端呢?
我发现 config.guess 可以确定差异,但它是通过运行最终用户计算机上可能不存在的编译器来确定的。除此之外 config.guess 完全忽略了操作系统在 32 位模式下工作并错误地报告mips64el而不是mipsel的事实。