Blame backends/arm_cfi.c

Packit 032894
/* arm ABI-specified defaults for DWARF CFI.
Packit 032894
   Copyright (C) 2013 Red Hat, Inc.
Packit 032894
   This file is part of elfutils.
Packit 032894
Packit 032894
   This file is free software; you can redistribute it and/or modify
Packit 032894
   it under the terms of either
Packit 032894
Packit 032894
     * the GNU Lesser General Public License as published by the Free
Packit 032894
       Software Foundation; either version 3 of the License, or (at
Packit 032894
       your option) any later version
Packit 032894
Packit 032894
   or
Packit 032894
Packit 032894
     * the GNU General Public License as published by the Free
Packit 032894
       Software Foundation; either version 2 of the License, or (at
Packit 032894
       your option) any later version
Packit 032894
Packit 032894
   or both in parallel, as here.
Packit 032894
Packit 032894
   elfutils is distributed in the hope that it will be useful, but
Packit 032894
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 032894
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 032894
   General Public License for more details.
Packit 032894
Packit 032894
   You should have received copies of the GNU General Public License and
Packit 032894
   the GNU Lesser General Public License along with this program.  If
Packit 032894
   not, see <http://www.gnu.org/licenses/>.  */
Packit 032894
Packit 032894
#ifdef HAVE_CONFIG_H
Packit 032894
# include <config.h>
Packit 032894
#endif
Packit 032894
Packit 032894
#include <dwarf.h>
Packit 032894
Packit 032894
#define BACKEND arm_
Packit 032894
#include "libebl_CPU.h"
Packit 032894
Packit 032894
Packit 032894
/* ABI-specified state of DWARF CFI based on:
Packit 032894
Packit 032894
   "DWARF for the ARM Architecture ABI r2.09"
Packit 032894
http://infocenter.arm.com/help/topic/com.arm.doc.ihi0040b/IHI0040B_aadwarf.pdf
Packit 032894
Packit 032894
   "Procedure Call Standard for the ARM Architecture ABI r2.09"
Packit 032894
http://infocenter.arm.com/help/topic/com.arm.doc.ihi0042e/IHI0042E_aapcs.pdf
Packit 032894
*/
Packit 032894
Packit 032894
int
Packit 032894
arm_abi_cfi (Ebl *ebl __attribute__ ((unused)), Dwarf_CIE *abi_info)
Packit 032894
{
Packit 032894
  static const uint8_t abi_cfi[] =
Packit 032894
    {
Packit 032894
      /* The initial Canonical Frame Address is the value of the
Packit 032894
         Stack Pointer (r13) as setup in the previous frame. */
Packit 032894
      DW_CFA_def_cfa, ULEB128_7 (13), ULEB128_7 (0),
Packit 032894
Packit 032894
      /* The Stack Pointer (r13) is restored from CFA address by default.  */
Packit 032894
      DW_CFA_val_offset, ULEB128_7 (13), ULEB128_7 (0),
Packit 032894
Packit 032894
#define SV(n) DW_CFA_same_value, ULEB128_7 (n)
Packit 032894
      /* Callee-saved regs r4-r8, r10, r11.  */
Packit 032894
      SV (4), SV (5), SV (6), SV (7), SV (8), SV (10), SV (11),
Packit 032894
Packit 032894
      /* The link register contains the return address setup by caller.  */
Packit 032894
      SV (14),
Packit 032894
      DW_CFA_register, ULEB128_7 (15), ULEB128_7 (14), /* pc = lr */
Packit 032894
#undef SV
Packit 032894
Packit 032894
      /* VFP S16-S31/D8-D15/Q4-Q7 are callee saved.
Packit 032894
         And uleb128 encoded with two bytes.  */
Packit 032894
#define ULEB128_8_2(x) ((x & 0x7f) | 0x80), 0x02
Packit 032894
#define SV(n) DW_CFA_same_value, ULEB128_8_2 (n)
Packit 032894
      SV (264), SV (265), SV (266), SV (267),
Packit 032894
      SV (268), SV (269), SV (270), SV (271),
Packit 032894
Packit 032894
      /* XXX Note: registers intentionally unused by the program,
Packit 032894
	 for example as a consequence of the procedure call standard
Packit 032894
	 should be initialized as if by DW_CFA_same_value.  */
Packit 032894
    };
Packit 032894
#undef ULEB128_8_2
Packit 032894
#undef SV
Packit 032894
Packit 032894
  abi_info->initial_instructions = abi_cfi;
Packit 032894
  abi_info->initial_instructions_end = &abi_cfi[sizeof abi_cfi];
Packit 032894
  abi_info->data_alignment_factor = 4;
Packit 032894
Packit 032894
  abi_info->return_address_register = 15; /* pc.  */
Packit 032894
Packit 032894
  return 0;
Packit 032894
}