Moj*_*jca 3 architecture linux mips endianness mips64
简短的问题:如何在任何Linux发行版上可靠地区分mips,mipsel,mips64和mips64el?
更长的解释:
我们为许多架构提供静态构建/分发独立二进制文件(用于TeX).安装脚本通常运行uname -s并uname -m确定操作系统和体系结构.然后根据该决定从服务器获取二进制文件,因此它需要可靠地工作.确实如此.几乎除了Mac OS X 10.6和Debian之外的所有地方.Mac将在运行64位应用程序的操作系统上报告i386,而Debian报告mips64用于32位操作系统.
mips64上的 Debian 正确报告处理器类型,但这至少有两个原因对我没有帮助:
以下是系统命令的一些输出:
$ 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
...
Run Code Online (Sandbox Code Playgroud)
dpkg-architecture对于该任务来说是完美的,除了它在其他Linux发行版中不存在.
这里已经解决了第一个问题:如何确定给定的Linux是32位还是64位?
命令
getconf LONG_BIT
Run Code Online (Sandbox Code Playgroud)
在我的系统上正确报告32.
但是,我如何确定它是大端还是小端?
我发现config.guess可以确定差异,但它通过运行最终用户计算机上可能不存在的编译器来实现.除此之外,config.guess完全忽略了操作系统在32位模式下工作并错误地报告mips64el而不是mipsel的事实.
file命令告诉你:
$ file my_binary_name
my_binary_name:ELF 32位LSB的可执行文件,MIPS,MIPS-I版本1(SYSV),动态链接(使用共享库),用于GNU/Linux 2.6.18,具有未知能力0xf41 = 0x756e6700,具有未知能力0x70100 = 0x1040000,剥离
那里的LSB代表最不重要的字节,意味着小端.给定big-endian二进制文件的文件输出将是MSB,最重要的字节.
请注意,MIPS有3个ABI(实际上更多),其中一个是n32.n32具有本机64位整数,但只有32位指针(并且需要64位内核).
对于n32二进制文件file仍将报告32位:
ELF 32位LSB可执行文件,MIPS,N32 MIPS-III版本1(SYSV)
o32(debian使用的):
ELF 32位LSB可执行文件,MIPS,MIPS-III版本1(SYSV)
N64:
ELF 64位LSB可执行文件,MIPS,MIPS-III版本1(SYSV)
| 归档时间: |
|
| 查看次数: |
8157 次 |
| 最近记录: |