Browse Source

add namespace-protected name for sysinfo function

it will be needed to implement some things in sysconf, and the syscall
can't easily be used directly because the x32 syscall uses the wrong
structure layout. the l (uncreative, for "linux") prefix is used since
the symbol name __sysinfo is already taken for AT_SYSINFO from the aux
vector.

the way the x32 override of this function works is also changed to be
simpler and avoid the useless jump instruction.
Rich Felker 11 years ago
parent
commit
de20a8ffc5
3 changed files with 9 additions and 7 deletions
  1. 4 1
      arch/x32/src/sysinfo.c
  2. 4 1
      src/linux/sysinfo.c
  3. 1 5
      src/linux/x32/sysinfo.s

+ 4 - 1
arch/x32/src/sysinfo.c

@@ -1,5 +1,6 @@
 #include <sys/sysinfo.h>
 #include "syscall.h"
+#include "libc.h"
 
 #define klong long long
 #define kulong unsigned long long
@@ -20,7 +21,7 @@ struct kernel_sysinfo {
 	unsigned mem_unit;
 };
 
-int __x32_sysinfo(struct sysinfo *info)
+int __lsysinfo(struct sysinfo *info)
 {
 	struct kernel_sysinfo tmp;
 	int ret = syscall(SYS_sysinfo, &tmp);
@@ -45,3 +46,5 @@ int __x32_sysinfo(struct sysinfo *info)
 	info->mem_unit = (tmp.mem_unit ? tmp.mem_unit : 1) << shifts;
 	return ret;
 }
+
+weak_alias(__lsysinfo, sysinfo);

+ 4 - 1
src/linux/sysinfo.c

@@ -1,7 +1,10 @@
 #include <sys/sysinfo.h>
 #include "syscall.h"
+#include "libc.h"
 
-int sysinfo(struct sysinfo *info)
+int __lsysinfo(struct sysinfo *info)
 {
 	return syscall(SYS_sysinfo, info);
 }
+
+weak_alias(__lsysinfo, sysinfo);

+ 1 - 5
src/linux/x32/sysinfo.s

@@ -1,5 +1 @@
-.text
-.global sysinfo
-.type   sysinfo,@function
-sysinfo:
-	jmp __x32_sysinfo
+# see arch/x32/src/sysinfo.c