syscall-internal.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /* -*-comment-start: "//";comment-end:""-*-
  2. * GNU Mes --- Maxwell Equations of Software
  3. * Copyright © 2016,2017,2018,2020 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
  4. *
  5. * This file is part of GNU Mes.
  6. *
  7. * GNU Mes is free software; you can redistribute it and/or modify it
  8. * under the terms of the GNU General Public License as published by
  9. * the Free Software Foundation; either version 3 of the License, or (at
  10. * your option) any later version.
  11. *
  12. * GNU Mes is distributed in the hope that it will be useful, but
  13. * WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with GNU Mes. If not, see <http://www.gnu.org/licenses/>.
  19. */
  20. #include <errno.h>
  21. #include <linux/x86_64/syscall.h>
  22. // *INDENT-OFF*
  23. static long
  24. __sys_call_internal (long sys_call)
  25. {
  26. long r;
  27. asm (
  28. "mov %1,%%rax\n\t"
  29. "syscall \n\t"
  30. "mov %%rax,%0\n\t"
  31. : "=r" (r)
  32. : "rm" (sys_call)
  33. : "rax"
  34. );
  35. return r;
  36. }
  37. static long
  38. __sys_call2_internal (long sys_call, long one, long two)
  39. {
  40. long r;
  41. asm (
  42. "mov %1,%%rax\n\t"
  43. "mov %2,%%rdi\n\t"
  44. "mov %3,%%rsi\n\t"
  45. "syscall \n\t"
  46. "mov %%rax,%0\n\t"
  47. : "=r" (r)
  48. : "rm" (sys_call), "rm" (one), "rm" (two)
  49. : "rax", "rdi", "rsi"
  50. );
  51. return r;
  52. }
  53. // *INDENT-ON*
  54. /* Return < 0 on error (errno-like value from kernel), or 0 on success */
  55. int
  56. __raise (int signum)
  57. {
  58. long pid = __sys_call_internal (SYS_getpid);
  59. if (pid < 0)
  60. return pid;
  61. else
  62. return __sys_call2_internal (SYS_kill, pid, signum);
  63. }