/* SPDX-License-Identifier: GPL-2.0
*
* Copyright (C) 2009 Matt Fleming <matt@console-pimps.org>
*/
#ifndef __ASM_SH_DWARF_H
#define __ASM_SH_DWARF_H
#ifdef CONFIG_DWARF_UNWINDER
/*
* DWARF expression operations
*/
#define DW_OP_addr 0 x03
#define DW_OP_deref 0 x06
#define DW_OP_const1u 0 x08
#define DW_OP_const1s 0 x09
#define DW_OP_const2u 0 x0a
#define DW_OP_const2s 0 x0b
#define DW_OP_const4u 0 x0c
#define DW_OP_const4s 0 x0d
#define DW_OP_const8u 0 x0e
#define DW_OP_const8s 0 x0f
#define DW_OP_constu 0 x10
#define DW_OP_consts 0 x11
#define DW_OP_dup 0 x12
#define DW_OP_drop 0 x13
#define DW_OP_over 0 x14
#define DW_OP_pick 0 x15
#define DW_OP_swap 0 x16
#define DW_OP_rot 0 x17
#define DW_OP_xderef 0 x18
#define DW_OP_abs 0 x19
#define DW_OP_and 0 x1a
#define DW_OP_div 0 x1b
#define DW_OP_minus 0 x1c
#define DW_OP_mod 0 x1d
#define DW_OP_mul 0 x1e
#define DW_OP_neg 0 x1f
#define DW_OP_not 0 x20
#define DW_OP_or 0 x21
#define DW_OP_plus 0 x22
#define DW_OP_plus_uconst 0 x23
#define DW_OP_shl 0 x24
#define DW_OP_shr 0 x25
#define DW_OP_shra 0 x26
#define DW_OP_xor 0 x27
#define DW_OP_skip 0 x2f
#define DW_OP_bra 0 x28
#define DW_OP_eq 0 x29
#define DW_OP_ge 0 x2a
#define DW_OP_gt 0 x2b
#define DW_OP_le 0 x2c
#define DW_OP_lt 0 x2d
#define DW_OP_ne 0 x2e
#define DW_OP_lit0 0 x30
#define DW_OP_lit1 0 x31
#define DW_OP_lit2 0 x32
#define DW_OP_lit3 0 x33
#define DW_OP_lit4 0 x34
#define DW_OP_lit5 0 x35
#define DW_OP_lit6 0 x36
#define DW_OP_lit7 0 x37
#define DW_OP_lit8 0 x38
#define DW_OP_lit9 0 x39
#define DW_OP_lit10 0 x3a
#define DW_OP_lit11 0 x3b
#define DW_OP_lit12 0 x3c
#define DW_OP_lit13 0 x3d
#define DW_OP_lit14 0 x3e
#define DW_OP_lit15 0 x3f
#define DW_OP_lit16 0 x40
#define DW_OP_lit17 0 x41
#define DW_OP_lit18 0 x42
#define DW_OP_lit19 0 x43
#define DW_OP_lit20 0 x44
#define DW_OP_lit21 0 x45
#define DW_OP_lit22 0 x46
#define DW_OP_lit23 0 x47
#define DW_OP_lit24 0 x48
#define DW_OP_lit25 0 x49
#define DW_OP_lit26 0 x4a
#define DW_OP_lit27 0 x4b
#define DW_OP_lit28 0 x4c
#define DW_OP_lit29 0 x4d
#define DW_OP_lit30 0 x4e
#define DW_OP_lit31 0 x4f
#define DW_OP_reg0 0 x50
#define DW_OP_reg1 0 x51
#define DW_OP_reg2 0 x52
#define DW_OP_reg3 0 x53
#define DW_OP_reg4 0 x54
#define DW_OP_reg5 0 x55
#define DW_OP_reg6 0 x56
#define DW_OP_reg7 0 x57
#define DW_OP_reg8 0 x58
#define DW_OP_reg9 0 x59
#define DW_OP_reg10 0 x5a
#define DW_OP_reg11 0 x5b
#define DW_OP_reg12 0 x5c
#define DW_OP_reg13 0 x5d
#define DW_OP_reg14 0 x5e
#define DW_OP_reg15 0 x5f
#define DW_OP_reg16 0 x60
#define DW_OP_reg17 0 x61
#define DW_OP_reg18 0 x62
#define DW_OP_reg19 0 x63
#define DW_OP_reg20 0 x64
#define DW_OP_reg21 0 x65
#define DW_OP_reg22 0 x66
#define DW_OP_reg23 0 x67
#define DW_OP_reg24 0 x68
#define DW_OP_reg25 0 x69
#define DW_OP_reg26 0 x6a
#define DW_OP_reg27 0 x6b
#define DW_OP_reg28 0 x6c
#define DW_OP_reg29 0 x6d
#define DW_OP_reg30 0 x6e
#define DW_OP_reg31 0 x6f
#define DW_OP_breg0 0 x70
#define DW_OP_breg1 0 x71
#define DW_OP_breg2 0 x72
#define DW_OP_breg3 0 x73
#define DW_OP_breg4 0 x74
#define DW_OP_breg5 0 x75
#define DW_OP_breg6 0 x76
#define DW_OP_breg7 0 x77
#define DW_OP_breg8 0 x78
#define DW_OP_breg9 0 x79
#define DW_OP_breg10 0 x7a
#define DW_OP_breg11 0 x7b
#define DW_OP_breg12 0 x7c
#define DW_OP_breg13 0 x7d
#define DW_OP_breg14 0 x7e
#define DW_OP_breg15 0 x7f
#define DW_OP_breg16 0 x80
#define DW_OP_breg17 0 x81
#define DW_OP_breg18 0 x82
#define DW_OP_breg19 0 x83
#define DW_OP_breg20 0 x84
#define DW_OP_breg21 0 x85
#define DW_OP_breg22 0 x86
#define DW_OP_breg23 0 x87
#define DW_OP_breg24 0 x88
#define DW_OP_breg25 0 x89
#define DW_OP_breg26 0 x8a
#define DW_OP_breg27 0 x8b
#define DW_OP_breg28 0 x8c
#define DW_OP_breg29 0 x8d
#define DW_OP_breg30 0 x8e
#define DW_OP_breg31 0 x8f
#define DW_OP_regx 0 x90
#define DW_OP_fbreg 0 x91
#define DW_OP_bregx 0 x92
#define DW_OP_piece 0 x93
#define DW_OP_deref_size 0 x94
#define DW_OP_xderef_size 0 x95
#define DW_OP_nop 0 x96
#define DW_OP_push_object_address 0 x97
#define DW_OP_call2 0 x98
#define DW_OP_call4 0 x99
#define DW_OP_call_ref 0 x9a
#define DW_OP_form_tls_address 0 x9b
#define DW_OP_call_frame_cfa 0 x9c
#define DW_OP_bit_piece 0 x9d
#define DW_OP_lo_user 0 xe0
#define DW_OP_hi_user 0 xff
/*
* Addresses used in FDE entries in the .eh_frame section may be encoded
* using one of the following encodings.
*/
#define DW_EH_PE_absptr 0 x00
#define DW_EH_PE_omit 0 xff
#define DW_EH_PE_uleb128 0 x01
#define DW_EH_PE_udata2 0 x02
#define DW_EH_PE_udata4 0 x03
#define DW_EH_PE_udata8 0 x04
#define DW_EH_PE_sleb128 0 x09
#define DW_EH_PE_sdata2 0 x0a
#define DW_EH_PE_sdata4 0 x0b
#define DW_EH_PE_sdata8 0 x0c
#define DW_EH_PE_signed 0 x09
#define DW_EH_PE_pcrel 0 x10
/*
* The architecture-specific register number that contains the return
* address in the .debug_frame table.
*/
#define DWARF_ARCH_RA_REG 17
#ifndef __ASSEMBLER__
#include <linux/compiler.h>
#include <linux/bug.h>
#include <linux/list.h>
#include <linux/module.h>
/*
* Read either the frame pointer (r14) or the stack pointer (r15).
* NOTE: this MUST be inlined.
*/
static __always_inline unsigned long dwarf_read_arch_reg(unsigned int reg)
{
unsigned long value = 0 ;
switch (reg) {
case 14 :
__asm__ __volatile__("mov r14, %0\n" : "=r" (value));
break ;
case 15 :
__asm__ __volatile__("mov r15, %0\n" : "=r" (value));
break ;
default :
BUG();
}
return value;
}
/**
* dwarf_cie - Common Information Entry
*/
struct dwarf_cie {
unsigned long length;
unsigned long cie_id;
unsigned char version;
const char *augmentation;
unsigned int code_alignment_factor;
int data_alignment_factor;
/* Which column in the rule table represents return addr of func. */
unsigned int return_address_reg;
unsigned char *initial_instructions;
unsigned char *instructions_end;
unsigned char encoding;
unsigned long cie_pointer;
unsigned long flags;
#define DWARF_CIE_Z_AUGMENTATION (1 << 0 )
/* linked-list entry if this CIE is from a module */
struct list_head link;
struct rb_node node;
};
/**
* dwarf_fde - Frame Description Entry
*/
struct dwarf_fde {
unsigned long length;
unsigned long cie_pointer;
struct dwarf_cie *cie;
unsigned long initial_location;
unsigned long address_range;
unsigned char *instructions;
unsigned char *end;
/* linked-list entry if this FDE is from a module */
struct list_head link;
struct rb_node node;
};
/**
* dwarf_frame - DWARF information for a frame in the call stack
*/
struct dwarf_frame {
struct dwarf_frame *prev, *next;
unsigned long pc;
struct list_head reg_list;
unsigned long cfa;
/* Valid when DW_FRAME_CFA_REG_OFFSET is set in flags */
unsigned int cfa_register;
unsigned int cfa_offset;
/* Valid when DW_FRAME_CFA_REG_EXP is set in flags */
unsigned char *cfa_expr;
unsigned int cfa_expr_len;
unsigned long flags;
#define DWARF_FRAME_CFA_REG_OFFSET (1 << 0 )
#define DWARF_FRAME_CFA_REG_EXP (1 << 1 )
unsigned long return_addr;
};
/**
* dwarf_reg - DWARF register
* @flags: Describes how to calculate the value of this register
*/
struct dwarf_reg {
struct list_head link;
unsigned int number;
unsigned long addr;
unsigned long flags;
#define DWARF_REG_OFFSET (1 << 0 )
#define DWARF_VAL_OFFSET (1 << 1 )
#define DWARF_UNDEFINED (1 << 2 )
};
/*
* Call Frame instruction opcodes.
*/
#define DW_CFA_advance_loc 0 x40
#define DW_CFA_offset 0 x80
#define DW_CFA_restore 0 xc0
#define DW_CFA_nop 0 x00
#define DW_CFA_set_loc 0 x01
#define DW_CFA_advance_loc1 0 x02
#define DW_CFA_advance_loc2 0 x03
#define DW_CFA_advance_loc4 0 x04
#define DW_CFA_offset_extended 0 x05
#define DW_CFA_restore_extended 0 x06
#define DW_CFA_undefined 0 x07
#define DW_CFA_same_value 0 x08
#define DW_CFA_register 0 x09
#define DW_CFA_remember_state 0 x0a
#define DW_CFA_restore_state 0 x0b
#define DW_CFA_def_cfa 0 x0c
#define DW_CFA_def_cfa_register 0 x0d
#define DW_CFA_def_cfa_offset 0 x0e
#define DW_CFA_def_cfa_expression 0 x0f
#define DW_CFA_expression 0 x10
#define DW_CFA_offset_extended_sf 0 x11
#define DW_CFA_def_cfa_sf 0 x12
#define DW_CFA_def_cfa_offset_sf 0 x13
#define DW_CFA_val_offset 0 x14
#define DW_CFA_val_offset_sf 0 x15
#define DW_CFA_val_expression 0 x16
#define DW_CFA_lo_user 0 x1c
#define DW_CFA_hi_user 0 x3f
/* GNU extension opcodes */
#define DW_CFA_GNU_args_size 0 x2e
#define DW_CFA_GNU_negative_offset_extended 0 x2f
/*
* Some call frame instructions encode their operands in the opcode. We
* need some helper functions to extract both the opcode and operands
* from an instruction.
*/
static inline unsigned int DW_CFA_opcode(unsigned long insn)
{
return (insn & 0 xc0);
}
static inline unsigned int DW_CFA_operand(unsigned long insn)
{
return (insn & 0 x3f);
}
#define DW_EH_FRAME_CIE 0 /* .eh_frame CIE IDs are 0 */
#define DW_CIE_ID 0 xffffffff
#define DW64_CIE_ID 0 xffffffffffffffffULL
/*
* DWARF FDE/CIE length field values.
*/
#define DW_EXT_LO 0 xfffffff0
#define DW_EXT_HI 0 xffffffff
#define DW_EXT_DWARF64 DW_EXT_HI
extern struct dwarf_frame *dwarf_unwind_stack(unsigned long ,
struct dwarf_frame *);
extern void dwarf_free_frame(struct dwarf_frame *);
extern int module_dwarf_finalize(const Elf_Ehdr *, const Elf_Shdr *,
struct module *);
extern void module_dwarf_cleanup(struct module *);
#endif /* !__ASSEMBLER__ */
#define CFI_STARTPROC .cfi_startproc
#define CFI_ENDPROC .cfi_endproc
#define CFI_DEF_CFA .cfi_def_cfa
#define CFI_REGISTER .cfi_register
#define CFI_REL_OFFSET .cfi_rel_offset
#define CFI_UNDEFINED .cfi_undefined
#else
/*
* Use the asm comment character to ignore the rest of the line.
*/
#define CFI_IGNORE !
#define CFI_STARTPROC CFI_IGNORE
#define CFI_ENDPROC CFI_IGNORE
#define CFI_DEF_CFA CFI_IGNORE
#define CFI_REGISTER CFI_IGNORE
#define CFI_REL_OFFSET CFI_IGNORE
#define CFI_UNDEFINED CFI_IGNORE
#ifndef __ASSEMBLER__
static inline void dwarf_unwinder_init(void )
{
}
#define module_dwarf_finalize(hdr, sechdrs, me) (0 )
#define module_dwarf_cleanup(mod) do { } while (0 )
#endif
#endif /* CONFIG_DWARF_UNWINDER */
#endif /* __ASM_SH_DWARF_H */
Messung V0.5 in Prozent C=93 H=88 G=90
¤ Dauer der Verarbeitung: 0.16 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland