compat-signal.h 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #ifndef __ASM_COMPAT_SIGNAL_H
  2. #define __ASM_COMPAT_SIGNAL_H
  3. #include <linux/bug.h>
  4. #include <linux/compat.h>
  5. #include <linux/compiler.h>
  6. static inline int __copy_conv_sigset_to_user(compat_sigset_t __user *d,
  7. const sigset_t *s)
  8. {
  9. int err;
  10. BUG_ON(sizeof(*d) != sizeof(*s));
  11. BUG_ON(_NSIG_WORDS != 2);
  12. err = __put_user(s->sig[0], &d->sig[0]);
  13. err |= __put_user(s->sig[0] >> 32, &d->sig[1]);
  14. err |= __put_user(s->sig[1], &d->sig[2]);
  15. err |= __put_user(s->sig[1] >> 32, &d->sig[3]);
  16. return err;
  17. }
  18. static inline int __copy_conv_sigset_from_user(sigset_t *d,
  19. const compat_sigset_t __user *s)
  20. {
  21. int err;
  22. union sigset_u {
  23. sigset_t s;
  24. compat_sigset_t c;
  25. } *u = (union sigset_u *) d;
  26. BUG_ON(sizeof(*d) != sizeof(*s));
  27. BUG_ON(_NSIG_WORDS != 2);
  28. if (unlikely(!access_ok(VERIFY_READ, d, sizeof(*d))))
  29. return -EFAULT;
  30. #ifdef CONFIG_CPU_BIG_ENDIAN
  31. err = __get_user(u->c.sig[1], &s->sig[0]);
  32. err |= __get_user(u->c.sig[0], &s->sig[1]);
  33. err |= __get_user(u->c.sig[3], &s->sig[2]);
  34. err |= __get_user(u->c.sig[2], &s->sig[3]);
  35. #endif
  36. #ifdef CONFIG_CPU_LITTLE_ENDIAN
  37. err = __get_user(u->c.sig[0], &s->sig[0]);
  38. err |= __get_user(u->c.sig[1], &s->sig[1]);
  39. err |= __get_user(u->c.sig[2], &s->sig[2]);
  40. err |= __get_user(u->c.sig[3], &s->sig[3]);
  41. #endif
  42. return err;
  43. }
  44. #endif /* __ASM_COMPAT_SIGNAL_H */