| // 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 <stdint.h> |
| |
| // 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 <cstddef> |
| 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 |