generated-offsets.c 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. #include <stddef.h>
  2. #include <asm/errno.h>
  3. #include "sgx_arch.h"
  4. #include "sgx_tls.h"
  5. #include "pal_linux.h"
  6. #include "pal_linux_defs.h"
  7. #include "pal_security.h"
  8. #include "ecall_types.h"
  9. #include "ocall_types.h"
  10. #include <generated-offsets-build.h>
  11. void dummy(void)
  12. {
  13. /* defines in sgx_arch.h */
  14. DEFINE(SGX_FLAGS_DEBUG, SGX_FLAGS_DEBUG);
  15. DEFINE(SGX_FLAGS_MODE64BIT, SGX_FLAGS_MODE64BIT);
  16. DEFINE(SGX_XFRM_LEGACY, SGX_XFRM_LEGACY);
  17. DEFINE(SGX_XFRM_AVX, SGX_XFRM_AVX);
  18. DEFINE(SGX_XFRM_MPX, SGX_XFRM_MPX);
  19. DEFINE(SGX_XFRM_AVX512, SGX_XFRM_AVX512);
  20. DEFINE(SGX_MISCSELECT_EXINFO, SGX_MISCSELECT_EXINFO);
  21. /* sgx_arch_key_t */
  22. DEFINE(SGX_ARCH_KEY_SIZE, sizeof(sgx_arch_key_t));
  23. /* sgx_arch_hash_t */
  24. DEFINE(SGX_ARCH_HASH_SIZE, sizeof(sgx_arch_hash_t));
  25. /* sgx_arch_gpr_t */
  26. OFFSET_T(SGX_GPR_RAX, sgx_arch_gpr_t, rax);
  27. OFFSET_T(SGX_GPR_RCX, sgx_arch_gpr_t, rcx);
  28. OFFSET_T(SGX_GPR_RDX, sgx_arch_gpr_t, rdx);
  29. OFFSET_T(SGX_GPR_RBX, sgx_arch_gpr_t, rbx);
  30. OFFSET_T(SGX_GPR_RSP, sgx_arch_gpr_t, rsp);
  31. OFFSET_T(SGX_GPR_RBP, sgx_arch_gpr_t, rbp);
  32. OFFSET_T(SGX_GPR_RSI, sgx_arch_gpr_t, rsi);
  33. OFFSET_T(SGX_GPR_RDI, sgx_arch_gpr_t, rdi);
  34. OFFSET_T(SGX_GPR_R8, sgx_arch_gpr_t, r8);
  35. OFFSET_T(SGX_GPR_R9, sgx_arch_gpr_t, r9);
  36. OFFSET_T(SGX_GPR_R10, sgx_arch_gpr_t, r10);
  37. OFFSET_T(SGX_GPR_R11, sgx_arch_gpr_t, r11);
  38. OFFSET_T(SGX_GPR_R12, sgx_arch_gpr_t, r12);
  39. OFFSET_T(SGX_GPR_R13, sgx_arch_gpr_t, r13);
  40. OFFSET_T(SGX_GPR_R14, sgx_arch_gpr_t, r14);
  41. OFFSET_T(SGX_GPR_R15, sgx_arch_gpr_t, r15);
  42. OFFSET_T(SGX_GPR_RFLAGS, sgx_arch_gpr_t, rflags);
  43. OFFSET_T(SGX_GPR_RIP, sgx_arch_gpr_t, rip);
  44. OFFSET_T(SGX_GPR_EXITINFO, sgx_arch_gpr_t, exitinfo);
  45. DEFINE(SGX_GPR_SIZE, sizeof(sgx_arch_gpr_t));
  46. /* sgx_context_t */
  47. OFFSET_T(SGX_CONTEXT_RAX, sgx_context_t, rax);
  48. OFFSET_T(SGX_CONTEXT_RCX, sgx_context_t, rcx);
  49. OFFSET_T(SGX_CONTEXT_RDX, sgx_context_t, rdx);
  50. OFFSET_T(SGX_CONTEXT_RBX, sgx_context_t, rbx);
  51. OFFSET_T(SGX_CONTEXT_RSP, sgx_context_t, rsp);
  52. OFFSET_T(SGX_CONTEXT_RBP, sgx_context_t, rbp);
  53. OFFSET_T(SGX_CONTEXT_RSI, sgx_context_t, rsi);
  54. OFFSET_T(SGX_CONTEXT_RDI, sgx_context_t, rdi);
  55. OFFSET_T(SGX_CONTEXT_R8, sgx_context_t, r8);
  56. OFFSET_T(SGX_CONTEXT_R9, sgx_context_t, r9);
  57. OFFSET_T(SGX_CONTEXT_R10, sgx_context_t, r10);
  58. OFFSET_T(SGX_CONTEXT_R11, sgx_context_t, r11);
  59. OFFSET_T(SGX_CONTEXT_R12, sgx_context_t, r12);
  60. OFFSET_T(SGX_CONTEXT_R13, sgx_context_t, r13);
  61. OFFSET_T(SGX_CONTEXT_R14, sgx_context_t, r14);
  62. OFFSET_T(SGX_CONTEXT_R15, sgx_context_t, r15);
  63. OFFSET_T(SGX_CONTEXT_RFLAGS, sgx_context_t, rflags);
  64. OFFSET_T(SGX_CONTEXT_RIP, sgx_context_t, rip);
  65. DEFINE(SGX_CONTEXT_SIZE, sizeof(sgx_context_t));
  66. /* struct enclave_tls */
  67. OFFSET(SGX_COMMON_SELF, enclave_tls, common.self);
  68. OFFSET(SGX_ENCLAVE_SIZE, enclave_tls, enclave_size);
  69. OFFSET(SGX_TCS_OFFSET, enclave_tls, tcs_offset);
  70. OFFSET(SGX_INITIAL_STACK_OFFSET, enclave_tls, initial_stack_offset);
  71. OFFSET(SGX_ECALL_RETURN_ADDR, enclave_tls, ecall_return_addr);
  72. OFFSET(SGX_SSA, enclave_tls, ssa);
  73. OFFSET(SGX_GPR, enclave_tls, gpr);
  74. OFFSET(SGX_EXIT_TARGET, enclave_tls, exit_target);
  75. OFFSET(SGX_FSBASE, enclave_tls, fsbase);
  76. OFFSET(SGX_STACK, enclave_tls, stack);
  77. OFFSET(SGX_USTACK_TOP, enclave_tls, ustack_top);
  78. OFFSET(SGX_USTACK, enclave_tls, ustack);
  79. OFFSET(SGX_THREAD, enclave_tls, thread);
  80. OFFSET(SGX_OCALL_PREPARED, enclave_tls, ocall_prepared);
  81. OFFSET(SGX_THREAD_STARTED, enclave_tls, thread_started);
  82. OFFSET(SGX_READY_FOR_EXCEPTIONS, enclave_tls, ready_for_exceptions);
  83. OFFSET(SGX_MANIFEST_SIZE, enclave_tls, manifest_size);
  84. OFFSET(SGX_HEAP_MIN, enclave_tls, heap_min);
  85. OFFSET(SGX_HEAP_MAX, enclave_tls, heap_max);
  86. OFFSET(SGX_EXEC_ADDR, enclave_tls, exec_addr);
  87. OFFSET(SGX_EXEC_SIZE, enclave_tls, exec_size);
  88. /* sgx_arch_tcs_t */
  89. OFFSET_T(TCS_OSSA, sgx_arch_tcs_t, ossa);
  90. OFFSET_T(TCS_NSSA, sgx_arch_tcs_t, nssa);
  91. OFFSET_T(TCS_OENTRY, sgx_arch_tcs_t, oentry);
  92. OFFSET_T(TCS_OGSBASGX, sgx_arch_tcs_t, ogsbasgx);
  93. OFFSET_T(TCS_FSLIMIT, sgx_arch_tcs_t, fslimit);
  94. OFFSET_T(TCS_GSLIMIT, sgx_arch_tcs_t, gslimit);
  95. DEFINE(TCS_SIZE, sizeof(sgx_arch_tcs_t));
  96. /* sgx_arch_attributes_t */
  97. OFFSET_T(SGX_ARCH_ATTRIBUTES_XFRM, sgx_arch_attributes_t, xfrm);
  98. /* sgx_arch_sigstruct_t */
  99. OFFSET_T(SGX_ARCH_SIGSTRUCT_HEADER, sgx_arch_sigstruct_t, header);
  100. OFFSET_T(SGX_ARCH_SIGSTRUCT_VENDOR, sgx_arch_sigstruct_t, vendor);
  101. OFFSET_T(SGX_ARCH_SIGSTRUCT_DATE, sgx_arch_sigstruct_t, date);
  102. OFFSET_T(SGX_ARCH_SIGSTRUCT_HEADER2, sgx_arch_sigstruct_t, header2);
  103. OFFSET_T(SGX_ARCH_SIGSTRUCT_SWDEFINED, sgx_arch_sigstruct_t, swdefined);
  104. OFFSET_T(SGX_ARCH_SIGSTRUCT_MODULUS, sgx_arch_sigstruct_t, modulus);
  105. OFFSET_T(SGX_ARCH_SIGSTRUCT_EXPONENT, sgx_arch_sigstruct_t, exponent);
  106. OFFSET_T(SGX_ARCH_SIGSTRUCT_SIGNATURE, sgx_arch_sigstruct_t, signature);
  107. OFFSET_T(SGX_ARCH_SIGSTRUCT_MISCSELECT, sgx_arch_sigstruct_t, miscselect);
  108. OFFSET_T(SGX_ARCH_SIGSTRUCT_MISCSELECT_MASK, sgx_arch_sigstruct_t, miscselect_mask);
  109. OFFSET_T(SGX_ARCH_SIGSTRUCT_ATTRIBUTES, sgx_arch_sigstruct_t, attributes);
  110. OFFSET_T(SGX_ARCH_SIGSTRUCT_ATTRIBUTES_MASK, sgx_arch_sigstruct_t, attribute_mask);
  111. OFFSET_T(SGX_ARCH_SIGSTRUCT_ENCLAVE_HASH, sgx_arch_sigstruct_t, enclave_hash);
  112. OFFSET_T(SGX_ARCH_SIGSTRUCT_ISVPRODID, sgx_arch_sigstruct_t, isvprodid);
  113. OFFSET_T(SGX_ARCH_SIGSTRUCT_ISVSVN, sgx_arch_sigstruct_t, isvsvn);
  114. OFFSET_T(SGX_ARCH_SIGSTRUCT_Q1, sgx_arch_sigstruct_t, q1);
  115. OFFSET_T(SGX_ARCH_SIGSTRUCT_Q2, sgx_arch_sigstruct_t, q2);
  116. DEFINE(SGX_ARCH_SIGSTRUCT_SIZE, sizeof(sgx_arch_sigstruct_t));
  117. /* struct pal_sec */
  118. OFFSET(PAL_SEC_ENCLAVE_ATTRIBUTES, pal_sec, enclave_attributes);
  119. /* pal_linux_def.h */
  120. DEFINE(ENCLAVE_HIGH_ADDRESS, ENCLAVE_HIGH_ADDRESS);
  121. DEFINE(SSAFRAMENUM, SSAFRAMENUM);
  122. DEFINE(MEMORY_GAP, MEMORY_GAP);
  123. DEFINE(ENCLAVE_STACK_SIZE, ENCLAVE_STACK_SIZE);
  124. DEFINE(DEFAULT_HEAP_MIN, DEFAULT_HEAP_MIN);
  125. /* pal_linux.h */
  126. DEFINE(PAGESIZE, PRESET_PAGESIZE);
  127. /* errno */
  128. DEFINE(EINTR, EINTR);
  129. /* Ecall numbers */
  130. DEFINE(ECALL_ENCLAVE_START, ECALL_ENCLAVE_START);
  131. DEFINE(ECALL_THREAD_START, ECALL_THREAD_START);
  132. DEFINE(ECALL_THREAD_RESET, ECALL_THREAD_RESET);
  133. /* Ocall Index */
  134. DEFINE(OCALL_EXIT, OCALL_EXIT);
  135. }