Branch data Line data Source code
1 : : /* C-SKY ABI-specified defaults for DWARF CFI. 2 : : Copyright (C) 2019 Hangzhou C-SKY Microsystems co.,ltd. 3 : : This file is part of elfutils. 4 : : 5 : : This file is free software; you can redistribute it and/or modify 6 : : it under the terms of either 7 : : 8 : : * the GNU Lesser General Public License as published by the Free 9 : : Software Foundation; either version 3 of the License, or (at 10 : : your option) any later version 11 : : 12 : : or 13 : : 14 : : * the GNU General Public License as published by the Free 15 : : Software Foundation; either version 2 of the License, or (at 16 : : your option) any later version 17 : : 18 : : or both in parallel, as here. 19 : : 20 : : elfutils is distributed in the hope that it will be useful, but 21 : : WITHOUT ANY WARRANTY; without even the implied warranty of 22 : : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 23 : : General Public License for more details. 24 : : 25 : : You should have received copies of the GNU General Public License and 26 : : the GNU Lesser General Public License along with this program. If 27 : : not, see <http://www.gnu.org/licenses/>. */ 28 : : 29 : : #ifdef HAVE_CONFIG_H 30 : : # include <config.h> 31 : : #endif 32 : : 33 : : #include <dwarf.h> 34 : : 35 : : #define BACKEND csky_ 36 : : #include "libebl_CPU.h" 37 : : 38 : : 39 : : int 40 : 2 : csky_abi_cfi (Ebl *ebl __attribute__ ((unused)), Dwarf_CIE *abi_info) 41 : : { 42 : 2 : static const uint8_t abi_cfi[] = 43 : : { 44 : : DW_CFA_def_cfa, ULEB128_7 (14), ULEB128_7 (0), 45 : : DW_CFA_val_offset, ULEB128_7 (14), ULEB128_7 (0), 46 : : 47 : : #define SV(n) DW_CFA_same_value, ULEB128_7 (n) 48 : : SV(4), SV (5), SV (6), SV (7), SV (8), SV (9), 49 : : SV(10), SV (11), SV (15), SV (16), SV (17) 50 : : #undef SV 51 : : }; 52 : : 53 : 2 : abi_info->initial_instructions = abi_cfi; 54 : 2 : abi_info->initial_instructions_end = &abi_cfi[sizeof abi_cfi]; 55 : 2 : abi_info->data_alignment_factor = -4; 56 : : 57 : 2 : abi_info->return_address_register = 15; /* lr. */ 58 : : 59 : 2 : return 0; 60 : : }