Two Linux frustrations
Jun. 4th, 2007 05:32 pmWe've just got a new machine at work on which I've been asked to install OpenSuSE 10.2 64-bit; this felt entirely straightforward.
Unfortunately, the default install of OpenSuSE doesn't include gcc. When I try installing gcc using YaST2, I get something which looks superficially like gcc, but which says 'gcc: error trying to exec 'cc1': execvp: No such file or directory' whenever I try to compile anything with it.
So, where's cc1 coming from? Deciding now would be a good time to use up some of the EU Assorted Symbol Mountain, I type
for i in /media/SU1020.001/suse/x86_64/*.rpm; do rpm -qpl $i | sed -e "s/^/${i//\//_}/g" | grep cc1; done
which tells me that /usr/lib64/gcc/x86_64-suse-linux/4.1.2/cc1 is provided by cpp41-4.1.2_20061115-5.x86_64.rpm
And indeed /usr/lib64/gcc/x86_64-suse-linux/4.1.2/cc1 exists on the machine. So, why isn't /usr/bin/gcc-4.1 finding it?
Normally strace comes to the rescue, but 'strace /usr/bin/gcc-4.1 -c foo.c' outputs many lines of the form
stat64(0x806b628, 0xff885abc) = -1 ENOENT (No such file or directory)
which are totally useless because strace is failing to dereference the pointer to the filename passed to stat64.
Unfortunately, the default install of OpenSuSE doesn't include gcc. When I try installing gcc using YaST2, I get something which looks superficially like gcc, but which says 'gcc: error trying to exec 'cc1': execvp: No such file or directory' whenever I try to compile anything with it.
So, where's cc1 coming from? Deciding now would be a good time to use up some of the EU Assorted Symbol Mountain, I type
for i in /media/SU1020.001/suse/x86_64/*.rpm; do rpm -qpl $i | sed -e "s/^/${i//\//_}/g" | grep cc1; done
which tells me that /usr/lib64/gcc/x86_64-suse-linux/4.1.2/cc1 is provided by cpp41-4.1.2_20061115-5.x86_64.rpm
And indeed /usr/lib64/gcc/x86_64-suse-linux/4.1.2/cc1 exists on the machine. So, why isn't /usr/bin/gcc-4.1 finding it?
Normally strace comes to the rescue, but 'strace /usr/bin/gcc-4.1 -c foo.c' outputs many lines of the form
stat64(0x806b628, 0xff885abc) = -1 ENOENT (No such file or directory)
which are totally useless because strace is failing to dereference the pointer to the filename passed to stat64.
no subject
Date: 2007-06-04 06:00 pm (UTC)no subject
Date: 2007-06-05 11:21 am (UTC)I'm a little surprised that I've ended up in a situation with
/usr/bin/gcc-4.1: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), for GNU/Linux 2.6.4, dynamically linked (uses shared libs), for GNU/Linux 2.6.4, stripped
/usr/lib64/gcc/x86_64-suse-linux/4.1.2/cc1: ELF 64-bit LSB executable, AMD x86-64, version 1 (SYSV), for GNU/Linux 2.6.4, dynamically linked (uses shared libs), for GNU/Linux 2.6.4, stripped
I've not done much to the machine; whilst this is an obvious admission of defeat, I'll reinstall the OS and see if that helps.
no subject
Date: 2007-06-05 01:38 pm (UTC)no subject
Date: 2007-06-05 02:48 pm (UTC)Sorry, that's the least useful possible resolution to this problem, but I lack the brain and the time to concoct a better.
no subject
Date: 2007-06-05 02:52 pm (UTC)no subject
Date: 2007-06-04 09:25 pm (UTC)The trick with suse installs is to click the "software selection" link when you get to the "this is what we're going to install" page; you then get the chance to say "development tools, that sounds cool" ...
no subject
Date: 2007-06-05 06:56 am (UTC)Maybe you could try uninstalling the gcc package and reinstalling ? Double-check that there are no error messages on installation ?
no subject
Date: 2007-06-05 09:13 am (UTC)no subject
Date: 2007-06-05 11:23 am (UTC)