From: Roland McGrath Date: Fri, 16 Aug 2013 18:12:30 +0000 (+0000) Subject: gold/ X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5d3ad97830372c746a00f1880f3d2d34e2a59bcf;p=thirdparty%2Fbinutils-gdb.git gold/ * i386.cc (Target_i386_nacl::do_code_fill): New virtual function. * x86_64.cc (Target_x86_64_nacl::do_code_fill): New virtual function. --- diff --git a/gold/ChangeLog b/gold/ChangeLog index 0c95dd0683f..69b76456d61 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,3 +1,8 @@ +2013-08-16 Roland McGrath + + * i386.cc (Target_i386_nacl::do_code_fill): New virtual function. + * x86_64.cc (Target_x86_64_nacl::do_code_fill): New virtual function. + 2013-07-19 Roland McGrath * options.h (General_options): Add -Trodata-segment option. diff --git a/gold/i386.cc b/gold/i386.cc index 3f0a0390861..47f2de4ea8f 100644 --- a/gold/i386.cc +++ b/gold/i386.cc @@ -3930,6 +3930,9 @@ class Target_i386_nacl : public Target_i386 return new Output_data_plt_i386_nacl_exec(layout, got_plt, got_irelative); } + virtual std::string + do_code_fill(section_size_type length) const; + private: static const Target::Target_info i386_nacl_info; }; @@ -4129,6 +4132,15 @@ Output_data_plt_i386_nacl::plt_eh_frame_fde[plt_eh_frame_fde_size] = elfcpp::DW_CFA_nop }; +// Return a string used to fill a code section with nops. +// For NaCl, long NOPs are only valid if they do not cross +// bundle alignment boundaries, so keep it simple with one-byte NOPs. +std::string +Target_i386_nacl::do_code_fill(section_size_type length) const +{ + return std::string(length, static_cast(0x90)); +} + // The selector for i386-nacl object files. class Target_selector_i386_nacl diff --git a/gold/x86_64.cc b/gold/x86_64.cc index 8ddf4f2d9bd..592b587e25e 100644 --- a/gold/x86_64.cc +++ b/gold/x86_64.cc @@ -4560,6 +4560,9 @@ class Target_x86_64_nacl : public Target_x86_64 plt_count); } + virtual std::string + do_code_fill(section_size_type length) const; + private: static const Target::Target_info x86_64_nacl_info; }; @@ -4784,6 +4787,16 @@ Output_data_plt_x86_64_nacl::plt_eh_frame_fde[plt_eh_frame_fde_size] = elfcpp::DW_CFA_nop }; +// Return a string used to fill a code section with nops. +// For NaCl, long NOPs are only valid if they do not cross +// bundle alignment boundaries, so keep it simple with one-byte NOPs. +template +std::string +Target_x86_64_nacl::do_code_fill(section_size_type length) const +{ + return std::string(length, static_cast(0x90)); +} + // The selector for x86_64-nacl object files. template