mm: fix exec activate_mm vs TLB shootdown and lazy tlb switching race
[linux/fpc-iii.git] / arch / arc / include / asm / syscall.h
blob29de098043064a20112dd7ffd02f86059261ae44
1 /*
2 * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 */
9 #ifndef _ASM_ARC_SYSCALL_H
10 #define _ASM_ARC_SYSCALL_H 1
12 #include <linux/err.h>
13 #include <linux/sched.h>
14 #include <asm/unistd.h>
15 #include <asm/ptrace.h> /* in_syscall() */
17 static inline long
18 syscall_get_nr(struct task_struct *task, struct pt_regs *regs)
20 if (user_mode(regs) && in_syscall(regs))
21 return regs->r8;
22 else
23 return -1;
26 static inline void
27 syscall_rollback(struct task_struct *task, struct pt_regs *regs)
29 regs->r0 = regs->orig_r0;
32 static inline long
33 syscall_get_error(struct task_struct *task, struct pt_regs *regs)
35 /* 0 if syscall succeeded, otherwise -Errorcode */
36 return IS_ERR_VALUE(regs->r0) ? regs->r0 : 0;
39 static inline long
40 syscall_get_return_value(struct task_struct *task, struct pt_regs *regs)
42 return regs->r0;
45 static inline void
46 syscall_set_return_value(struct task_struct *task, struct pt_regs *regs,
47 int error, long val)
49 regs->r0 = (long) error ?: val;
53 * @i: argument index [0,5]
54 * @n: number of arguments; n+i must be [1,6].
56 static inline void
57 syscall_get_arguments(struct task_struct *task, struct pt_regs *regs,
58 unsigned int i, unsigned int n, unsigned long *args)
60 unsigned long *inside_ptregs = &(regs->r0);
61 inside_ptregs -= i;
63 BUG_ON((i + n) > 6);
65 while (n--) {
66 args[i++] = (*inside_ptregs);
67 inside_ptregs--;
71 #endif