diff options
author | Ian Lance Taylor <iant@google.com> | 2006-11-03 18:38:43 +0000 |
---|---|---|
committer | Ian Lance Taylor <iant@google.com> | 2006-11-03 18:38:43 +0000 |
commit | 593f47df457d5e059f49b1ce62d1b51d4a7cc3e4 (patch) | |
tree | 1f5b2070678b01fd88b1818246356679bd078d59 /gold/symtab.cc | |
parent | ead1e4244a55707685d105c662a9a1faf5d122fe (diff) | |
download | gdb-593f47df457d5e059f49b1ce62d1b51d4a7cc3e4.zip gdb-593f47df457d5e059f49b1ce62d1b51d4a7cc3e4.tar.gz gdb-593f47df457d5e059f49b1ce62d1b51d4a7cc3e4.tar.bz2 |
gcc 3.2.2 portability hacks.
Diffstat (limited to 'gold/symtab.cc')
-rw-r--r-- | gold/symtab.cc | 44 |
1 files changed, 29 insertions, 15 deletions
diff --git a/gold/symtab.cc b/gold/symtab.cc index 0f43faa..9adb9de 100644 --- a/gold/symtab.cc +++ b/gold/symtab.cc @@ -308,8 +308,8 @@ Symbol_table::add_from_object(Sized_object<size, big_endian>* object, if (!ins.second) { // We already have an entry for NAME/VERSION. - ret = this->get_sized_symbol SELECT_SIZE_NAME (ins.first->second - SELECT_SIZE(size)); + ret = this->get_sized_symbol SELECT_SIZE_NAME(size) (ins.first->second + SELECT_SIZE(size)); assert(ret != NULL); was_undefined = ret->is_undefined(); @@ -330,10 +330,10 @@ Symbol_table::add_from_object(Sized_object<size, big_endian>* object, // This is the unfortunate case where we already have // entries for both NAME/VERSION and NAME/NULL. const Sized_symbol<size>* sym2; - sym2 = this->get_sized_symbol SELECT_SIZE_NAME ( + sym2 = this->get_sized_symbol SELECT_SIZE_NAME(size) ( insdef.first->second SELECT_SIZE(size)); - Symbol_table::resolve SELECT_SIZE_ENDIAN_NAME ( + Symbol_table::resolve SELECT_SIZE_ENDIAN_NAME(size, big_endian) ( ret, sym2 SELECT_SIZE_ENDIAN(size, big_endian)); this->make_forwarder(insdef.first->second, ret); insdef.first->second = ret; @@ -352,8 +352,9 @@ Symbol_table::add_from_object(Sized_object<size, big_endian>* object, { // We already have an entry for NAME/NULL. Make // NAME/VERSION point to it. - ret = this->get_sized_symbol SELECT_SIZE_NAME (insdef.first->second - SELECT_SIZE(size)); + ret = this->get_sized_symbol SELECT_SIZE_NAME(size) ( + insdef.first->second + SELECT_SIZE(size)); Symbol_table::resolve(ret, sym, object); ins.first->second = ret; } @@ -500,7 +501,8 @@ Symbol_table::add_from_object( template<int size, bool big_endian> Sized_symbol<size>* Symbol_table::define_special_symbol(Target* target, const char* name, - bool only_if_ref) + bool only_if_ref + ACCEPT_SIZE_ENDIAN) { assert(this->size_ == size); @@ -562,8 +564,8 @@ Symbol_table::define_special_symbol(Target* target, const char* name, { assert(sym == NULL); - sym = this->get_sized_symbol SELECT_SIZE_NAME (oldsym - SELECT_SIZE(size)); + sym = this->get_sized_symbol SELECT_SIZE_NAME(size) (oldsym + SELECT_SIZE(size)); assert(sym->source() == Symbol::FROM_OBJECT); const int old_shnum = sym->shnum(); if (old_shnum != elfcpp::SHN_UNDEF @@ -628,9 +630,13 @@ Symbol_table::do_define_in_output_data( Sized_symbol<size>* sym; if (target->is_big_endian()) - sym = this->define_special_symbol<size, true>(target, name, only_if_ref); + sym = this->define_special_symbol SELECT_SIZE_ENDIAN_NAME(size, true) ( + target, name, only_if_ref + SELECT_SIZE_ENDIAN(size, true)); else - sym = this->define_special_symbol<size, false>(target, name, only_if_ref); + sym = this->define_special_symbol SELECT_SIZE_ENDIAN_NAME(size, false) ( + target, name, only_if_ref + SELECT_SIZE_ENDIAN(size, false)); if (sym == NULL) return; @@ -684,9 +690,13 @@ Symbol_table::do_define_in_output_segment( Sized_symbol<size>* sym; if (target->is_big_endian()) - sym = this->define_special_symbol<size, true>(target, name, only_if_ref); + sym = this->define_special_symbol SELECT_SIZE_ENDIAN_NAME(size, true) ( + target, name, only_if_ref + SELECT_SIZE_ENDIAN(size, true)); else - sym = this->define_special_symbol<size, false>(target, name, only_if_ref); + sym = this->define_special_symbol SELECT_SIZE_ENDIAN_NAME(size, false) ( + target, name, only_if_ref + SELECT_SIZE_ENDIAN(size, false)); if (sym == NULL) return; @@ -736,9 +746,13 @@ Symbol_table::do_define_as_constant( Sized_symbol<size>* sym; if (target->is_big_endian()) - sym = this->define_special_symbol<size, true>(target, name, only_if_ref); + sym = this->define_special_symbol SELECT_SIZE_ENDIAN_NAME(size, true) ( + target, name, only_if_ref + SELECT_SIZE_ENDIAN(size, true)); else - sym = this->define_special_symbol<size, false>(target, name, only_if_ref); + sym = this->define_special_symbol SELECT_SIZE_ENDIAN_NAME(size, false) ( + target, name, only_if_ref + SELECT_SIZE_ENDIAN(size, false)); if (sym == NULL) return; |