Commit 9e51ddaa by Geoffrey Keating Committed by Geoffrey Keating

dwarf2out.c (is_c_family): Understand new DWARF3 language types.

2006-03-24  Geoffrey Keating  <geoffk@apple.com>

	* dwarf2out.c (is_c_family): Understand new DWARF3 language types.
	(is_cxx): Likewise.
	(gen_compile_unit_die): Use new language types for Objective-C and
	Objective-C++.
	(dwarf2out_decl): Use is_cxx rather than testing explicitly against
	DW_LANG_C_plus_plus.

Index: testsuite/ChangeLog
2006-03-24  Geoffrey Keating  <geoffk@apple.com>

	* objc.dg/dwarf-2.m: New.
	* obj-c++.dg/dwarf-2.mm: New.

From-SVN: r112372
parent affceb31
...@@ -5,6 +5,13 @@ ...@@ -5,6 +5,13 @@
2006-03-24 Geoffrey Keating <geoffk@apple.com> 2006-03-24 Geoffrey Keating <geoffk@apple.com>
* dwarf2out.c (is_c_family): Understand new DWARF3 language types.
(is_cxx): Likewise.
(gen_compile_unit_die): Use new language types for Objective-C and
Objective-C++.
(dwarf2out_decl): Use is_cxx rather than testing explicitly against
DW_LANG_C_plus_plus.
PR 26793 PR 26793
* config/t-darwin (crt3.o): Work around bug 26840. * config/t-darwin (crt3.o): Work around bug 26840.
* config/darwin-crt3.c: Rewrite. * config/darwin-crt3.c: Rewrite.
......
...@@ -5326,8 +5326,9 @@ is_c_family (void) ...@@ -5326,8 +5326,9 @@ is_c_family (void)
{ {
unsigned int lang = get_AT_unsigned (comp_unit_die, DW_AT_language); unsigned int lang = get_AT_unsigned (comp_unit_die, DW_AT_language);
return (lang == DW_LANG_C || lang == DW_LANG_C89 return (lang == DW_LANG_C || lang == DW_LANG_C89 || lang == DW_LANG_ObjC
|| lang == DW_LANG_C_plus_plus); || lang == DW_LANG_C99
|| lang == DW_LANG_C_plus_plus || lang == DW_LANG_ObjC_plus_plus);
} }
/* Return TRUE if the language is C++. */ /* Return TRUE if the language is C++. */
...@@ -5335,8 +5336,9 @@ is_c_family (void) ...@@ -5335,8 +5336,9 @@ is_c_family (void)
static inline bool static inline bool
is_cxx (void) is_cxx (void)
{ {
return (get_AT_unsigned (comp_unit_die, DW_AT_language) unsigned int lang = get_AT_unsigned (comp_unit_die, DW_AT_language);
== DW_LANG_C_plus_plus);
return lang == DW_LANG_C_plus_plus || lang == DW_LANG_ObjC_plus_plus;
} }
/* Return TRUE if the language is Fortran. */ /* Return TRUE if the language is Fortran. */
...@@ -12204,6 +12206,10 @@ gen_compile_unit_die (const char *filename) ...@@ -12204,6 +12206,10 @@ gen_compile_unit_die (const char *filename)
language = DW_LANG_Pascal83; language = DW_LANG_Pascal83;
else if (strcmp (language_string, "GNU Java") == 0) else if (strcmp (language_string, "GNU Java") == 0)
language = DW_LANG_Java; language = DW_LANG_Java;
else if (strcmp (language_string, "GNU Objective-C") == 0)
language = DW_LANG_ObjC;
else if (strcmp (language_string, "GNU Objective-C++") == 0)
language = DW_LANG_ObjC_plus_plus;
else else
language = DW_LANG_C89; language = DW_LANG_C89;
...@@ -13314,8 +13320,7 @@ dwarf2out_decl (tree decl) ...@@ -13314,8 +13320,7 @@ dwarf2out_decl (tree decl)
{ {
/* OK, we need to generate one for `bool' so GDB knows what type /* OK, we need to generate one for `bool' so GDB knows what type
comparisons have. */ comparisons have. */
if ((get_AT_unsigned (comp_unit_die, DW_AT_language) if (is_cxx ()
== DW_LANG_C_plus_plus)
&& TREE_CODE (TREE_TYPE (decl)) == BOOLEAN_TYPE && TREE_CODE (TREE_TYPE (decl)) == BOOLEAN_TYPE
&& ! DECL_IGNORED_P (decl)) && ! DECL_IGNORED_P (decl))
modified_type_die (TREE_TYPE (decl), 0, 0, NULL); modified_type_die (TREE_TYPE (decl), 0, 0, NULL);
......
...@@ -4,6 +4,9 @@ ...@@ -4,6 +4,9 @@
2006-03-24 Geoffrey Keating <geoffk@apple.com> 2006-03-24 Geoffrey Keating <geoffk@apple.com>
* objc.dg/dwarf-2.m: New.
* obj-c++.dg/dwarf-2.mm: New.
* g++.old-deja/g++.other/init19.C: New. * g++.old-deja/g++.other/init19.C: New.
2006-03-24 David Edelsohn <edelsohn@gnu.org> 2006-03-24 David Edelsohn <edelsohn@gnu.org>
/* { dg-options "-gdwarf-2 -dA" } */
/* { dg-final { scan-assembler "0x11\[^0-9a-f\].*DW_AT_language" } } */
int x;
/* { dg-options "-gdwarf-2 -dA" } */
/* { dg-final { scan-assembler "0x10\[^0-9a-f\].*DW_AT_language" } } */
int x;
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment