aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/generic
diff options
context:
space:
mode:
authorAndreas Jaeger <aj@suse.de>2000-11-15 08:46:30 +0000
committerAndreas Jaeger <aj@suse.de>2000-11-15 08:46:30 +0000
commita6c1c03a440ec55e427844ba851eed1ea2c95c95 (patch)
treefd63a016f9ad7a0bbd35a3848864560ce11fa9bd /sysdeps/generic
parentad1a5cc746c507ddd9b31cae653aefe3fac7a249 (diff)
downloadglibc-a6c1c03a440ec55e427844ba851eed1ea2c95c95.zip
glibc-a6c1c03a440ec55e427844ba851eed1ea2c95c95.tar.gz
glibc-a6c1c03a440ec55e427844ba851eed1ea2c95c95.tar.bz2
Update.
2000-11-15 Andreas Jaeger <aj@suse.de> * elf/cache.c (struct cache_entry): Use uint64_t for hwcap. (print_entry): Likewise. (add_to_cache): Likewise. * elf/ldconfig.h (add_to_cache): Change prototype for hwcap change. * elf/ldconfig.c (struct lib_entry): Use uint64_t for hwcap. (path_hwcap): Likewise. (search_dir): Likewise. * sysdeps/generic/dl-cache.c (HWCAP_CHECK): Handle platform. * elf/cache.c (add_to_cache): Handle 64 bit hwcap entry. * sysdeps/unix/sysv/linux/sparc/sparc32/dl-procinfo.h (_dl_platform_string): New. (_DL_HWCAP_PLATFORM): New. (_dl_string_platform): New. * sysdeps/unix/sysv/linux/sparc/sparc64/dl-procinfo.h: Likewise. * sysdeps/generic/dl-procinfo.h (_DL_HWCAP_COUNT): New. (_dl_string_platform): New. (_DL_HWCAP_PLATFORM): New. (_dl_platform_string): New. * sysdeps/unix/sysv/linux/i386/dl-procinfo.h: Added x86 platform recognition. (_DL_HWCAP_COUNT): New. (_dl_string_platform): New. (_DL_HWCAP_PLATFORM): New. (_dl_platform_string): New.
Diffstat (limited to 'sysdeps/generic')
-rw-r--r--sysdeps/generic/dl-cache.c21
-rw-r--r--sysdeps/generic/dl-procinfo.h8
2 files changed, 26 insertions, 3 deletions
diff --git a/sysdeps/generic/dl-cache.c b/sysdeps/generic/dl-cache.c
index 8206171..4ece370 100644
--- a/sysdeps/generic/dl-cache.c
+++ b/sysdeps/generic/dl-cache.c
@@ -22,7 +22,9 @@
#include <ldsodefs.h>
#include <sys/mman.h>
#include <dl-cache.h>
+#include <dl-procinfo.h>
+#include <stdio-common/_itoa.h>
/* System-dependent function to read a file's whole contents
in the most convenient manner available. */
@@ -30,6 +32,8 @@ extern void *_dl_sysdep_read_whole_file (const char *filename,
size_t *filesize_ptr,
int mmap_prot);
+extern const char *_dl_platform;
+
/* This is the starting address and the size of the mmap()ed file. */
static struct cache_file *cache;
static struct cache_file_new *cache_new;
@@ -209,6 +213,7 @@ _dl_load_cache_lookup (const char *name)
{
/* This file ends in static libraries where we don't have a hwcap. */
unsigned long int *hwcap;
+ uint64_t platform;
weak_extern (_dl_hwcap);
/* This is where the strings start. */
@@ -218,9 +223,19 @@ _dl_load_cache_lookup (const char *name)
cache_data_size = (const char *) cache + cachesize - cache_data;
hwcap = &_dl_hwcap;
-
-#define HWCAP_CHECK \
- if (hwcap && (cache_new->libs[middle].hwcap & *hwcap) > *hwcap) \
+ platform = _dl_string_platform (_dl_platform);
+ if (platform != -1)
+ platform = 1ULL << platform;
+
+ /* Only accept hwcap if it's for the right platform. */
+#define HWCAP_CHECK \
+ if (_DL_PLATFORMS_COUNT && platform != -1 \
+ && (cache_new->libs[middle].hwcap & _DL_HWCAP_PLATFORM) != 0 \
+ && (cache_new->libs[middle].hwcap & _DL_HWCAP_PLATFORM) != platform) \
+ continue; \
+ if (hwcap \
+ && ((cache_new->libs[middle].hwcap & *hwcap & ~_DL_HWCAP_PLATFORM) \
+ > *hwcap)) \
continue
SEARCH_CACHE (cache_new);
}
diff --git a/sysdeps/generic/dl-procinfo.h b/sysdeps/generic/dl-procinfo.h
index 180a08b..902eddd 100644
--- a/sysdeps/generic/dl-procinfo.h
+++ b/sysdeps/generic/dl-procinfo.h
@@ -27,12 +27,20 @@
/* There are no hardware capabilities defined. */
#define _dl_hwcap_string(idx) ""
+/* There are no different platforms defined. */
+#define _dl_platform_string(idx) ""
+
/* By default there is no important hardware capability. */
#define HWCAP_IMPORTANT (0)
+/* There're no platforms to filter out. */
+#define _DL_HWCAP_PLATFORM 0
+
/* We don't have any hardware capabilities. */
#define _DL_HWCAP_COUNT 0
#define _dl_string_hwcap(str) (-1)
+#define _dl_string_platform(str) (-1)
+
#endif /* dl-procinfo.h */