summaryrefslogtreecommitdiffstats
path: root/mdk-stage1/insmod-modutils/util/arch64.c
diff options
context:
space:
mode:
authorGwenolé Beauchesne <gbeauchesne@mandriva.org>2003-06-04 18:31:57 +0000
committerGwenolé Beauchesne <gbeauchesne@mandriva.org>2003-06-04 18:31:57 +0000
commit09e967c2d732783b2579e4e120cd9b608404cb00 (patch)
tree8d2783a6a7e33608c6012efd6a88b8f5694df81d /mdk-stage1/insmod-modutils/util/arch64.c
parent18fcff49d3c836697d3b75a3d01d31c700e69974 (diff)
downloaddrakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar.gz
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar.bz2
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.tar.xz
drakx-backup-do-not-use-09e967c2d732783b2579e4e120cd9b608404cb00.zip
Merge from R9_0-AMD64, most notably:
- AMD64 support to insmod-busybox, minilibc, et al. - Sync with insmod-modutils 2.4.19 something but everyone should use dietlibc nowadays - Factor out compilation and prefix with $(DIET) for dietlibc builds - 64-bit & varargs fixes
Diffstat (limited to 'mdk-stage1/insmod-modutils/util/arch64.c')
-rw-r--r--mdk-stage1/insmod-modutils/util/arch64.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/mdk-stage1/insmod-modutils/util/arch64.c b/mdk-stage1/insmod-modutils/util/arch64.c
index 4d5ace223..90886d16b 100644
--- a/mdk-stage1/insmod-modutils/util/arch64.c
+++ b/mdk-stage1/insmod-modutils/util/arch64.c
@@ -18,8 +18,6 @@
along with this program; if not, write to the Free Software Foundation,
Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
-#ident "$Id$"
-
#include <stdlib.h>
#include <string.h>
#include <sys/utsname.h>
@@ -30,6 +28,16 @@
/* Indicate if the current machine uses 64 bit architecture */
int arch64(void)
{
- struct utsname u;
- return(!uname(&u) && strstr(u.machine, "64"));
+ struct utsname uts;
+ char *uname_m;
+ if (uname(&uts))
+ return(0);
+ if ((uname_m = getenv("UNAME_MACHINE"))) {
+ int l = strlen(uname_m);
+ if (l >= sizeof(uts.machine))
+ l = sizeof(uts.machine)-1;
+ memcpy(uts.machine, uname_m, l);
+ uts.machine[l] = '\0';
+ }
+ return(strstr(uts.machine, "64") != NULL);
}