diff options
author | Tristan Gingold <gingold@adacore.com> | 2013-01-31 09:55:40 +0000 |
---|---|---|
committer | Tristan Gingold <gingold@adacore.com> | 2013-01-31 09:55:40 +0000 |
commit | 865ece86ae752332c53cea3363b4991b078f3052 (patch) | |
tree | 9c6f96276db6f9cf878f0626e74f5b826be5dbbc | |
parent | 39d8655363c72a58ceaf23c7e18130027fd30196 (diff) | |
download | binutils-redhat-865ece86ae752332c53cea3363b4991b078f3052.tar.gz |
2013-01-31 Tristan Gingold <gingold@adacore.com>
* mach-o.c (bfd_mach_o_scan): Call bfd_mach_o_flatten_sections
earlier. Fix status checking of bfd_mach_o_scan_start_address.
(bfd_mach_o_scan_start_address): Handle LC_MAIN.
-rw-r--r-- | bfd/ChangeLog | 6 | ||||
-rw-r--r-- | bfd/mach-o.c | 17 |
2 files changed, 21 insertions, 2 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index c53af4ba48..470ecb9e22 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2013-01-31 Tristan Gingold <gingold@adacore.com> + + * mach-o.c (bfd_mach_o_scan): Call bfd_mach_o_flatten_sections + earlier. Fix status checking of bfd_mach_o_scan_start_address. + (bfd_mach_o_scan_start_address): Handle LC_MAIN. + 2013-01-31 Alan Modra <amodra@gmail.com> David S. Miller <davem@davemloft.net> diff --git a/bfd/mach-o.c b/bfd/mach-o.c index 7f4b968c9c..e3bfa58182 100644 --- a/bfd/mach-o.c +++ b/bfd/mach-o.c @@ -3979,6 +3979,18 @@ bfd_mach_o_scan_start_address (bfd *abfd) cmd = &mdata->commands[i].command.thread; break; } + else if (mdata->commands[i].type == BFD_MACH_O_LC_MAIN + && mdata->nsects > 1) + { + bfd_mach_o_main_command *main_cmd = &mdata->commands[i].command.main; + bfd_mach_o_section *text_sect = mdata->sections[0]; + if (text_sect) + { + abfd->start_address = main_cmd->entryoff + + (text_sect->addr - text_sect->offset); + return TRUE; + } + } if (cmd == NULL) return FALSE; @@ -4121,10 +4133,11 @@ bfd_mach_o_scan (bfd *abfd, } } - if (bfd_mach_o_scan_start_address (abfd) < 0) + /* Sections should be flatten before scanning start address. */ + bfd_mach_o_flatten_sections (abfd); + if (!bfd_mach_o_scan_start_address (abfd)) return FALSE; - bfd_mach_o_flatten_sections (abfd); return TRUE; } |