64位linux提示gnu/stubs-32.h:No such file or directory的解决方法

Re阿里云yum源没有glibc.i686
阿里云的64位Linux发行版屏蔽了32位,也就是常见的i686软件包的数据源,你可以修改yum的配置文件/etc/yum.conf,找到其中exclude=*.i?86 kernel kernel-xen kernel-debug,用#注释掉即可,但是阿里不赞成这么做,如果32位、64位混用,比较容易出问题。



今天在64linux编译程序时,出现如下错误提示

/usr/include/gnu/stubs.h:7:27: error: gnu/stubs-32.h:No such file or directory

解决方法如下

# yum -y install glibc-devel


场景描述:在编译程序的时候出现如下的错误:

make[1]: Entering directory `/root/rpmbuild/BUILD/test/conf'

In file included from /usr/include/features.h:385,

                 from /usr/include/stdint.h:26,

                 from ../include/MyTypes.h:4,

                 from conf_init.c:1:

/usr/include/gnu/stubs.h:7:27: error: gnu/stubs-32.h: No such file or directory

make[1]: *** [conf_init32.o] Error 1

make[1]: Leaving directory `/root/rpmbuild/BUILD/test/conf'

make: *** [all] Error 1


解决过程:

1完全无法分析天书般的错误,英文非常简单,但是翻译非常困难,好在

/usr/include/gnu/stubs.h:7:27: error: gnu/stubs-32.h: No such file or directory

这一句了解,好既然少这个文件,拷贝一个文件过来,OK解决问题。

2.经过老大的解决思路,看出端倪。

说明如下:conf_init.c:第一行引用../include/MyTypes.h头文件,

而这个头文件在第四行引用/usr/include/stdint.h头文件,

而这个头文件在第26行引用/usr/include/features.h头文件,

而这个头文件在第385行应用了/usr/include/gnu/stubs.h头文件,

而这个头文件在第7行引用了gnu/stubs-32.h头文件

然后在编译的过程中,没有发现这个文件。大体意思清楚没有。

下面是/usr/include/gnu/stubs.h文件的内容如下:


/* This file selects the right generated file of `__stub_FUNCTION' macros

   based on the architecture being compiled for.  */



#include


#if __WORDSIZE == 32

# include

#elif __WORDSIZE == 64

# include

#els

# error "unexpected value for __WORDSIZE macro"

#endif

~       

注明:这个文件说明了64位或者32位编译环境选择的头文件。所以在编译的过程中,

使用了-m2的参数就会链接到32位版本的编译器,修改所有的Makefile文件,查看

是否有什么32位编译的删除即可。


查阅的外文资料几乎没有任何用处:

On Ubuntu it's called libc6-dev-i386 - do sudo apt-get install libc6-dev-i386. See below for extra instructions for Ubuntu 12.04.


On Red Hat distros, the package name is glibc-devel.i686 (Thanks to David Gardner's comment)


On CentOS 5.8, the package name is glibc-devel.i386 (Thanks to JimKleck's comment)


On CentOS 6.3, the package name is glibc-devel.i686.


On SLES it's called glibc-devel-32bit - do zypper in glibc-devel-32bit

在SLES系统上,执行上述指令安装,在/usr/include/gnu目录下确实生成了上述的文件。

在CentOS系统上,无效。


你可能感兴趣的:(linux,make)