// Copyright 2019 The Marl Authors. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // https://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #define MARL_REG_r0 0x00 #define MARL_REG_r1 0x04 #define MARL_REG_r12 0x08 #define MARL_REG_r4 0x0c #define MARL_REG_r5 0x10 #define MARL_REG_r6 0x14 #define MARL_REG_r7 0x18 #define MARL_REG_r8 0x1c #define MARL_REG_r9 0x20 #define MARL_REG_r10 0x24 #define MARL_REG_r11 0x28 #define MARL_REG_v8 0x2c #define MARL_REG_v9 0x30 #define MARL_REG_v10 0x34 #define MARL_REG_v11 0x38 #define MARL_REG_v12 0x3c #define MARL_REG_v13 0x40 #define MARL_REG_v14 0x44 #define MARL_REG_v15 0x48 #define MARL_REG_SP 0x4c #define MARL_REG_LR 0x50 #ifndef MARL_BUILD_ASM #include // Procedure Call Standard for the ARM 64-bit Architecture // http://infocenter.arm.com/help/topic/com.arm.doc.ihi0055b/IHI0055B_aapcs64.pdf struct marl_fiber_context { // parameter registers uintptr_t r0; uintptr_t r1; // special purpose registers uintptr_t r12; // Intra-Procedure-call // callee-saved registers uintptr_t r4; uintptr_t r5; uintptr_t r6; uintptr_t r7; uintptr_t r8; uintptr_t r9; uintptr_t r10; uintptr_t r11; uintptr_t v8; uintptr_t v9; uintptr_t v10; uintptr_t v11; uintptr_t v12; uintptr_t v13; uintptr_t v14; uintptr_t v15; uintptr_t SP; // stack pointer (r13) uintptr_t LR; // link register (r14) }; #ifdef __cplusplus #include static_assert(offsetof(marl_fiber_context, r0) == MARL_REG_r0, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r1) == MARL_REG_r1, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r12) == MARL_REG_r12, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r4) == MARL_REG_r4, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r5) == MARL_REG_r5, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r6) == MARL_REG_r6, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r7) == MARL_REG_r7, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r8) == MARL_REG_r8, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r9) == MARL_REG_r9, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r10) == MARL_REG_r10, "Bad register offset"); static_assert(offsetof(marl_fiber_context, r11) == MARL_REG_r11, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v8) == MARL_REG_v8, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v9) == MARL_REG_v9, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v10) == MARL_REG_v10, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v11) == MARL_REG_v11, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v12) == MARL_REG_v12, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v13) == MARL_REG_v13, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v14) == MARL_REG_v14, "Bad register offset"); static_assert(offsetof(marl_fiber_context, v15) == MARL_REG_v15, "Bad register offset"); static_assert(offsetof(marl_fiber_context, SP) == MARL_REG_SP, "Bad register offset"); static_assert(offsetof(marl_fiber_context, LR) == MARL_REG_LR, "Bad register offset"); #endif // __cplusplus #endif // MARL_BUILD_ASM