check_initial_reg_state.c 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * check_initial_reg_state.c - check that execve sets the correct state
  4. * Copyright (c) 2014-2016 Andrew Lutomirski
  5. */
  6. #define _GNU_SOURCE
  7. #include <stdio.h>
  8. unsigned long ax, bx, cx, dx, si, di, bp, sp, flags;
  9. unsigned long r8, r9, r10, r11, r12, r13, r14, r15;
  10. asm (
  11. ".pushsection .text\n\t"
  12. ".type real_start, @function\n\t"
  13. ".global real_start\n\t"
  14. "real_start:\n\t"
  15. #ifdef __x86_64__
  16. "mov %rax, ax\n\t"
  17. "mov %rbx, bx\n\t"
  18. "mov %rcx, cx\n\t"
  19. "mov %rdx, dx\n\t"
  20. "mov %rsi, si\n\t"
  21. "mov %rdi, di\n\t"
  22. "mov %rbp, bp\n\t"
  23. "mov %rsp, sp\n\t"
  24. "mov %r8, r8\n\t"
  25. "mov %r9, r9\n\t"
  26. "mov %r10, r10\n\t"
  27. "mov %r11, r11\n\t"
  28. "mov %r12, r12\n\t"
  29. "mov %r13, r13\n\t"
  30. "mov %r14, r14\n\t"
  31. "mov %r15, r15\n\t"
  32. "pushfq\n\t"
  33. "popq flags\n\t"
  34. #else
  35. "mov %eax, ax\n\t"
  36. "mov %ebx, bx\n\t"
  37. "mov %ecx, cx\n\t"
  38. "mov %edx, dx\n\t"
  39. "mov %esi, si\n\t"
  40. "mov %edi, di\n\t"
  41. "mov %ebp, bp\n\t"
  42. "mov %esp, sp\n\t"
  43. "pushfl\n\t"
  44. "popl flags\n\t"
  45. #endif
  46. "jmp _start\n\t"
  47. ".size real_start, . - real_start\n\t"
  48. ".popsection");
  49. int main()
  50. {
  51. int nerrs = 0;
  52. if (sp == 0) {
  53. printf("[FAIL]\tTest was built incorrectly\n");
  54. return 1;
  55. }
  56. if (ax || bx || cx || dx || si || di || bp
  57. #ifdef __x86_64__
  58. || r8 || r9 || r10 || r11 || r12 || r13 || r14 || r15
  59. #endif
  60. ) {
  61. printf("[FAIL]\tAll GPRs except SP should be 0\n");
  62. #define SHOW(x) printf("\t" #x " = 0x%lx\n", x);
  63. SHOW(ax);
  64. SHOW(bx);
  65. SHOW(cx);
  66. SHOW(dx);
  67. SHOW(si);
  68. SHOW(di);
  69. SHOW(bp);
  70. SHOW(sp);
  71. #ifdef __x86_64__
  72. SHOW(r8);
  73. SHOW(r9);
  74. SHOW(r10);
  75. SHOW(r11);
  76. SHOW(r12);
  77. SHOW(r13);
  78. SHOW(r14);
  79. SHOW(r15);
  80. #endif
  81. nerrs++;
  82. } else {
  83. printf("[OK]\tAll GPRs except SP are 0\n");
  84. }
  85. if (flags != 0x202) {
  86. printf("[FAIL]\tFLAGS is 0x%lx, but it should be 0x202\n", flags);
  87. nerrs++;
  88. } else {
  89. printf("[OK]\tFLAGS is 0x202\n");
  90. }
  91. return nerrs ? 1 : 0;
  92. }