syscall.h 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright Altera Corporation (C) <2014>. All rights reserved
  4. */
  5. #ifndef __ASM_NIOS2_SYSCALL_H__
  6. #define __ASM_NIOS2_SYSCALL_H__
  7. #include <uapi/linux/audit.h>
  8. #include <linux/err.h>
  9. #include <linux/sched.h>
  10. static inline int syscall_get_nr(struct task_struct *task, struct pt_regs *regs)
  11. {
  12. return regs->r2;
  13. }
  14. static inline void syscall_rollback(struct task_struct *task,
  15. struct pt_regs *regs)
  16. {
  17. regs->r2 = regs->orig_r2;
  18. regs->r7 = regs->orig_r7;
  19. }
  20. static inline long syscall_get_error(struct task_struct *task,
  21. struct pt_regs *regs)
  22. {
  23. return regs->r7 ? regs->r2 : 0;
  24. }
  25. static inline long syscall_get_return_value(struct task_struct *task,
  26. struct pt_regs *regs)
  27. {
  28. return regs->r2;
  29. }
  30. static inline void syscall_set_return_value(struct task_struct *task,
  31. struct pt_regs *regs, int error, long val)
  32. {
  33. if (error) {
  34. /* error < 0, but nios2 uses > 0 return value */
  35. regs->r2 = -error;
  36. regs->r7 = 1;
  37. } else {
  38. regs->r2 = val;
  39. regs->r7 = 0;
  40. }
  41. }
  42. static inline void syscall_get_arguments(struct task_struct *task,
  43. struct pt_regs *regs, unsigned long *args)
  44. {
  45. *args++ = regs->r4;
  46. *args++ = regs->r5;
  47. *args++ = regs->r6;
  48. *args++ = regs->r7;
  49. *args++ = regs->r8;
  50. *args = regs->r9;
  51. }
  52. static inline int syscall_get_arch(struct task_struct *task)
  53. {
  54. return AUDIT_ARCH_NIOS2;
  55. }
  56. #endif