Commit f87ea91d authored by Jeff Dike's avatar Jeff Dike Committed by Linus Torvalds

uml: redo the calculation of NR_syscalls

Redo the calculation of NR_syscalls since that disappeared from i386 and
use a similar mechanism on x86_64.

We now figure out the size of the system call table in arch code and stick
that in syscall_table_size.  arch/um/kernel/skas/syscall.c defines
NR_syscalls in terms of that since its the only thing that needs to know
how many system calls there are.

The old mechananism that was used on x86_64 is gone.

arch/um/include/sysdep-i386/syscalls.h got some formatting since I was
looking at it.
Signed-off-by: default avatarJeff Dike <jdike@linux.intel.com>
Cc: WANG Cong <xiyou.wangcong@gmail.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 966f1d8f
/* /*
* Copyright (C) 2000 Jeff Dike (jdike@karaya.com) * Copyright (C) 2000 - 2008 Jeff Dike (jdike@{addtoit,linux.intel}.com)
* Licensed under the GPL * Licensed under the GPL
*/ */
...@@ -18,7 +18,8 @@ extern syscall_handler_t old_mmap_i386; ...@@ -18,7 +18,8 @@ extern syscall_handler_t old_mmap_i386;
extern syscall_handler_t *sys_call_table[]; extern syscall_handler_t *sys_call_table[];
#define EXECUTE_SYSCALL(syscall, regs) \ #define EXECUTE_SYSCALL(syscall, regs) \
((long (*)(struct syscall_args)) (*sys_call_table[syscall]))(SYSCALL_ARGS(&regs->regs)) ((long (*)(struct syscall_args)) \
(*sys_call_table[syscall]))(SYSCALL_ARGS(&regs->regs))
extern long sys_mmap2(unsigned long addr, unsigned long len, extern long sys_mmap2(unsigned long addr, unsigned long len,
unsigned long prot, unsigned long flags, unsigned long prot, unsigned long flags,
......
...@@ -17,16 +17,7 @@ ...@@ -17,16 +17,7 @@
#define OFFSET(sym, str, mem) \ #define OFFSET(sym, str, mem) \
DEFINE(sym, offsetof(struct str, mem)); DEFINE(sym, offsetof(struct str, mem));
#define __NO_STUBS 1
#undef __SYSCALL
#undef _ASM_X86_64_UNISTD_H_
#define __SYSCALL(nr, sym) [nr] = 1,
static char syscalls[] = {
#include <asm/arch/unistd.h>
};
void foo(void) void foo(void)
{ {
#include <common-offsets.h> #include <common-offsets.h>
DEFINE(UM_NR_syscall_max, sizeof(syscalls) - 1);
} }
...@@ -30,6 +30,4 @@ extern long old_mmap(unsigned long addr, unsigned long len, ...@@ -30,6 +30,4 @@ extern long old_mmap(unsigned long addr, unsigned long len,
extern syscall_handler_t sys_modify_ldt; extern syscall_handler_t sys_modify_ldt;
extern syscall_handler_t sys_arch_prctl; extern syscall_handler_t sys_arch_prctl;
#define NR_syscalls (UM_NR_syscall_max + 1)
#endif #endif
...@@ -9,6 +9,9 @@ ...@@ -9,6 +9,9 @@
#include "sysdep/ptrace.h" #include "sysdep/ptrace.h"
#include "sysdep/syscalls.h" #include "sysdep/syscalls.h"
extern int syscall_table_size;
#define NR_syscalls (syscall_table_size / sizeof(void *))
void handle_syscall(struct uml_pt_regs *r) void handle_syscall(struct uml_pt_regs *r)
{ {
struct pt_regs *regs = container_of(r, struct pt_regs, regs); struct pt_regs *regs = container_of(r, struct pt_regs, regs);
......
...@@ -9,4 +9,9 @@ ...@@ -9,4 +9,9 @@
#define old_mmap old_mmap_i386 #define old_mmap old_mmap_i386
.section .rodata,"a"
#include "../../x86/kernel/syscall_table_32.S" #include "../../x86/kernel/syscall_table_32.S"
ENTRY(syscall_table_size)
.long .-sys_call_table
...@@ -52,11 +52,19 @@ typedef void (*sys_call_ptr_t)(void); ...@@ -52,11 +52,19 @@ typedef void (*sys_call_ptr_t)(void);
extern void sys_ni_syscall(void); extern void sys_ni_syscall(void);
sys_call_ptr_t sys_call_table[UM_NR_syscall_max+1] __cacheline_aligned = { /*
/* * We used to have a trick here which made sure that holes in the
* Smells like a like a compiler bug -- it doesn't work when the & * x86_64 table were filled in with sys_ni_syscall, but a comment in
* below is removed. * unistd_64.h says that holes aren't allowed, so the trick was
* removed.
* The trick looked like this
* [0 ... UM_NR_syscall_max] = &sys_ni_syscall
* before including unistd_64.h - the later initializations overwrote
* the sys_ni_syscall filler.
*/ */
[0 ... UM_NR_syscall_max] = &sys_ni_syscall,
sys_call_ptr_t sys_call_table[] __cacheline_aligned = {
#include <asm-x86/unistd_64.h> #include <asm-x86/unistd_64.h>
}; };
int syscall_table_size = sizeof(sys_call_table);
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment