1 /* 2 * Copyright (C) 2014 The Android Open Source Project 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * * Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * * Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in 12 * the documentation and/or other materials provided with the 13 * distribution. 14 * 15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * SUCH DAMAGE. 27 */ 28 29 #pragma once 30 31 #include <stdint.h> 32 #include <sys/cdefs.h> 33 34 namespace unwindstack { 35 36 typedef uint64_t __riscv_mc_gp_state[32]; // unsigned long 37 38 struct __riscv_mc_f_ext_state { 39 uint32_t __f[32]; 40 uint32_t __fcsr; 41 }; 42 43 struct __riscv_mc_d_ext_state { 44 uint64_t __f[32]; 45 uint32_t __fcsr; 46 }; 47 48 struct __riscv_mc_q_ext_state { 49 uint64_t __f[64] __attribute__((__aligned__(16))); 50 uint32_t __fcsr; 51 uint32_t __reserved[3]; 52 }; 53 54 union __riscv_mc_fp_state { 55 struct __riscv_mc_f_ext_state __f; 56 struct __riscv_mc_d_ext_state __d; 57 struct __riscv_mc_q_ext_state __q; 58 }; 59 60 struct __riscv_stack_t { 61 uint64_t ss_sp; 62 int32_t ss_flags; 63 uint64_t ss_size; 64 }; 65 66 struct riscv64_sigset_t { 67 uint64_t sig; // unsigned long 68 }; 69 70 struct riscv64_mcontext_t { 71 __riscv_mc_gp_state __gregs; 72 union __riscv_mc_fp_state __fpregs; 73 }; 74 75 struct riscv64_ucontext_t { 76 uint64_t uc_flags; // unsigned long 77 struct riscv64_ucontext_t* uc_link; 78 __riscv_stack_t uc_stack; 79 riscv64_sigset_t uc_sigmask; 80 /* The kernel adds extra padding here to allow sigset_t to grow. */ 81 int8_t __padding[128 - sizeof(riscv64_sigset_t)]; // char 82 riscv64_mcontext_t uc_mcontext; 83 }; 84 85 } // namespace unwindstack 86