summaryrefslogtreecommitdiff
path: root/gas
diff options
context:
space:
mode:
authoriains <iains>2012-02-10 13:12:54 +0000
committeriains <iains>2012-02-10 13:12:54 +0000
commit8b86bc14e0fcdd2ced8dba1224fc48b93223e6c0 (patch)
treefc79f0563c5187b17b20d4fa8bb75021730c9cad /gas
parent90d8b96b9d446f52ba3e0b4abb97f24b28c122c6 (diff)
downloadbinutils-redhat-8b86bc14e0fcdd2ced8dba1224fc48b93223e6c0.tar.gz
gas:
* config/obj-macho.c (obj_mach_o_make_or_get_sect): Always fill in stub size when provided. (obj_mach_o_section): Flag that stub-size has been provided.
Diffstat (limited to 'gas')
-rw-r--r--gas/ChangeLog6
-rw-r--r--gas/config/obj-macho.c7
2 files changed, 12 insertions, 1 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index dc5da04131..757db70e76 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,9 @@
+2012-02-10 Iain Sandoe <idsandoe@googlemail.com>
+
+ * config/obj-macho.c (obj_mach_o_make_or_get_sect): Always fill in
+ stub size when provided. (obj_mach_o_section): Flag that stub-size
+ has been provided.
+
2012-02-08 H.J. Lu <hongjiu.lu@intel.com>
* config/tc-i386.c (HLE_PREFIX): New.
diff --git a/gas/config/obj-macho.c b/gas/config/obj-macho.c
index f4706ab03e..c32398ffdd 100644
--- a/gas/config/obj-macho.c
+++ b/gas/config/obj-macho.c
@@ -161,6 +161,7 @@ obj_mach_o_get_section_names (char *seg, char *sec,
#define SECT_TYPE_SPECIFIED 0x0001
#define SECT_ATTR_SPECIFIED 0x0002
#define SECT_ALGN_SPECIFIED 0x0004
+#define SECT_STUB_SPECIFIED 0x0008
static segT
obj_mach_o_make_or_get_sect (char * segname, char * sectname,
@@ -250,7 +251,6 @@ obj_mach_o_make_or_get_sect (char * segname, char * sectname,
msect->align = secalign;
msect->flags = sectype | secattr;
- msect->reserved2 = stub_size;
if (sectype == BFD_MACH_O_S_ZEROFILL
|| sectype == BFD_MACH_O_S_GB_ZEROFILL)
@@ -263,6 +263,10 @@ obj_mach_o_make_or_get_sect (char * segname, char * sectname,
as_warn (_("Ignoring changed section attributes for %s"), name);
}
+ if (specified_mask & SECT_STUB_SPECIFIED)
+ /* At present, the stub size is not supplied from the BFD tables. */
+ msect->reserved2 = stub_size;
+
return sec;
}
@@ -396,6 +400,7 @@ obj_mach_o_section (int ignore ATTRIBUTE_UNUSED)
input_line_pointer++;
sizeof_stub = get_absolute_expression ();
+ specified_mask |= SECT_STUB_SPECIFIED;
}
else if ((specified_mask & SECT_ATTR_SPECIFIED)
&& sectype == BFD_MACH_O_S_SYMBOL_STUBS)