final.c: Revert back my previous changes.
authorChandrakala Chavva <cchavva@redhat.com>
Wed, 7 Feb 2001 01:05:35 +0000 (20:05 -0500)
committerChandra Chavva <cchavva@gcc.gnu.org>
Wed, 7 Feb 2001 01:05:35 +0000 (20:05 -0500)
        * final.c: Revert back my previous changes.
        * output.h: Make profile_label_no extern.
        * config/rs6000/rs6000.c (output_profile_hook): Use standard functions
        for generating label.

From-SVN: r39506

gcc/ChangeLog
gcc/config/rs6000/rs6000.c
gcc/final.c
gcc/output.h

index 7aa8c7255c861bc7cb282847459f8f9e0198385f..9c1596c6ea8556ca78a7f2f4a4276b1ce18d3427 100644 (file)
@@ -1,3 +1,10 @@
+2001-02-06  Chandrakala Chavva  <cchavva@redhat.com>
+
+       * final.c: Revert back my previous changes.
+       * output.h: Make profile_label_no extern.
+       * config/rs6000/rs6000.c (output_profile_hook): Use standard functions
+       for generating label.
+
 2001-02-06  Laurynas Biveinis  <lauras@softhome.net>
 
        * config/i386/djgpp.h: Add comments about standard paths.
index 40c8bbd4cc54cb07425eb07760089287fe628811..d64d7772289383f95c416c3ccb6429e834317df2 100644 (file)
@@ -7118,24 +7118,21 @@ void
 output_profile_hook (labelno)
      int labelno;
 {
+  if (DEFAULT_ABI == ABI_AIX)
+    {
+      char buf[30];
+      char *label_name;
+      rtx fun;
 
-   if (profile_flag && DEFAULT_ABI == ABI_AIX)
-     {
-       char *buf;
-       int length = 0;
-       rtx fun;
-
-       labelno += 1;
-       buf = permalloc (labelno+6);
-
-       ASM_GENERATE_INTERNAL_LABEL (buf, "LP", labelno);
-
-       fun = gen_rtx_SYMBOL_REF (Pmode, buf+1);
+      labelno += 1;
 
-       emit_library_call (init_one_libfunc (RS6000_MCOUNT), 0, VOIDmode, 1,
-                          fun, Pmode, Pmode);
+      ASM_GENERATE_INTERNAL_LABEL (buf, "LP", labelno);
+      STRIP_NAME_ENCODING (label_name, ggc_strdup (buf));
+      fun = gen_rtx_SYMBOL_REF (Pmode, label_name);
 
-      }
+      emit_library_call (init_one_libfunc (RS6000_MCOUNT), 0, VOIDmode, 1,
+                         fun, Pmode);
+    }
 }
 
 /* Write function profiler code. */
index 18f3e90fe8bca7607729f58037a0bd460da3b20b..3a2fc1537c5e22356364a15767c356ef9b2f8ada 100644 (file)
@@ -205,6 +205,10 @@ char regs_ever_live[FIRST_PSEUDO_REGISTER];
 
 int frame_pointer_needed;
 
+/* Assign unique numbers to labels generated for profiling.  */
+
+int profile_label_no;
+
 /* Number of unmatched NOTE_INSN_BLOCK_BEG notes we have seen.  */
 
 static int block_depth;
index 0cdb719174f227ea82bbc2adf965ff272c2cd5e2..d50b795c8c8fbe1ee65565492ca159210f8446fa 100644 (file)
@@ -459,4 +459,4 @@ extern const char *user_label_prefix;
 #endif
 /* Assign unique numbers to labels generated for profiling.  */
 
-int profile_label_no;
+extern int profile_label_no;