summaryrefslogtreecommitdiff
path: root/gas/stabs.c
diff options
context:
space:
mode:
authorMichael Snyder <msnyder@vmware.com>2001-12-04 23:07:26 +0000
committerMichael Snyder <msnyder@vmware.com>2001-12-04 23:07:26 +0000
commitb7091fc4dfb89e7c7fda88ffd5c49f9b4b68722b (patch)
treeba20b5ab680772a4a49f1841afd95c6e42cb5a0e /gas/stabs.c
parent3b1ab2e0a13533738b538217a80faa347962164a (diff)
downloadbinutils-redhat-b7091fc4dfb89e7c7fda88ffd5c49f9b4b68722b.tar.gz
2001-11-16 Michael Snyder <msnyder@redhat.com>
* stabs.c (stabs_generate_asm_lineno): Remember file and line number from one call to the next, and eliminate consecutive duplicates (thereby emitting only one line symbol per source line). * dwarf2dbg.c (dwarf2_gen_line_info): Ditto.
Diffstat (limited to 'gas/stabs.c')
-rw-r--r--gas/stabs.c35
1 files changed, 31 insertions, 4 deletions
diff --git a/gas/stabs.c b/gas/stabs.c
index cd5a705ff2..60b03c4994 100644
--- a/gas/stabs.c
+++ b/gas/stabs.c
@@ -580,10 +580,9 @@ stabs_generate_asm_lineno ()
unsigned int lineno;
char *buf;
char sym[30];
-
- /* Let the world know that we are in the middle of generating a
- piece of stabs line debugging information. */
- outputting_stabs_line_debug = 1;
+ /* Remember the last file/line and avoid duplicates. */
+ static unsigned int prev_lineno = -1;
+ static char *prev_file = NULL;
/* Rather than try to do this in some efficient fashion, we just
generate a string and then parse it again. That lets us use the
@@ -594,6 +593,34 @@ stabs_generate_asm_lineno ()
as_where (&file, &lineno);
+ /* Don't emit sequences of stabs for the same line. */
+ if (prev_file == NULL)
+ {
+ /* First time thru. */
+ prev_file = xstrdup (file);
+ prev_lineno = lineno;
+ }
+ else if (lineno == prev_lineno
+ && strcmp (file, prev_file) == 0)
+ {
+ /* Same file/line as last time. */
+ return;
+ }
+ else
+ {
+ /* Remember file/line for next time. */
+ prev_lineno = lineno;
+ if (strcmp (file, prev_file) != 0)
+ {
+ free (prev_file);
+ prev_file = xstrdup (file);
+ }
+ }
+
+ /* Let the world know that we are in the middle of generating a
+ piece of stabs line debugging information. */
+ outputting_stabs_line_debug = 1;
+
generate_asm_file (N_SOL, file);
sprintf (sym, "%sL%d", FAKE_LABEL_NAME, label_count);