summaryrefslogtreecommitdiff
path: root/gas/dw2gencfi.c
diff options
context:
space:
mode:
authorThomas Schwinge <tschwinge@gnu.org>2010-03-15 15:08:01 +0000
committerThomas Schwinge <tschwinge@gnu.org>2010-03-15 15:08:01 +0000
commit7f43b972be3e8a8c0a688147556f4018d46ea531 (patch)
tree6f92362c08c61a29f4163c306fa7cd96b46ddb59 /gas/dw2gencfi.c
parent97435c0169af539c4845fe96f4031ff00b0d2cc2 (diff)
downloadbinutils-redhat-7f43b972be3e8a8c0a688147556f4018d46ea531.tar.gz
2010-03-15 Thomas Schwinge <thomas@codesourcery.com>
* dw2gencfi.c (output_cie): Make it more explicit which code paths belong to .eh_frame only.
Diffstat (limited to 'gas/dw2gencfi.c')
-rw-r--r--gas/dw2gencfi.c36
1 files changed, 19 insertions, 17 deletions
diff --git a/gas/dw2gencfi.c b/gas/dw2gencfi.c
index 93e011f457..09171da296 100644
--- a/gas/dw2gencfi.c
+++ b/gas/dw2gencfi.c
@@ -1,5 +1,5 @@
/* dw2gencfi.c - Support for generating Dwarf2 CFI information.
- Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009
+ Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010
Free Software Foundation, Inc.
Contributed by Michal Ludvig <mludvig@suse.cz>
@@ -1319,29 +1319,31 @@ output_cie (struct cie_entry *cie, bfd_boolean eh_frame, int align)
if (cie->per_encoding != DW_EH_PE_omit)
augmentation_size += 1 + encoding_size (cie->per_encoding);
out_uleb128 (augmentation_size); /* Augmentation size. */
- }
- if (cie->per_encoding != DW_EH_PE_omit)
- {
- offsetT size = encoding_size (cie->per_encoding);
- out_one (cie->per_encoding);
- exp = cie->personality;
- if ((cie->per_encoding & 0x70) == DW_EH_PE_pcrel)
+
+ if (cie->per_encoding != DW_EH_PE_omit)
{
+ offsetT size = encoding_size (cie->per_encoding);
+ out_one (cie->per_encoding);
+ exp = cie->personality;
+ if ((cie->per_encoding & 0x70) == DW_EH_PE_pcrel)
+ {
#if CFI_DIFF_EXPR_OK
- exp.X_op = O_subtract;
- exp.X_op_symbol = symbol_temp_new_now ();
- emit_expr (&exp, size);
+ exp.X_op = O_subtract;
+ exp.X_op_symbol = symbol_temp_new_now ();
+ emit_expr (&exp, size);
#elif defined (tc_cfi_emit_pcrel_expr)
- tc_cfi_emit_pcrel_expr (&exp, size);
+ tc_cfi_emit_pcrel_expr (&exp, size);
#else
- abort ();
+ abort ();
#endif
+ }
+ else
+ emit_expr (&exp, size);
}
- else
- emit_expr (&exp, size);
+
+ if (cie->lsda_encoding != DW_EH_PE_omit)
+ out_one (cie->lsda_encoding);
}
- if (cie->lsda_encoding != DW_EH_PE_omit)
- out_one (cie->lsda_encoding);
switch (DWARF2_FDE_RELOC_SIZE)
{