diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-08-11 21:22:43 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-08-11 21:22:43 +0000 |
commit | 600b9bbf6c9016b24a7c8f1cc1f4385d859f2b46 (patch) | |
tree | b522af862704889ed8299e0f561bb9942ffb9181 /gcc/dwarf2out.c | |
parent | 9aad6f8198b721ac57833ab7edd8a9c73cfb750e (diff) | |
download | gcc-600b9bbf6c9016b24a7c8f1cc1f4385d859f2b46.tar.gz |
* dwarf2out.c (add_location_or_const_value_attribute): Prefer
locations gathered by var-tracking in single entry loc_list
over loc_descriptor_from_tree.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@103004 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/dwarf2out.c')
-rw-r--r-- | gcc/dwarf2out.c | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c index 44750f97324..2dc03f4d0e6 100644 --- a/gcc/dwarf2out.c +++ b/gcc/dwarf2out.c @@ -10235,16 +10235,7 @@ add_location_or_const_value_attribute (dw_die_ref die, tree decl, return; } - /* We couldn't get any rtl, and we had no >1 element location list, so try - directly generating the location description from the tree. */ - descr = loc_descriptor_from_tree (decl); - if (descr) - { - add_AT_location_description (die, attr, descr); - return; - } - - /* Lastly, if we have tried to generate the location otherwise, and it + /* If we have tried to generate the location otherwise, and it didn't work out (we wouldn't be here if we did), and we have a one entry location list, try generating a location from that. */ if (loc_list && loc_list->first) @@ -10253,7 +10244,19 @@ add_location_or_const_value_attribute (dw_die_ref die, tree decl, descr = loc_descriptor (NOTE_VAR_LOCATION (node->var_loc_note), can_use_fb); if (descr) - add_AT_location_description (die, attr, descr); + { + add_AT_location_description (die, attr, descr); + return; + } + } + + /* We couldn't get any rtl, so try directly generating the location + description from the tree. */ + descr = loc_descriptor_from_tree (decl); + if (descr) + { + add_AT_location_description (die, attr, descr); + return; } } |