]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gprof/ChangeLog
* config/tc-mips.c (md_apply_fix): Improve error message for out
[thirdparty/binutils-gdb.git] / gprof / ChangeLog
CommitLineData
22395d7e
ILT
1Thu Feb 27 12:46:53 1997 Ian Lance Taylor <ian@cygnus.com>
2
3 * configure.in: Define BSD44_FORMAT if the target looks like a
4 BSD4.4 derived system.
5 * configure: Rebuild.
6 * Makefile.in (.c.o): Add @DEFS@.
7 * gmon_io.c (gmon_out_read): In BSD44_FORMAT code, get profrate
8 from profrate field, not version field.
9
9edcbc03
ILT
10Thu Jan 16 17:42:54 1997 Ian Lance Taylor <ian@cygnus.com>
11
12 * dummy.c (find_call): Clear ignore_direct_calls.
13
b3902dd3
ILT
14Tue Dec 31 15:44:10 1996 Ian Lance Taylor <ian@cygnus.com>
15
16 * Makefile.in (.c.o): Add -D_GNU_SOURCE. Put $(CFLAGS) at the
17 end.
18 (gprof): Put $(CFLAGS) after the other options.
19
4947b15f
ILT
20Tue Nov 26 17:08:38 1996 Ian Lance Taylor <ian@cygnus.com>
21
22 * configure: Rebuild with autoconf 2.12.
23
1259da3e
ILT
24Wed Oct 2 15:23:16 1996 Ian Lance Taylor <ian@cygnus.com>
25
26 * sparc.c (find_call): Align p_lowpc to avoid bus error.
27
50622dea
ILT
28Tue Oct 1 15:58:10 1996 Ian Lance Taylor <ian@cygnus.com>
29
30 * gprof.c (usage): Print bug report address.
31 (main): Change version printing to match current GNU standards.
32
76a61985
ILT
33Fri Aug 30 12:16:11 1996 Ian Lance Taylor <ian@cygnus.com>
34
35 * gmon.h: Replace #elif with #else/#endif.
36
3d5aa992
MM
37Thu Aug 29 17:04:10 1996 Michael Meissner <meissner@tiktok.cygnus.com>
38
39 * configure.in (i[345]86-*-*): Recognize i686 for pentium pro.
40 * configure: Regenerate.
41
cb26c22d
ILT
42Thu Aug 22 17:12:30 1996 Ian Lance Taylor <ian@cygnus.com>
43
44 * configure.in: Set and substitute HLDENV.
45 * configure: Rebuild.
46 * Makefile.in (HLDENV): New variable.
47 (gprof): Use $(HLDENV).
48
1c34a108
ILT
49Wed Aug 7 14:43:51 1996 Philippe De Muyter <phdm@info.ucl.ac.be>
50
51 * core.c (read_function_mappings): Cast xmalloc return.
52
45c85bcb
ILT
53Thu Jul 4 12:01:42 1996 Ian Lance Taylor <ian@cygnus.com>
54
4cdbf68f
ILT
55 * gprof.c (VERSION): Define as "2.7.1".
56
45c85bcb
ILT
57 * Released binutils 2.7.
58
13566744
ILT
59 * bb_exit_func.c: Rename from __bb_exit_func.c, so that it can be
60 stored on a System V file system.
61
e3c0e00b
ILT
62Thu Jun 27 11:36:22 1996 Ian Lance Taylor <ian@cygnus.com>
63
64 * configure.in: Call AC_ISC_POSIX.
65 * configure: Rebuild.
66 * Makefile.in (gprof): Pass $(CFLAGS) during link.
67 * hertz.c: Don't include <sys/time.h>; let sysdep.h handle that.
68 If HAVE_SETITIMER is not defined, try using sysconf.
69
39c3964f
JM
70Mon Jun 24 18:27:28 1996 Jason Molenda (crash@godzilla.cygnus.co.jp)
71
72 * Makefile.in (exec_prefix, bindir, libdir, mandir, infodir, datadir,
73 INSTALL_PROGRAM, INSTALL_DATA): Use autoconf-set values.
74 * configure.in (AC_PREREQ): autoconf 2.5 or higher.
75 (AC_PROG_INSTALL): added.
76 * configure: Rebuilt.
77
8530ae8e
ILT
78Mon Jun 24 12:03:09 1996 Ian Lance Taylor <ian@cygnus.com>
79
80 * configure.in: On alpha*-*-osf*, link against libbfd.a if not
81 using shared libraries.
82 * configure: Rebuild with autoconf 2.10.
83
d75ea6de
ILT
84Tue Jun 18 17:35:58 1996 Ian Lance Taylor <ian@cygnus.com>
85
86 * core.c (core_create_line_syms): Use xstrdup rather than strdup.
87 * source.c (source_file_lookup_path): Likewise.
88
b4cb4ea2
ILT
89Mon Apr 8 14:44:33 1996 Ian Lance Taylor <ian@cygnus.com>
90
91 * configure.in: Permit --enable-shared to specify a list of
92 directories.
93 * configure: Rebuild.
94
df928c8f
ILT
95Thu Mar 21 17:18:25 1996 Ian Lance Taylor <ian@cygnus.com>
96
97 * core.c (core_create_function_syms): Move filename and func_name
98 inside ifdef where they are used.
99
100 * core.c (core_sym_class): Parenthesize && within ||.
101 * symtab.c (symtab_finalize): Correct parenthesization.
102
103 * cg_print.h (cg_print_file_ordering): Declare.
104 (cg_print_function_ordering): Declare.
105
106 * __bb_exit_func.c (__bb_exit_func): Replace bcopy with memcpy.
107 * cg_arcs.c (arc_add): Likewise.
108 * cg_print.c (cg_print_function_ordering): Likewise.
109
0f579087
ILT
110Thu Mar 21 17:02:02 1996 David Mosberger-Tang <davidm@azstarnet.com>
111
112 * gprof.c (default_excluded_list): Add "__mcount".
113
114 * gprof.c (main): Change ifdef __osf__ to __alpha__.
115
116 * gmon_io.c (gmon_out_read): If BSD44_FORMAT is defined, get the
117 profiling rate from the header.
118
119 * gmon.h (struct raw_phdr): Only include pad if both __alpha__ and
120 __osf__ are defined. Add new fields if BSD44_FORMAT is defined.
121
122 * alpha.h (MIN_INSN_SIZE): Define.
123 * core.c (MIN_INSN_SIZE): If not defined, define as 1.
124 (core_sym_class): Ignore debugging symbols.
125 (core_create_line_syms): Use MIN_INSN_SIZE when gathering line
126 information.
127
7a542ed9
ILT
128Wed Mar 20 18:15:47 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
129
130 * cg_print.c (cg_print_function_ordering): Fix __GNUC__ misspelled
131 as __GNU_C__.
132 (order_and_dump_functions_by_arcs): Likewise.
133
ea2488ad
ILT
134Tue Mar 12 12:19:50 1996 Ian Lance Taylor <ian@cygnus.com>
135
136 * configure: Rebuild with autoconf 2.8.
137
7925f4d4
ILT
138Sun Feb 18 15:06:18 1996 Ian Lance Taylor <ian@cygnus.com>
139
140 * configure.in: Check for 'do not mix' from native linker before
141 trying to use -rpath.
142 * configure: Rebuild.
143
56f9773f
ILT
144Tue Feb 13 15:32:53 1996 Ian Lance Taylor <ian@cygnus.com>
145
146 * configure.in: Set HDLFLAGS for *-*-hpux with --enable-shared.
147 * configure: Rebuild.
148
ba8e3a2e
ILT
149Wed Feb 7 14:03:17 1996 Ian Lance Taylor <ian@cygnus.com>
150
151 * configure.in: Don't set CC. Look for --enable-shared. Set
152 BFDLIB and HLDFLAGS and substitute them.
153 * configure: Rebuild.
154 * Makefile.in (LIBS): Use @BFDLIB@.
155 (HLDFLAGS): New variable.
156 (gprof): Use $(HLDFLAGS).
157
04ed3b54
ILT
158Mon Feb 5 16:34:44 1996 Ian Lance Taylor <ian@cygnus.com>
159
160 Support for building bfd and opcodes as shared libraries, based on
161 patches from Alan Modra <alan@spri.levels.unisa.edu.au>:
162 * Makefile.in (LIBDEPS): New variable.
163 (LIBS): Use -L../bfd -lbfd.
164 (gprof): Depend upon $(LIBDEPS) rather than $(LIBS).
165
64c50fc5
JL
166Sat Dec 30 10:11:03 1995 Jeffrey A Law (law@cygnus.com)
167
168 * gprof.c (long_options): Add "--function-ordering" and
169 "--file-ordering" options.
170 (usage): Add new options to usage message.
171 (main): Handle new options.
172 * gprof.h (STYLE_FUNCTION_ORDER): Define.
173 (STYLE_FILE_ORDER): Define.
174 (function_mapping_file): Declare.
175 * cg_arcs.c (arcs, numarcs): New globals.
176 (arc_add): Put new arcs into the arc array so the function/file
177 ordering code can examine them.
178 * cg_arcs.h (struct arc): New field "has_been_placed".
179 (arcs, numarcs): Declare new globals.
180 * core.c (symbol_map, symbol_map_count): New globals.
181 (read_function_mappings): New function to read in a function
182 to object map file.
183 (core_init): Call read_function_mappings if a function mapping
184 file exists.
185 (core_create_function_syms): Handle function to object file
186 mappings.
187 * symtab.h (struct sym): New fields "mapped", "has_been_placed",
188 "nuses", "prev".
189 * cg_print.c (cmp_arc_count): New function for sorting arcs.
190 (cmp_fun_nuses): Likewise for functions.
191 (cg_print_function_ordering): New function to print a suggested
192 function ordering.
193 (cg_print_file_ordering): Likewise for ordering .o files.
194 (order_and_dump_functions_by_arcs): Helper function for function
195 and object file ordering code.
196
32843f94
JL
197Sun Dec 24 21:32:27 1995 Jeffrey A Law (law@cygnus.com)
198
199 * core.c (core_sym_class): Ignore symbols without BSF_FUNCTION
200 set if ignore_non_function is set.
201 * gprof.h (ignore_non_functions): Declare.
202 * gprof.c (ignore_non_functions): Define.
203 (long_options): Add "ignore-non-functions".
204 (usage): Add new options.
205 (main): Recognize "-D" and "--ignore-non-functions" option.
206
1aa65af6
KR
207Tue Nov 21 13:24:39 1995 Ken Raeburn <raeburn@cygnus.com>
208
a4f589cc
KR
209 * Makefile.in (.m.c): Strip out directory name from function
210 name.
211
fcc14c40
KR
212 * hist.c (scale_and_align_entries): Don't use DEFUN_VOID. Do
213 UNITS_TO_CODE adjustment unconditionally; compiler can optimize
214 away zero-offset case. Refer to scaled_addr, not aligned_addr.
215
1aa65af6
KR
216 * vax.c: Don't include vax.h here.
217
b218076e
KR
218Thu Nov 16 03:41:37 1995 Ken Raeburn <raeburn@cygnus.com>
219
220 Version 2.6 released.
221
31af2d7e
ILT
222Wed Nov 8 11:40:04 1995 Ian Lance Taylor <ian@cygnus.com>
223
224 * gprof.c (main): Cast getenv return value.
225
4a07e94f
KR
226Mon Nov 6 15:05:00 1995 Ken Raeburn <raeburn@cygnus.com>
227
228 * Makefile.in (TAGS): New target.
229
c3294c2e
PB
230Wed Nov 1 12:51:21 1995 Per Bothner <bothner@kalessin.cygnus.com>
231
232 * Makefile.in (DISTSTUFF): Rename to GEN_FILES, to avoid confusion.
233 (all): Depend on $(GEN_FILES), not diststuff (which also depends
234 on info).
235
911d6ca1
ILT
236Wed Nov 1 15:23:15 1995 Manfred Hollstein KS/EF4A 60/1F/110 #40283 <manfred@lts.sel.alcatel.de>
237
238 * sym_ids.c: Include <ctype.h>.
239
fc9e7850
PB
240Wed Oct 25 13:24:31 1995 Per Bothner <bothner@kalessin.cygnus.com>
241
242 * Makefile.in (diststuff): Also make info.
243 (mostlyclean): Don't remove gprof.info*.
244 (maintainer-clean realclean): Also remove *.info*.
245
869b94c5
KR
246Fri Oct 6 16:25:32 1995 Ken Raeburn <raeburn@cygnus.com>
247
248 Mon Sep 25 22:49:32 1995 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
249
250 * Makefile.in: Add dependecies for $(OBJS) on header files.
251
252 * cg_print.c (print_cycle, print_members, cg_print_index): Fix new
253 style output format to make it consistent.
254 * dummy.c (find_call): Fix typo in error message.
255
0312401c
ILT
256Wed Sep 20 13:21:02 1995 Ian Lance Taylor <ian@cygnus.com>
257
258 * Makefile.in (maintainer-clean): New target, synonym for
259 realclean.
260
3e0d0327
ILT
261Fri Sep 8 14:38:08 1995 Ian Lance Taylor <ian@cygnus.com>
262
263 * Makefile.in (install): Don't install in $(tooldir).
264
af0786b4
KR
265Fri Aug 25 15:30:05 1995 Ken Raeburn <raeburn@cygnus.com>
266
267 NS32K changes from Ian Dall:
268 * configure.in: Use ns32k, not ns532.
269 * ns532.c: Include symtab.h.
270 (find_call): Renamed from findcall. Print a message.
271 * ns532.h: Remove dummy.h comments.
272
d0c997a9
JL
273Tue Aug 22 10:00:45 1995 Jeffrey A. Law <law@rtl.cygnus.com>
274
275 * Makefile.in (install): Remove "brokensed" hack, unnecessary now
276 that we're using autoconf.
277
643f17d2
FF
278Wed Jul 19 18:46:13 1995 Fred Fish <fnf@cygnus.com>
279
280 * core.c (get_src_info): Cast arg 7 of bfd_find_nearest_line
281 to proper type of "unsigned int *".
282
379062d1
KR
283Fri Jun 16 15:29:36 1995 Ken Raeburn <raeburn@cujo.cygnus.com>
284
285 * configure.in: Use changequote around use of [].
286
9e4be2c7
C
287Mon Jun 12 12:14:52 1995 J.T. Conklin <jtc@rtl.cygnus.com>
288
289 * Makefile.in (distclean, realclean): Remove config.cache and
290 config.log.
291
3ecd5c7d
C
292Wed May 17 17:56:53 1995 J.T. Conklin <jtc@rtl.cygnus.com>
293
294 * Makefile.in (Makefile): Added config.status to dependency list.
295 (config.status): New target.
296 (SHELL): New definition.
297
e4fc2696
KR
298Tue Apr 25 21:11:12 1995 Ken Raeburn <raeburn@cujo.cygnus.com>
299
300 * Makefile.in (install): Depend on "all".
301
4c92f064
KR
302Thu Apr 20 17:29:07 1995 Ken Raeburn <raeburn@cujo.cygnus.com>
303
304 * Makefile.in: Change all references to MY_MACHINE to MY_TARGET,
305 to match configure script.
306
7858d8dc
C
307Wed Apr 19 11:19:37 1995 J.T. Conklin <jtc@rtl.cygnus.com>
308
309 * gen-c-prog.awk: Changed reference to "make-c-prog.awk" in
310 comment emitted by this script to gen-c-prog.awk.
311
312 * Makefile.in, configure.in: Converted to use autoconf.
313 * configure: New file, generated with autoconf 2.3.
314 * config/{mt-alpha, mt-dummy, mt-i386, mt-ns532, mt-sparc,
315 mt-tahoe, mt-vax}: Removed.
316
03c35bcb
KR
317Mon Mar 13 21:44:24 1995 Ken Raeburn <raeburn@cujo.cygnus.com>
318
319 * __bb_exit_func.c: New file, from David Mosberger-Tang.
320
321 Thu Feb 9 16:56:07 1995 David Mosberger-Tang <davidm@piston.cs.arizona.edu>
322
323 * All *.c: More cleanup towards GNU format.
324
325 * gmon_out.h (struct gmon_hist_hdr, struct gmon_cg_arc_record):
326 replaced sizeof (bfd_vma) by size (char*) because Ken tells me
327 that bfd_vma is only guaranteed to be at least as big as a pointer.
328
329 (GMON_Record_tag): added explicit enumeration values to ensure
330 compatibility across compilers.
331
332 * gmon_io.c (get_vma, put_vma): replaced sizeof(bfd_vma) by
333 sizeof(char*).
334
5489fcc3
KR
335Tue Feb 7 17:24:12 1995 Ken Raeburn <raeburn@cujo.cygnus.com>
336
12516a37
KR
337 * All *.c and *.h files: Ran "indent -gnu". Cleaned up a couple
338 of constructs GNU indent couldn't handle. Block comments not yet
339 rewritten in GNU format.
340
5489fcc3
KR
341 * gprof.c (VERSION): Changed to 2.6, to get in sync for next
342 binutils release.
343
344Sun Feb 5 16:19:46 1995 David Mosberger-Tang <davidm@piston.cs.arizona.edu>
345
346 * symtab.c (symtab_finalize): ensure globals symbols really
347 are favored over static ones---even if their name looks less
348 preferable; this is important for HP-UX; for example, there
349 is a static label Ltext_something that aliases the global
350 symbol _start
351
352 * hist.c (hist_print): auto-scaling is now in effect for FSF-style
353 output only; also, auto-scaling is now performed based on
354 per-call, rather than total execution time, which is what it was
355 meant to be.
356
357 * gprof.h (File_Format): new type.
358
359 * gprof.c (VERSION): upped to 2.7---seems to be completely out of
360 sync with Cygnus version numbers though...
361
362 (long_options): renamed --gmon-info to --file-info, --width added,
363 renamed --old-file-format to --file-format
364 (main): dito; also added support to read prof files, but as
365 mon_out_read() is not implemented, it's #ifdef'd out for now
366
367 (usage): update to reflect new options.
368
369 * gmon_io.c: replaced "old_file_format" by more general
370 "file_format" option
371
372 * gmon.h (struct raw_phdr): fixed declaration for OSF/1.
373
374 * core.c (core_sym_class): added back check for __gnu_compiled and
375 ___gnu_compiled for the benefit of systems without
376 bfd_find_nearest_line() support
377
378 (get_src_info): now the libbfd is fixed, invoke bfd_find_nearest_line()
379 with section-relative addresses
380
381 (core_create_function_syms): get_src_info() calls are currently
382 enabled for OSF/1 only. It appears to work allright for SunOS
383 4.1.x as well, but on SPARCs it gets painfully slow with the
384 current implementation of aout_32_find_nearest_line();
385 unfortunately, this means that static functions will not have their
386 filename printed in the call-graph function index; line-level
387 profiling should still work, but requires some patience
388
389 * cg_print.c (cg_print_index): sanitized printing of index when
390 using FSF-style output; in particular, output width is now controlled
391 via option --width and the function tries hard to keep columns
392 aligned even in the presence of (occasional) long names
393
394 * NOTES: a first shot at updating the documentation.
395
396Wed Feb 1 19:07:44 1995 David Mosberger-Tang <davidm@piston.cs.arizona.edu>
397
398 * core.c (core_create_function_syms): fixed computation of min_vma
399 and max_vma.
400
401 * *.c: removed rcsid.
402
403Tue Jan 31 16:18:18 1995 Ken Raeburn <raeburn@cujo.cygnus.com>
404
405 * Lots of changes from David Mosberger-Tang:
406
407 Tue Oct 25 19:20:14 1994 David Mosberger-Tang <davidm@piston.cs.arizona.edu>
408
409 * gprof.c (main): put parentheses around & within &&.
410
411 * basic_blocks.c (bb_read_rec): print warning message (once) when
412 ignoring basic-block execution counts.
413
414 * source.c (source_file_lookup_name): corrected second argument to
415 strcmp().
416
417 * hist.c (print_header): merged Fri Oct 21 18:58:02 1994 change by
418 Ken Raeburn <raeburn@cujo.cygnus.com> from binutils-2.5.1.
419
420 * gmon_io.c (gmon_out_read): the output stule STYLE_GMON_INFO is now
421 supported both for old and new (versioned) gmon.out files. Old
422 files are identified as version 0.
423
424 * gmon.h (struct raw_arc): count field is now sizeof(long) bytes
425 long (instead of 4) because that is what OSF/1 v3.0 uses.
426
427 * core.c: minor fixes and debugging info changes.
428
429 Sun Sep 11 18:47:47 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
430
431 * core.c (core_init): if .text cannot be found, try $CODE$ (the
432 name of the text-section under HP-UX).
433
434 * hist.c (hist_assign_samples): fixed off-by-one bug: highpc
435 points one past the last sampling bin, so hist_scale should be
436 computed as "hist_scale /= hist_num_bins", not "hist_scale /=
437 hist_num_bins - 1".
438
439 * gmon_io.c, hist.c, hist.h: renamed hist_num_samples to
440 hist_num_bins.
441
442 * configure.in: added alpha-*-*) for per-target config.
443
444 * alpha.c, alpha.h: created.
445
446 * gprof.c (default_excluded_list): <locore>, <hicore> added.
447
448 * core.c (core_create_function_syms, core_create_line_syms):
449 explicitly keep two sentinels "<locore>" and "<hicore>" that catch
450 all addresses outside the text-space. Thus, sym_lookup(&symtab,
451 addr) continues to guarantee not to return 0 on any address. It
452 also avoids incorrectly crediting the first/last symbol in the
453 text-space.
454
455 * core.c (core_create_line_syms): always create function symbols
456 first, then merge in line symbols; this is so that if parts of the
457 program were compiled without -g, function-level symbols are
458 available still.
459
460 * utils.c (print_name_only): support for print_path added.
461
462 * symtab.c (cmp_addr): also use is_func flag in comparison.
463 (symtab_finalize): return immediately when table empty; now
464 more careful about getting rid of the right duplicate symbol.
465
466 * sparc.c (find_call): many fixes---this function was rather
467 botched in binutils-2.4 already; it should work again.
468
469 * source.c (source_file_lookup_path): PATH is now strdup'ed (it is
470 not good to rely on get_src_info() to return distinct string
471 pointers).
472
473 * search_list.c (search_list_append): added cast for xmalloc().
474
475 * hist.c: added explicit initialization to some of the global
476 variables; fixed SItab (scales were off by a factor of 10).
477
478 * hist.h: include of bfd.h added.
479
480 * gprof.c, gprof.h (print_path): added.
481
482 * gprof.h (MAX): fixed.
483
484 * gmon_out.h: renamed gmon_time_hist_hdr to gmon_hist_hdr.
485
486 * gmon_io.c: added some casts to (long) so we can always print as %lx
487
488 * core.c (core_get_text_space): fixed to make it work.
489
490 * cg_print.c (cg_print_index): added support for print_path option.
491
492 * cg_dfn.h (cg_dfn): wrap prototype in PARAMS().
493
494 * call_graph.c, gmon_io.c, hist.c: avoid taking address of array
495 as some compilers complain (e.g., DEC's OSF/1 compiler)
496
497 * basic_blocks.c, gmon_io.c, hist.c, source.c, sym_ids.c,
498 symtab.c: calls to memset() had 2nd and 3rd args reversed.
499
500 Sat Sep 10 21:53:13 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
501
502 * gprof.c: added "_mcount" to default_excluded_list.
503 (main): if output_style==0 and there is either a histogram or a
504 call-graph, always generate flat and call-graph, no matter what
505 line_granularity is set to.
506
507 * source.c (source_file_lookup_name): if searching for sf->name
508 fails, try again with filename obtained after stripping off any
509 partial path from sf->name.
510
511 * gprof.h (SRCDEBUG): added.
512
513 * search_list.c (search_list_append): directories were added in wrong
514 order.
515
516 * reimplemented selection mechanism from ground up; it is now possible
517 to accurately control what gets included/excluded in each of the
518 output styles; a "symbol-specification" (spec) is the basic means
519 to select a set of symbols; a spec has the syntax:
520
521 spec == (FILENAME:(FUNCNAME|LINE_NUM) | NAME).
522 arc == spec/spec.
523
524 any of the terminal symbols can be empty, in which case they
525 match anything (wildcards). NAME is interpreted as a FILENAME
526 if it contains a dot (e.g., foo.c), as LINE_NUM if it starts
527 with a digit, and as FUNCNAME otherwise.
528
529 For example, to get a call-graph display that ignores arcs
530 from foo() to bar(), you'd say "--no-graph=foo/bar"; to
531 show only arcs into bar() (no matter what the caller),
532 you'd say "--graph=/bar"; and to get a call-graph without
533 any arc info, you'd say "--graph=/"; similarly, to
534 get a flat profile without mcount, you'd say "--no-flat=mcount"
535 and to get a flat profile that shows includes all functions
536 you'd say "--flat=""" (i.e., an empty spec)
537
538 * hist.c (hist_print): top_time wasn't initialized to 0.0.
539
540 Fri Sep 9 01:10:21 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
541
542 * gmon_out.h: all headers now declared in terms of characters
543 to avoid getting into trouble with different compilers introducing
544 different amount of padding; the code already accessed the fields
545 through bfd functions, so that didn't have to change.
546
547 * hist.c (hist_read_rec, hist_write_rec): added support for
548 collection pc histograms measuring quantities other than time;
549 the histogram header now includes a field that specifies the
550 dimension of the quantity measured by the histogram bins
551 (normally, this is "seconds", but other meaningful dimensions
552 include such things as "I-cache misses", "instruction issue stalls"
553 etc.); there is also a field to specify a one-character
554 abbreviation for the dimension; in the case of time, this would
555 be 's'; in most other cases it probably would be '1' (not a physical
556 dimension).
557
558 Thu Sep 8 16:05:08 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
559
560 * gprof.c, gmon_io.[ch]: BSD_COMPATIBLE is gone and new_file_version
561 has become old_file_version; gmon_io.c now always supports old-style
562 gmon.out files; it first tries to read gmon.out as a new version
563 file, if that fails, it tries to read it in the old format;
564 although not very likely, it is possible for gprof to mistake an
565 old-style file as a new one (the first 4 bytes would have to
566 be "gmon"---including the trailing '\0'); in that case, it is
567 necessary to specify --old-file-version
568
569 * gprof.h: removed dependency on SYSV; the code now always uses
570 strrchr(), memset(), and memcpy() and does not include either
571 of string.h or strings.h; this should make gprof compile on
572 any (Unix) system without configuration (per suggestion of
573 raeburn@cygnus.com)
574
575 * gprof.c (usage): fixed location of --new-file-format option.
576
577 * cg_arcs.c (propagate_flags): fixed typo in declaration.
578
579 * flat_bl.m: removed formfeed at end of file; the form-feed
580 is now printed cg_print.c only when necessary.
581
582 * major rewrite of gprof---too many changes to mention all of
583 them. new features:
584
585 + -l now requests profiling at the line level (as opposed
586 to function level); in this mode, gprof creates a "symbol"
587 (aka name-list entry) for each line of source code, instead
588 of one per function)
589
590 + support for a new gmon.out file format; the new format
591 consists of a header with a magic and a version number,
592 followed by a sequence of profile data; profile data
593 can any of: (a) PC histogram, (b) call-graph arcs, or
594 (c) basic-block execution counts; the version number makes
595 it possible to extend gmon.out in a backwards compatible
596 fashion
597
598 + support for tcov style annotated output: if the gmon.out file
599 contains basic-block execution counts, the user can request
600 the generation of annotated source files, much like Sun's
601 tcov used to do
602
603 + long options
604
605 + new scheme to suppress symbols that aren't function names
606 (e.g., avoids mistaking a goto label as a function)
607
608 + reorganized source code to make it more managable; as a
609 side effect, gprof now compiles cleanly with "gcc -Wall"
610
611 Thu Sep 1 15:46:49 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
612
613 * gprof.c (funcsymbol): bfd_find_nearest_line() is now used as a
614 final cross-check to determine whether a static symbol should be
615 considered as a function-name.
616
617 Fri Aug 5 19:32:36 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
618
619 * gmon_io.c (gmon_out_read): recognize "-" as the filename for
620 stdin; this is useful if you wanna keep gmon.out files compressed;
621 this way you can "gzcat" the compressed file into gprof.
622
623 * gprof.c: flag_min_count now initialized with 1 instead of 0.
624
625 * basic_blocks.c (bb_annotate_source): added support for creating
626 .tcov files when option flag_annotate_make_files is TRUE.
627 (annotate_with_count): all counts less than the minimum count
628 specified by -m are now annotated with hash-marks.
629
630 * gprof.c (main): -A is now followed by a string of option chars.
631
632 * basic_blocks.c (annotate_with_count): replaced b->count with
633 cnt.
634
635 * source.c: flag_annotate_source replaced by source_lock_map.
636
637 * source.h: source_lock_map added.
638
639 * gprof.c (main): new command-line syntax: -S simply specifies
640 which source-files user is interested in; -A requests annotated
641 source files and -AA requests that all lines in a source file
642 are annotated.
643
644 Thu Aug 4 23:27:03 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
645
646 * basic_blocks.c (PATH_MAX): if undefined, define as 1024.
647
648 * sparc.c, i386.c, tahoe.c, vax.c: added include of "time_hist.h"
649 so s_lowpc etc. get declared.
650
651 * arcs.h (doarcs): created.
652
653 * arcs.c: reordered static functions such that they get defined
654 before use.
655
656 * gprof.c (main): added options:
657 -A: request annotation of all source lines (with -S)
658 -m: minimum execution count (with default basic-block display)
659 -N: force new file format (only if BSD_COMPATIBLE is defined)
660 -S: annotate source file
661 -t: set table length (with -S)
662
663 * Makefile (OBJS): added basic_blocks.o call_graph.o gmon_io.o
664 source.o time_hist.o
665
666 Fri Jul 1 15:23:50 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu)
667
668 * gprof.c (asgnsamples): computation of "pcl" and "pch" depended
669 on the fact being able to store a long in a double without loss of
670 precision; this does not hold on machines with 64 bit longs and 64
671 bit doubles.
672
a051e7cc
KR
673Fri Oct 21 18:58:02 1994 Ken Raeburn <raeburn@cujo.cygnus.com>
674
675 * printgprof.c (flatprofheader): Always set totime to 1.0 if not
676 greater than 0.0. Suggested by Harold Assink
677 <carlo@sg.tn.tudelft.nl>.
678
a67d9a42
KR
679Fri Sep 23 15:06:45 1994 Ken Raeburn <raeburn@cujo.cygnus.com>
680
681 * printgprof.c (printprof): Use free, not cfree.
682 (printgprof, printindex): Ditto.
683
54a17c91
JL
684Thu Sep 1 10:40:45 1994 Jeff Law (law@snake.cs.utah.edu)
685
686 * gprof.h (kfromlist, ktolist, flist, Flist, elist, Elist): Make
687 decls extern to keep native HP compiler quiet.
688
f43a7782
ILT
689Tue Aug 30 11:12:13 1994 Ian Lance Taylor (ian@sanguine.cygnus.com)
690
691 * gprof.c (funcsymbol): Ignore ___gnu_compiled as well as
692 __gnu_compiled, for the benefit of systems which add a leading
693 underscore.
694
68e01f9d
ILT
695Wed Aug 24 12:49:13 1994 Ian Lance Taylor (ian@sanguine.cygnus.com)
696
697 * configure.in: Change i386-*-* to i[345]86-*-*.
698
fbcbb8c4
KR
699Sun Jul 10 00:35:31 1994 Ian Dall (dall@hfrd.dsto.gov.au)
700
701 * ns532.c, ns532.h: New Files. ns532 support.
702
703 * config/mt-ns532: New File. ns532 support.
704
705 * gprof.c: user register int i instead of defaulting the int.
706 Allows compilation with -Dregister= for debugging.
707
708 * configure.in: Add ns532 support.
709
15aca511
JL
710Thu Jun 23 11:22:41 1994 Jeff Law (law@snake.cs.utah.edu)
711
712 * Makefile.in (gprof): Depend on $(LIBS).
713
c06e55d9
KR
714Fri May 27 12:24:57 1994 Ken Raeburn (raeburn@cujo.cygnus.com)
715
716 From binutils-2.4 release:
717
718 Wed May 11 22:32:00 1994 DJ Delorie (dj@ctron.com)
719
720 * configure.bat: [new] build makefile from makefile.in (dos)
721 * hertz.c: allow static HERTZ (msdos needs it)
722 * gprof.c: allow target to select "r" or "rb" for fopen
723 * gprof.c: ignore __gnu_compiled symbols
724 * i386.h: dfine FOPEN_RB to "rb" for dos.
725
9cda8e3a
BC
726Tue May 17 15:30:22 1994 E. Michael Smith (ems@cygnus.com)
727
728 * Makefile.in (.m.c:): Added .SUFFIXES : .m
729 so flat_bl.c would make from flat_bl.m file.
730
dc2b222a
KR
731Thu May 5 19:23:24 1994 Ken Raeburn (raeburn@cujo.cygnus.com)
732
733 * Makefile.in (install-info): Check for gprof.info in build dir,
734 fall back to srcdir. Depend on it.
735
736 * gprof.h (TRUE, FALSE): Always use undef before defining them.
737
4e8e5c4a
JL
738Mon Apr 4 23:47:30 1994 Jeffrey A. Law (law@snake.cs.utah.edu)
739
5489fcc3
KR
740 * Makefile.in (MY_MACHINE): Renamed from MACHINE to avoid losing
741 makes (osf1) in which the value of MACHINE can not be changed.
742 * config/*.mt: Changed appropriately.
4e8e5c4a 743
bd7fc39d
ILT
744Wed Mar 30 16:12:40 1994 Ian Lance Taylor (ian@tweedledumb.cygnus.com)
745
746 * gprof.c (getsymtab): Change nosyms to long. Rename
747 get_symtab_upper_bound to bfd_get_symtab_upper_bound. Check for
748 errors from bfd_get_symtab_upper_bound and
749 bfd_canonicalize_symtab.
750
4b8250bd
JL
751Tue Mar 22 10:50:52 1994 Jeffrey A. Law (law@snake.cs.utah.edu)
752
753 * gprof.c (funcsymbol): Use bfd_get_symbol_info instead of
754 bfd_decode_symclass.
755
756Sun Mar 20 15:40:21 1994 Jeffrey A. Law (law@snake.cs.utah.edu)
4e85e79f
JL
757
758 * Makefile.in: Avoid bug in hpux sed.
759
4fe2350b
DZ
760Wed Dec 15 20:16:40 1993 david d `zoo' zuhn (zoo@andros.cygnus.com)
761
762 * gprof.texi (Invoking): add text about -v flag
763
764 * gprof.1: add text about -v flag
765
b4f476e9
DZ
766Wed Dec 8 16:55:06 1993 david d `zoo' zuhn (zoo@andros.cygnus.com)
767
768 * gprof.c (VERSION): defined a version macro, print the value
769 when the -v option is used
770
b4a1e77b
SC
771Tue Jul 6 10:11:56 1993 Steve Chamberlain (sac@phydeaux.cygnus.com)
772
773 * Makefile.in: Install correctly.
774
7ce122a2
DM
775Thu Jun 24 14:43:22 1993 David J. Mackenzie (djm@thepub.cygnus.com)
776
777 * gprof.c (main): Get whoami from argv, instead of hardcoding.
778 Use it in usage message. Split usage message to fit in 80 cols.
779
92c7228d
KR
780Sun Jun 20 20:58:02 1993 Ken Raeburn (raeburn@poseidon.cygnus.com)
781
782 * Makefile.in: Undo 15 June change.
783
73fbbeea 784Wed Jun 16 12:54:53 1993 Steve Chamberlain (sac@phydeaux.cygnus.com)
5489fcc3 785
73fbbeea
SC
786 * gmon.h, gprof.h: structs of chars used to hold external
787 representations.
788 * gprof.c (getpfile, openpfile, readsamples): Swap data in using
789 new structures.
790
c2ada801 791Tue Jun 15 23:09:17 1993 Ken Raeburn (raeburn@cambridge.cygnus.com)
f905eff4
KR
792
793 * Makefile.in (.c.o): Look in ../include, not ../bfd, for bfd.h.
794
263773ec
DZ
795Mon Jun 14 16:22:59 1993 david d `zoo' zuhn (zoo at rtl.cygnus.com)
796
797 * Makefile.in: remove parentdir support
798
7f2649bb
PB
799Mon Jun 7 12:56:17 1993 Per Bothner (bothner@rtl.cygnus.com)
800
801 * Makefile.in (INCLUDES): Add -I../bfd for sysdep.h and bfd.h.
802 * configure.in: No longer need to configure to get sysdep.h.
803
aab37f52
DZ
804Tue May 18 21:44:11 1993 david d `zoo' zuhn (zoo at cirdan.cygnus.com)
805
806 * Makefile.in (install): should not depend on install-info
807
8739c727
ILT
808Mon Apr 26 12:37:46 1993 Ian Lance Taylor (ian@cygnus.com)
809
7508b715 810 * gprof.h: Include ansidecl.h before sysdep.h. Undefine hz.
8739c727 811
9d651373
PB
812Tue Apr 13 16:14:03 1993 Per Bothner (bothner@cygnus.com)
813
814 * M Makefile.in: Add -g to CFLAGS.
815 Ads LDFLAGS and use in place of CFLAGS where appropriate.
816 * configure.in: Make a sysdep.hlink in the same way other
817 bfd-based directories do.
818 * gprof.h (UNIT): Replace non-standard 'u_short' by 'unsigned
819 short'.
820 * gprof.h: #include sysdep.h instead of a bunch of stuff.
821 * gprof.c (main): Fix typo gproff->gprof.
822
44c8c1d5
DZ
823Thu Mar 25 19:00:37 1993 david d `zoo' zuhn (zoo at cirdan.cygnus.com)
824
825 * gprof.texi: add INFO-DIR-ENTRY
826
80c8fd72
DZ
827Tue Mar 23 00:03:11 1993 david d `zoo' zuhn (zoo at cirdan.cygnus.com)
828
829 * Makefile.in: add installcheck target
830
33023c9c
PB
831Sat Feb 27 18:17:10 1993 Per Bothner (bothner@rtl.cygnus.com)
832
833 * gprof.c (funcsymbol): Invert test for aflag.
834
8a6e5b69
PB
835Thu Feb 25 16:01:50 1993 Per Bothner (bothner@rtl.cygnus.com)
836
837 * printgprof (xmalloc, xrealloc): Cast results of malloc
838 and realloc to PTR.
839
2518bf37
JO
840Wed Feb 3 13:55:33 1993 Jeffrey Osier (jeffrey@fowanton.cygnus.com)
841
842 * Makefile.in: created info, install-info, dvi
843
dedfbe49
DZ
844Wed Jan 6 00:58:09 1993 david d `zoo' zuhn (zoo at cirdan.cygnus.com)
845
846 * Makefile.in: fix install rule for $(PROG)
847
03c08660
ME
848Fri Oct 9 11:25:41 1992 Mark Eichin (eichin@cygnus.com)
849
5489fcc3 850 * gprof.1: updated SYNOPSIS to match actual behavior.
03c08660 851
3d3e494e
PB
852Mon Oct 5 17:50:16 1992 Per Bothner (bothner@cygnus.com)
853
854 * gen-c-prog.awk: New awk script, lightly changed from
855 previously deleted make-c-prog.awk. Converts a text file
856 to a c function that prints that text.
857 * flat_bl.m, fsf_callg_bl.m, bsd_callg_bl.m: New files.
858 Inputs to gen-c-prog.awk, containing text describing
859 gprof output.
860 * blurbs.c: Removed. Use *_bl.c instead.
861 * Makefile.in: Use gen-cprog.awk to generate *_bl.c files
862 from *_bl.m files. Also, improve *clean rules.
863 * printgprof.c (printgprof): Usw new function names from *_bl.c.
864
865
dc1d1ca5
PB
866Sun Aug 30 19:54:53 1992 Per Bothner (bothner@rtl.cygnus.com)
867
868 * gprof.h, gprof.c, printfgprof.c: Add support for two
869 output styles: The default is similar to the old FSF gprof,
870 while -T sets the variable bsd_style_output, which causes
871 output matching Berkeley's gprof. The biggest differences
872 are that with the FSF style output, the flat profile comes
873 before the call graph; numbers come before explanations;
874 and there is less gratuitous white space.
875 * gprof.h, gprof.c, printfgprof.c: New discard_underscores
876 variable causes discarding of initial underscores when
877 printing symbol names. It is set unless there is a "main"
878 symbol (without an underscore).
879 * printfgprof.c: New function printnameonly(), called
880 by printname(). It handles stripping of initial '_',
881 as well as C++ name-demangling.
882 * gprof.callg, gprof.flat, make-c-prog.awk: Removed.
883 It is just as convenient to edit blurbs.c directly.
884 * Makefile.in: Removed rule for making blurbs.c.
885 * blurbs.c: This is now a true source file (as opposed
886 to being generated from gprof.callg and gprof.flat).
887 Change style to use one long string literal, instead of
888 one literal per output line. Add FSF-style blurb for call graph.
889
3c9c3ce3
ILT
890Wed Aug 19 14:36:39 1992 Ian Lance Taylor (ian@cygnus.com)
891
892 * Makefile.in: always create installation directories.
893
4be49df5
ME
894Wed Aug 12 15:14:14 1992 Mark Eichin (eichin@cygnus.com)
895
c3193400 896 * Makefile.in: change ${MACHINE} to $(MACHINE).
4be49df5 897
ea2b679c
DZ
898Sun Jul 19 17:34:01 1992 david d `zoo' zuhn (zoo at cirdan.cygnus.com)
899
900 * Makefile.in: removed installation of the now useless
901 call.{flag,callg} files.
902
903 * gprof.1: now uses the standard man macros instead of the new BSD
904 mandoc macros.
905
a4ea3274
JG
906Sun Jul 12 19:06:00 1992 John Gilmore (gnu at cygnus.com)
907
5d32c952
JG
908 * configure.in: Remove host section, expand target section.
909 * config/mt-{tahoe,vax}: Add, to match existing support files.
910 * config/tmake-*: Remove leftover crud.
911
a4ea3274
JG
912 * blurbs.c: New file, created from gprof.flat and gprof.callg by
913 * make-c-prog.awk: which processes text files into C programs.
914 * printgprof.c (flatprofheader, gprofheader): Call new functions
915 to print blurbs.
916 (printblurb): Remove.
917 * Makefile.in: Infrastructure to build blurbs.
918 * pathnames.h: has been removed. Gprof now has no filename
919 dependencies in it.
920 * gprof.c: Lint.
921
922Sat Jul 11 18:07:21 1992 david d `zoo' zuhn (zoo at cirdan.cygnus.com)
923
924 * Makefile.in: define man1dir and install the man page
925
926Fri Jul 10 21:14:08 1992 david d `zoo' zuhn (zoo@cygnus.com)
927
928 * Makefile.in: added dummy info and install-info targets
929
ba79f5fa
ME
930Thu Jun 4 11:34:02 1992 Mark Eichin (eichin at cygnus.com)
931
932 * lookup.c: fixed fencepost in nllookup and added dbg_nllookup for
933 help in debugging the problem (with -DDEBUG)
934 * gprof.c: symbol values are now real values, don't add the vma
935 anymore. (done for solaris; should verify this on other platforms)
936 * ChangeLog: created.