2001-12-31 Philippe Elie <ph_e@club-internet.fr> * module/op_init.c: * module/oprofile.c: export cpu type preparing for user space cpu detection change * module/oprofile.h: preparatory work to add support for preempt patch * pp/oprofpp.cpp: cleanup #if 0 ... #else ... #endif * pp/orofpp_util.cpp: allow to deduce image name from shared lib samples files name produced with --separate-samples * gui/oprof_start.cpp: minor fix 2001-12-31 John Levon <moz@compsoc.man.ac.uk> * various files: use op_cpu enum for cpu type * all .cvsignore: * Rules.make.in: * all Makefile.in: hide .d files in .deps directories 2001-12-31 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: move config.h.in to maintainerclean - it is included in a tarball so a distclean shouldn't remove it 2001-12-31 John Levon <moz@compsoc.man.ac.uk> * TODO: update * gui/ui/oprof_start.base.ui: * doc/oprofile.sgml: * doc/oprofile.1.in: small updates * oprofile.c: more detail on locking requirements for wake_up 2001-12-31 Michel Dagenais <michel.dagenais@polymtl.ca> * gui/oprof_start.cpp: * gui/oprof_start.h: show total samples so far 2001-12-29 Philippe Elie <ph_e@club-internet.fr> * dae/oprofiled.c: * dae/op_start: --separate-samples is working * gui/oprof_start.cpp: * gui/oprof_start_config.cpp: * gui/oprof_start_config.h: * gui/ui/oprof_start.base.ui: handle separating for shared libs, off by default. * doc/oprofile.sgml: * doc/oprofile.1.in: document --show-shared-libs * pp/opf_filter.h: * pp/opf_container.cpp: new class samples_files_t to easier access to subset of symbols/samples or source filename from multiple image * pp/Makefile.in: * pp/op_time.cpp: * pp/opf_filter.cpp: * pp/oprofpp.cpp: * pp/oprofpp.h: * pp/oprofpp_util.cpp: implement --show-shared-libs except for opf_filter * util/file_manip.h: * util/file_manip.cpp: new function to manipulate sample file name and list of sample file name. 2001-12-27 Philippe Elie <ph_e@club-internet.fr> * dae/op_stop: always do an op_dump before stopping * gui/oprof_start.cpp: op_dump before op_stop no longer required 2001-12-26 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.cpp: * pp/opf_filter.h: * pp/oprofpp.h: * pp/opf_filter.cpp: * pp/oprofpp_util.cpp: * pp/oprofpp.cpp: * pp/op_time.c: remove some use of global var samplefile and imagefile * pp/oprofpp.cpp: do_dump_gprof() free memory too soon. (was bugged from 2001-12-05) * doc/oprofile.sgml: remove mention about oprof-thread 2001-12-23 Philippe Elie <ph_e@club-internet.fr> * util/string_manip.h: * util/string_manip.cpp: separate_token() new function * pp/opf_filter.cpp: * pp/oprofpp.cpp: * pp/oprofpp.h: * pp/oprofpp_util.cpp: * doc/oprofil.1.in: * doc/oprofile.sgml: add support for --exclude-symbol * TODO: update 2001-12-22 Philippe Elie <ph_e@club-internet.fr> * dae/op_start: add --separate-samples * dae/oprofiled.c: ditto * dae/opd_proc.c: * dae/opd_util.h: * dae/opd_util.c: * dae/oprofiled.h: implementation of above * pp/op_time.cpp: * doc/oprofile.1.in: * doc/oprfile.sgml: handle and document above * pp/oprofpp_util.cpp: minor change related * dae/oprofiled.c: bug fix while blocking signal * doc/Makefile.in: avoid unecessary build of html doc 2001-12-22 Dave Jones <davej@suse.de> * config.h.in: Readd to CVS. 2001-12-18 Dave Jones <davej@suse.de> * Makefile.in: Make documentation build again. 2001-12-14 Philippe Elie <ph_e@club-internet.fr> * dae/opd_proc.c: memory leak fix in opd_init_images() 2001-12-12 Philippe Elie <ph_e@club-internet.fr> * module/oprofile.h: change slightly op_hash() * util/file_manip.h: * util/file_manip.cpp: * util/string_manip.h: * util/string_manip.cpp: * util/child_reader.h: * util/child_reader.cpp: cleanup John's FIXME * dae/opd_util.h: * dae/opd_util.c: move libiberty things to ... * util/misc.h: * util/misc.c: here * util/Makefile.in: update * dae/Makefile.in: * pp/Makefile.in: * doc/Makefile.in: install the html doc 2001-12-10 John Levon <moz@compsoc.man.ac.uk> * dae/oprofiled.c: fix sigprocmask() blooper 2001-12-09 John Levon <moz@compsoc.man.ac.uk> * TODO: update again * util/child_reader.h: * util/child_reader.cpp: * util/file_manip.cpp: * util/string_manip.cpp: pedantic cleanup + FIXMEs 2001-12-09 John Levon <moz@compsoc.man.ac.uk> * configure.in: add FIXME comment * util/file_manip.h: add FIXME comment, avoid warning with // 2001-12-09 John Levon <moz@compsoc.man.ac.uk> * TODO: update 2001-12-09 Philippe Elie <ph_e@club-internet.fr> * dae/opd_proc.c: verbprintf() what cause the deletion of a sample file + minor cleanup * doc/oprofile.sgml: document samples files backup 2001-12-07 Philippe Elie <ph_e@club-internet.fr> * dae/oprofiled.h: * dae/opd_proc.c: handle an accessed field of deleted of deleted procs to defer deleting the procs. This greatly reduce the Nr of lost samples due to no proc information. 2001-12-06 Philippe Elie <ph_e@club-internet.fr> * dae/oprofiled.h: * dae/opd_proc.c: separate stats for kernel and modules address space and minor cleanup 2001-12-05 Philippe Elie <ph_e@club-internet.fr> * Rules.make.in: * dae/Makefile.in: * events/Makefile.in: * pp/Makefile.in: * util/Makefile.in: tidy * module/Makefile.in: * gui/Makefile.in: use auto-deps * util/child_reader.h: allow to compile with -ansi * util/child_reader.cpp: fix memory leak fix * pp/oprofpp.cpp: fix memory leak * TODO: update 2001-12-05 Philippe Elie <ph_e@club-internet.fr> * autogen.sh: use autoheader to create config.h * configure.in: handle missing libiberty.h and missing xcalloc in libiberty.a * dae/opd_util.cpp: * dae/opd_proc.c: * dae/opd_util.h: * dae/oprofiled.c: * evets/Makefile.in * pp/oprof_convert.c: * pp/oprofpp.cpp: * pp/oprofpp_util.cpp: replace opd_malloc() and related by xmalloc. * util/op_popt.c: add call to xmalloc_set_program_name() * ./cvsignore: add config.h, config.h.in 2001-12-04 Dave Jones <davej@suse.de> * events/op_events_desc.c: Add recognition for alternative PIII string. Reported by Lev Iserovich <lev@ciprico.com> 2001-12-04 Philippe Elie <ph_e@club-internet.fr> * dae/opd_util.c: * dae/opd_util.c: move common fuctionnality to ... * util/file_manip.h * util/file_manip.c: here * pp/oprof_convert.c: reflect above change * pp/oprof_convert.c: * pp/opf_filter.cpp: ditto + minor cleanup * gui/Makefile.in: * pp/Makefile.in: reflect above change 2001-12-02 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp.h: * pp/oprofpp.cpp: * pp/oprofpp_util.cpp: * pp/opf_filter.cpp: small tidies 2001-12-01 Philippe Elie <ph_e@club-internet.fr> * Makefile.in: build util sub-dir first * dae/opd_util.h: * dae/opd_util.c: move opd_GetContext() ... * util/opd_popt.h: * util/opd_popt.c: in these new files * pp/oprofpp.cpp: * pp/opf_filter.cpp: * pp/op_time.cpp: * dae/oprofiled.c: free the poptContext + cleanup popt * events/op_help.c: * events/Makefile.in: use the popt library * pp/oprofpp.cpp: allow to use --output-linenr-info with --list-symbols. * doc/oprofile.1.in: * doc/oprofile.sgml: reflect it 2001-12-01 Philippe Elie <ph_e@club-internet.fr> * dae/opd_proc.c: * dae/opd_util.c: * dae/opd_util.h: * dae/oprofiled.c: backup if needed old samples files in a separate directory * pp/oprofpp.h: * pp/oprofpp_util.cpp: cleanup + minor buglet fix * util/file_manip.h: * util/file_manip.cpp: create_file_list() new to create a list of all the file in a directory * pp/op_time.cpp: new utility * pp/Makefile.in: handle op_time * doc/oprofile.sgml: * doc/oprofile.1.in: Document op_time 2001-11-30 Philippe Elie <ph_e@club-internet.fr> * configure.in: cvs add Rules.make.in. 2001-11-30 Dave Jones <davej@suse.de> * configure.in: suppress reference to an inexistant Rules.make.in 2001-11-29 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp_util.cpp: do not remove leading underscore to avoid C++ demangling failure 2001-11-27 Philippe Elie <ph_e@club-internet.fr> * configure.in: * pp/Makefile.in: work-around for gcc 3.0 and bfd pre-1998 * doc/oprofile.sgml: typo 2001-11-26 Philippe Elie <ph_e@club-internet.fr> * Rules.make.in: new to add autodeps and share commons definitions * all Makefile.in except module, gui: use autodeps * doc/oprofile.1.in: typo * util/filemanip.h: missing std:: 2001-11-25 Philippe Elie <ph_e@club-internet.fr> * oprofile-tests/understanding/persistent.cpp: new * util/persistent.h: new. An attempt to provide a better configuration saving/restoring library. Not yet linked to oprof_start. 2001-11-22 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp_util.cpp: take care than get_linenr() get line nr and filename info from bfd for the right symbol and not for the nearest symbol with debug info (#484660) 2001-11-15 Philippe Elie <ph_e@club-internet.fr> * module/oprofile.h: work around against a gcc 2.91.66 code generation bug in oprof_exit() 2001-11-14 Philippe Elie <ph_e@club-internet.fr> * dae/op_start: do not pass bufsize, note_bufsize and kernel_only as option to the daemon but ... * dae/oprofiled.c: read them from sysctl * dae/opd_proc.c: in opd_handle_old_sample_file() do not delete sample file if mtime differ but backup it. * doc/oprofile.sgml: * pp/oprof_convert.c: * pp/oprofpp_util.cpp: replace session number by backup number * util/string_manip.cpp: fix stupid bug in rtrim() 2001-11-13 Philippe Elie <ph_e@club-internet.fr> * gui/oprof_start.h: * gui/oprof_start.cpp: * dae/opd_util.h: * dae/opd_util.cpp: small cleanup * module/oprofile.c: simplify a little what the nmi handler * doc/oprofile.sgml: clarify op_to_source options * pp/child_reader.cpp: * pp/child_reader.h: move these ... * util/child_reader.cpp: * util/child_reader.h: here * util/file_manip.h: * util/file_manip.cpp: new * gui/Makefile.in: * gui/oprof_start_util.h: * gui/oprof_start_util.cpp: * pp/Makefile.in: * pp/opf_filter.cpp: use child_reader and file_manip * pp/oprofpp_util.cpp: change ordering of opening in opp_bfd ctr to avoid cryptic error message * TODO: update 2001-11-12 Philippe Elie <ph_e@club-internet.fr> * events: new directory * events/Makefile.in: * events/op_events.c: * events/op_events_desc.c: * events/op_help.c: new, splitted from op_events.c * pp/oprofpp_util.cpp: new, splitted from oprofpp.cpp * pp/oprofpp.h: * pp/oprofpp.c: * op_user.h: * all Makefile.in: update * op_events.c: remove 2001-11-12 Philippe Elie <ph_e@club-internet.fr> * op_events.c: last commit was bad * pp/oprofpp.c: use sstream 2001-11-12 Philippe Elie <ph_e@club-internet.fr> * util: new directory * util/string_manip.cpp: * util/string_manip.h: new * Makefile.in: handle util directory * pp/Makefile.in: * pp/opf_filter.h: * pp/opf_filter.cpp: * gui/Makefile.in: * gui/oprof_start_util.cpp: * gui/oprof_start_util.h: update to use string_manip.cpp * op_events.c: * op_user.h: * pp/opf_filter.h: * pp/opf_filter.cpp: * pp/opf_container.cpp: remove dead code 2001-11-11 Dave Jones <davej@suse.de> * module/oprofile.[c|h]: Change MSR defines from MSR_IA32_xxx from MSR_P6_xxx, based on info on Linux kernel from Mikael Pettersson that these MSRs don't exist on Pentium 4. 2001-11-11 Philippe Elie <ph_e@club-internet.fr> * gui/oprof_start.cpp: fix record_config() * op_user.h: fix one comment 2001-11-10 Bob Montgomery <bob_montgomery@hp.com> * module/oprofile.c: fix pid/pgrp filter to reset counter 2001-11-08 John Levon <moz@compsoc.man.ac.uk> * TODO: update * configure.in: bump to 0.0.8cvs 2001-11-07 John Levon <moz@compsoc.man.ac.uk> * acinclude.m4: * configure.in: fixes for configuration when Qt2 not found * child_reader.h: * child_reader.cpp: compile with gcc 3.0 2001-11-07 John Levon <moz@compsoc.man.ac.uk> * configure.in: bump to 0.0.7 2001-11-07 John Levon <moz@compsoc.man.ac.uk> * configure.in: * module/oprofile.h: * module/oprofile.c: fail if hard_get_current() exists - this won't work 2001-11-06 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.1.in: reformat options * doc/oprofile.sgml: clarify options that require argument. Document short option * gui/oprof_start_util.cpp: fix basename() * pp/oprofpp.cpp: * pp/oprofpp.h: * pp/opf_filter.cpp: better options handling * module/oprofile.c: update one comment * TODO: update 2001-11-06 John Levon <moz@compsoc.man.ac.uk> * configure.in: * module/oprofile.h: * module/oprofile.c: support for hard_get_current() 2001-11-06 John Levon <moz@compsoc.man.ac.uk> * module/oprofile.h: * module/oprofile.c: make allow_unload exist for UP too (default to 1) 2001-11-05 John Levon <moz@compsoc.man.ac.uk> * TODO: update * module/oprofile.c: fix nr_interrupts sysctl 2001-11-04 Philippe Elie <ph_e@club-internet.fr> * dae/op_start: * gui/oprof_start.cpp: * gui/oprof_start_config.cpp: * gui/oprof_start_config.h: * gui/ui/oprof_start.base.ui: handle note table size sysctl * module/op_syscalls.c: handle dname hash coding collision with a linear search. * module/oprofile.c: * module/oprofile.h: * module/op_syscalls.c: Use a struct to hold the whole sysctl settable things rather global var. 2001-11-03 Philippe Elie <ph_e@club-internet.fr> * modules/oprofile.h: add a sysctl struct to hold all sysctl set-able variable * modules/oprofile.c: two bugs fixes. 2001-11-02 Philippe Elie <ph_e@club-internet.fr> * modules/oprofile.h: minor cleanup * modules/oprofile.c: better handling of irq statistics 2001-10-31 John Levon <moz@compsoc.man.ac.uk> * module/oprofile.c: add comment about unfixable races. 2001-10-30 John Levon <moz@compsoc.man.ac.uk> * Move module code into module/ subdir. Bye bye CVS history :/ 2001-10-30 John Levon <moz@compsoc.man.ac.uk> * op_x86.c: complain properly about lAPIC-less machines 2001-10-26 John Levon <moz@compsoc.man.ac.uk> * TODO: update 2001-10-26 H. J. Lu <hjl@users.sf.net> * Makefile.in: use $(LD) not ld 2001-10-25 Philippe Elie <ph_e@club-internet.fr> * configure.in: fix version.h checking for gcc 2.91.66 2001-10-25 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: * doc/Makefile.in: * dae/Makefile.in: * pp/Makefile.in: * gui/Makefile.in: add $DESTDIR to prefix (part from H.J. Lu) 2001-10-25 H. J. Lu <hjl@users.sf.net> * configure.in: better version.h workaround * doc/*.1: * doc/Makefile.in: better .so manpage install 2001-10-25 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.sgml: minor change. * pp/opf_filter.cpp: repair short option -a and -s 2001-10-24 Philippe Elie <ph_e@club-internet.fr> * pp/op_to_source: remove from cvs * pp/Makefile.in: opf_filter application renamed to op_to_source * pp/child_reader.h: new * pp/child_reader.cpp: new, allow to fork a child and read its stdout/stderr * pp/opf_filter.h: * pp/opf_filter.cpp: use child_reader to launch objdump. op_to_source -a and -s must be specified with long form --assembly and --source-with-assembly. This also speed-up assembly output. Doc not updated. 2001-10-18 John Levon <moz@compsoc.man.ac.uk> * configure.in: workaround #2, hopefully fixing Mandrake (bug #471448) 2001-10-17 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: don't mask when restoring MSR values * doc/Makefile.in: don't use man symlinks 2001-10-17 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: save original counter setup and restore on unload (bug #464094) 2001-10-16 John Levon <moz@compsoc.man.ac.uk> * configure.in: * oprofile.h: workaround for Mandrake randomly back-porting things. 2001-10-16 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: * gui/oprof_start.cpp: * gui/oprof_start_config.cpp: * gui/oprof_start_config.h: * gui/oprof_start_util.cpp: * pp/opf_container.cpp: * pp/opf_filter.h: * pp/opf_filter.cpp: * pp/oprof_convert.cpp: add note device to gui, general cleanup 2001-10-16 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: fix likely() macro 2001-10-14 John Levon <moz@compsoc.man.ac.uk> * TODO: update * op_syscalls.c: * op_user.h: * oprofile.h: * oprofile.c: * dae/op_start: * dae/opd_proc.c: * dae/oprofiled.h: * dae/oprofiled.c: use a separate map buffer. 2001-10-14 John Levon <moz@compsoc.man.ac.uk> * acinclude.m4: don't give up if we can't find moc 2001-10-14 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: merge no-thread code 2001-10-14 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: * dae/oprofiled.c: * op_user.h: * oprofile.h: * op_syscalls.c: use string pool. Prime hash table with common entries. Consider parent in name_hash. 2001-10-13 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.sgml: minor change * pp/opf_filter.cpp: better warning 2001-10-13 John Levon <moz@compsoc.man.ac.uk> * configure.in: 0.0.6 has been released -> 0.0.7cvs 2001-10-12 John Levon <moz@compsoc.man.ac.uk> * TODO: update * doc/oprofile.sgml: new docs for annotation filter 2001-10-12 John Levon <moz@compsoc.man.ac.uk> * pp/opf_filter.cpp: make output filters more like diff (needs doc), briefer info message 2001-10-12 John Levon <moz@compsoc.man.ac.uk> * doc/Makefile.in: add FIXME * gui/oprof_start.cpp: fix std:: * acinclude.m4: more fixes 2001-10-12 Philippe Elie <ph_e@club-internet.fr> * gui/oprof_start_util.cpp: use select() rather non-blocking mode to read output from the child process 2001-10-11 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.sgml: * doc/oprofile.1.in: * pp/opf_filter: make --output and --no-output more intuitive 2001-10-09 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.sgml: * doc/oprofile.1.in: clarify doc * pp/opf_filter.cpp: corner case fix in --output-dir and --source-dir handling. 2001-10-08 John Levon <moz@compsoc.man.ac.uk> * acinclude.m4: * configure.in: * gui/Makefile.in: fix idiot config bug of mine 2001-10-06 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.cpp: * pp/op_to_source: small cleanup 2001-10-05 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.1.in: * doc/oprofile.sgml: * pp/op_to_source: * pp/opf_filter.cpp: implement --output and --no-output to allow output file generation filtering 2001-10-04 John Levon <moz@compsoc.man.ac.uk> * TODO: update 2001-10-03 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.1.in: * doc/oprofile.sgml: * pp/op_to_source: * pp/opf_filter.cpp: implement --source-dir and --output-dir to generated separated annoted source file. 2001-10-03 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp.cpp * pp/oprofpp.h * pp/opf_filter.cpp: minor cleanup 2001-10-03 John Levon <moz@compsoc.man.ac.uk> * TODO: update * Makefile.in: remove generated files on make distclean * acinclude.m4: update from source 2001-10-02 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp.cpp: fix a silly bug in do_list_symbols (oprofpp -l) 2001-10-02 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: fix * Makefile.in: dist fix 2001-10-02 John Levon <moz@compsoc.man.ac.uk> * TODO: update * configure.in: -> 0.0.5 for release 2001-10-01 Philippe Elie <ph_e@club-internet.fr> * pp/opf_container.cpp: * pp/opf_filter.h: comment * pp/opf_filter.cpp: speed-up 2001-09-30 Philippe Elie <ph_e@club-internet.fr> * pp/opf_container.cpp: * pp/opf_filter.cpp: * pp/oprofpp.cpp: * pp/oprofpp.h: cleanup 2001-09-30 Philippe Elie <ph_e@club-internet.fr> * gui/oprof_start.cpp: * gui/oprof_start.h: * gui/ui/oprof_start.base.ui: cleanup 2001-09-29 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.cpp: check if we need debug info to work. * gui/oprof_start.cpp: use one config file by counter. Store selected counter in oprof_start_config * gui/oprof_start.cpp: * gui/persistent_config.h: remove dirty flag in persistent_config_t template class 2001-09-29 John Levon <moz@compsoc.man.ac.uk> * TODO: update * gui/oprof_start.cpp: * gui/ui/oprof_start_base.ui: * gui/oprof_start_config.h: * gui/oprof_start_config.cpp: add verbose option * pp/opf_container.cpp: * pp/opf_filter.cpp: some FIXMEs and little cleanups 2001-09-29 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp.cpp: bug fix when calling the bfd lib. 2001-09-29 Philippe Elie <ph_e@club-internet.fr> * gui/oprof_start.cpp: two minor fixes. 2001-09-28 John Levon <moz@compsoc.man.ac.uk> * various files: the footer is now a header ! * dae/opd_start.c: fix msync !! * gui/oprof_start.cpp: * gui/oprof_start_util.h: * gui/oprof_start_util.cpp: better default event count value. Save CPU type to oprofile file. 2001-09-28 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.c: fix op_to_source [-a] [-s] 2001-09-28 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.sgml: oops, correct bad merging with John's last update. 2001-09-27 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.1.in: minor change * op_events.c: remove --gui-description stuff * pp/opf_filter.cpp: remove use of temporary array to pass argument to the popt library 2001-09-27 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: updates * gui/oprof_start_util.cpp: fix compile, revert g++ extension (different on g++ 3.0) 2001-09-27 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start_util.cpp: use g++ extension to avoid using temporary files 2001-09-27 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start_util.cpp: fix crasher bug 2001-09-27 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start.h: * gui/oprof_start.cpp: get per-counter config working 2001-09-27 John Levon <moz@compsoc.man.ac.uk> * pp/Makefile.in: * pp/oprofpp.c: * pp/oprofpp.cpp: rename file 2001-09-27 John Levon <moz@compsoc.man.ac.uk> * pp/opf_container.cpp: * pp/oprofpp.h: * pp/oprofpp.c: speed improvements 2001-09-26 Philippe Elie <ph_e@club-internet.fr> * configure.in: typo * pp/oprofpp.c: fix oprofpp -s. Use std::string (work not yet finish) * pp/oprofpp.h: ditto * pp/opf_filter.cpp: ditto 2001-09-26 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: add nr_interrupts * gui/oprof_start.h: * gui/oprof_start.cpp: * gui/oprof_start_util.h: * gui/oprof_start_util.cpp: * gui/oprof_start_config.h: * gui/oprof_start_config.cpp: * gui/ui/oprof_start_base.ui: add daemon status display, fix basename() 2001-09-26 John Levon <moz@compsoc.man.ac.uk> * configure.in: remove broken bit * pp/Makefile.in: fix options * doc/oprofile.sgml: minor changes 2001-09-26 Philippe Elie <ph_e@club-internet.fr> * pp/Makefile.in: increase level of warning * pp/oprof_convert.c: minor fix to avoid warning * dae/opd_util.c: ditto * pp/oprofpp.c: get_linenr() never return null in filename (fix bug #464482). symcomp() ensure correct vma comparison (fix #464093) * dae/opd_util.c: minor fixe in op_poptGetContext() * gui/oprof_start.cpp: minor cleanup 2001-09-25 John Levon <moz@compsoc.man.ac.uk> * dae/op_stop: * gui/oprof_start_config.cpp: use pidof instead 2001-09-25 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start_config.cpp: fix is_profiler_started() too 2001-09-25 John Levon <moz@compsoc.man.ac.uk> * dae/op_stop: fix terribly stupid error 2001-09-25 John Levon <moz@compsoc.man.ac.uk> * op_event.c: whooops 2001-09-25 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start.cpp: std:: fix * dae/op_start: * op_events.c: robustness fix 2001-09-25 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start.cpp: fix silly bug 2001-09-24 John Levon <moz@compsoc.man.ac.uk> * pp/opf_filter.cpp: "fix" compile error 2001-09-24 John Levon <moz@compsoc.man.ac.uk> * gui/oprofile: * gui/Makefile.in: remove old gui 2001-09-24 John Levon <moz@compsoc.man.ac.uk> * dae/op_start: make a little more robust 2001-09-24 John Levon <moz@compsoc.man.ac.uk> * include/sstream: * Makefile.in: * configure.in: * pp/Makefile.in: * gui/Makefile.in: configure/make fixes * op_events.c: re-order for Athlon 2001-09-23 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.c: small cleanup 2001-09-23 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: * op_x86.c: support for 2.4.10 2001-09-23 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start.h: * gui/oprof_start.cpp: rework validator stuff a bit 2001-09-23 John Levon <moz@compsoc.man.ac.uk> * gui/oprof_start.cpp: use std::find_if * gui/oprof_start_config.cpp: * gui/oprof_start_util.cpp: minor tidies 2001-09-23 John Levon <moz@compsoc.man.ac.uk> * dae/op_dump: * dae/op_start: echo errors to stderr * gui/oprof_start_util.h: * gui/oprof_start_util.cpp: * gui/oprof_start.cpp: use fork/exec to spawn children 2001-09-23 John Levon <moz@compsoc.man.ac.uk> * TODO: update * gui/Makefile.in: * gui/oprof_start_config.h: * gui/oprof_start_config.cpp: * gui/oprof_start_util.h: * gui/oprof_start_util.cpp: * gui/oprof_start.h: * gui/oprof_start.cpp: new file for util functions 2001-09-23 John Levon <moz@compsoc.man.ac.uk> * dae/opd_util.c: * dae/opd_util.h: * dae/oprofiled.c: * pp/oprofpp.c: * pp/opf_filter.cpp: * configure.in: enable __builtin_expect, fix popt problem * pp/oprof_convert.c: small fixes * op_events.c: shorten event descriptions for GUI * gui/*: many more updates * pp/Makefile.in: fix 2001-09-21 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: removed over-verbose line * configure.in: * oprofile.h: * oprofile.c: add likely/unlikely, take note lock on dump 2001-09-21 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.h: move declaration of counter_array_t to * pp/oprofpp.h: here * pp/oprofpp.c: define and use counter_array_t + minor cleanup * pp/opf_filter.cpp: remove definition of counter_array_t 2001-09-21 Philippe Elie <ph_e@club-internet.fr> * Makefile.in: remove aclocal.m4 in distclean * pp/Makefile.in: use $(CXX) and $(CXXFLAGS) * pp/opf_container.cpp: * pp/opf_filter.cpp: * pp/opf_filter.h: * pp/oprofpp.c: * pp/oprofpp.h: cleanup 2001-09-20 Philippe Elie <ph_e@club-internet.fr> * Makefile.in: minor change in module building * pp/Makefile.in: link oprofpp with opf_filter * pp/op_to_source: avoid pipe from oprofpp to opf_filter * pp/opf_filter.h: remove a few member function * pp/opf_container.cpp: ditto + minor cleanup * pp/opf_filter.cpp: oprofpp is no longer piped to opf_filter but linked with it. Many change, needs additional cleanup * pp/oprofpp.c: group all stuff in two class. Rather a a C with class than a full C++ file for now. Fix a bug in filename handling. * pp/oprofpp.h: add opp_bfd and opp_samples_files class. * dae/opd_util.c: add a few explicit cast for C++ compile * dae/opd_util.h: wrap function declaratio with extern "C" 2001-09-19 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: fix silly read valid bug 2001-09-19 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: whoops, missed op_util.o from build 2001-09-19 John Levon <moz@compsoc.man.ac.uk> * dae/oprofiled.c: fix little bug, tidy a bit * TODO: update 2001-09-18 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: * op_syscalls.c: * op_util.c: * oprofile.h: move some code around * oprofile.c: fix a tiny bug 2001-09-18 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: * dae/oprofiled.h: implement hashing of images * doc/oprofile.sgml: fix -- issue and use <screen> 2001-09-18 John Levon <moz@compsoc.man.ac.uk> * .cvsignore: * README: update * configure.in: small cleanup * op_init.c: add comment * oprofile.h: * op_syscalls.c: * op_x86.c: move fixmap stuff, remove disable APIC * oprofile.c: init failure fix * doc/oprofile.sgml: * dae/opd_proc.c: fix handle_old_sample_files() bug, check mtime hasn't changed on a new map 2001-09-16 John Levon <moz@compsoc.man.ac.uk> * acinclude.m4: * autogen.sh: * configure.in: * gui/Makefile.in: * gui/ui/Makefile.in: * gui/ui/oprof_start.base.ui: * gui/oprof_start.h: autoconfiscation for Qt2 * gui/oprof_start_config.cpp: add comments 2001-09-16 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.cpp: fix unrecognized input * pp/opf_container.cpp: better error messages. put op_nr_counters in the global namespace (gcc 2.91 work around) 2001-09-16 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.cpp: small tidy 2001-09-16 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.cpp: minor tidy * gui/oprof_start.base.ui: new oprof_start gui * gui/oprof_start.cpp: new, derived class of oprof_start_base * gui/oprof_start.h: ditto * gui/oprof_start_impl.cpp: implementation of oprof_start class * gui/oprof_start_config.cpp: utilities function for oprof_start * gui/oprof_start_config.h: ditto * gui/persistent_config.h: utility template * gui/oprof_start_main.cpp: main() for oprof_start * gui/Makefile.in: handle this stuff 2001-09-15 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.c: some cleanup 2001-09-15 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.c: allow non-matching mtimes in order to allow pp on different machines. Make conflicting counter specifications a fatal error 2001-09-15 John Levon <moz@compsoc.man.ac.uk> * all Makefile.in: install should depend on all * pp/oprofpp.c: fixes for Athlon 4 counters. Enable debug info for list-symbol. Some stricter checking 2001-09-15 Philippe Elie <ph_e@club-internet.fr> * op_events.c: some static variable to global * op_user.h: export these * oprofile.c: typo in comment * dae/opd_proc.c: fix size of samples files 2001-09-13 Dave Jones <davej@suse.de> * doc/oprofile.1.in: Update so it doesn't say 'Intel only' * dae/op_start: Fix output so that it prints [0-3] instead of [0-4[ 2001-09-12 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp.c: fix cpu type output for opf_filter * dae/op_stop: return error code properly 2001-09-12 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.c: print name of cpu type * dae/op_stop: * dae/op_start: re-organise, tidy 2001-09-12 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: fix small but triggerable SMP dump race 2001-09-12 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: * oprofile.c: * op_x86.c: move some code about * op_syscalls.c: add comment 2001-09-12 John Levon <moz@compsoc.man.ac.uk> * configure.in: remove warning * op_user.h: * op_events.c: fix and clean up cpu type detection * op_init.c: fix email * oprofile.c: add IRQ stats. Not sure whether to keep... 2001-09-12 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: * oprofile.c: use cpu_number_map (pedantry thing) 2001-09-07 Philippe Elie <ph_e@club-internet.fr> * oprofile.c: remove /proc/.../cpu_type. Check if user mode cpu type detection is identical to module cpu type * op_events.h: * op_events.c: add op_get_cpu_type(). script can get cpu_type by op_help --get-cpu-type * gui/oprofile: use it * dae/oprofiled.c: ditto * dae/op_start: ditto, pass expected_cpu_type to module * doc/oprofile.sgml: update * doc/oprofile.1.in: update * pp/oprofpp.c: get cpu_type from samples file * pp/opf_filter.cpp: get cpu type from stdin 2001-09-06 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: use j not i in msync ! 2001-09-06 John Levon <moz@compsoc.man.ac.uk> * dae/op_start: more sanity checking of options 2001-09-06 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: update a bit 2001-09-06 John Levon <moz@compsoc.man.ac.uk> * <most files>: make op_nr_counters a var (no pp support for > 2 yet) * dae/oprofiled.c: don't print help when counter event etc. are wrong 2001-09-06 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: * oprofile.c: use MODULE_LICENSE 2001-09-06 John Levon <moz@compsoc.man.ac.uk> * op_user.h: add missing prototype * dae/op_start: fix counter extraction 2001-09-05 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp.c: fix a few corner case, cleanup. * dae/opd_proc: ditto. * dae/op_start: better handling of counter number * dae/opd_proc: minor change. * op_user.h: enable support for four counters * oprofile.c: ditto. Split functions * op_events.c: expose op_get_cpu_type_str(int) to world. 2001-09-04 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: * oprofile.c: don't restore delivery mode to LVTPC (causes APIC error on SMP). Fix for silly sem hang with do_dump 2001-09-04 John Levon <moz@compsoc.man.ac.uk> * dae/op_start: fix typo bug 2001-09-04 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: some small tidies 2001-09-04 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: change lvtpc_apic_restore to be more careful ! 2001-09-02 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: don't allow unload on SMP unless allow_unload is set. Still needs docs (no point till SMP works). 2001-09-02 John Levon <moz@compsoc.man.ac.uk> * dae/op_dump: complain if not root more clearly. 2001-09-02 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: remove bogus setting for NMI oopser. smp_apic_restore() -> lvtpc_apic_restore() 2001-09-01 Philippe Elie <ph_e@club-internet.fr> * oprofile.c: fix pmc_setup() * pp/Makefile.in: * dae/Makefile.in: fix uninstall problem 2001-08-31 Philippe Elie <ph_e@club-internet.fr> * oprofile.h: * dae/oprofiled.h: * op_user.h: * oprofpp.h: * dae/opd_util.h: share commmon declarations, put it in op_user.h, include op_user.h in other .h when necessary. * op_events.c: * all Makefile.in: update dependancies. 2001-08-30 Philippe Elie <ph_e@club-internet.fr> * oprofile.c: use loop instead of fixed counter number 2001-08-26 Philippe Elie <ph_e@club-internet.fr> * op_events.c: add option to op_help for the gui * gui/oprofile: use op_help to build description of events, accept Athlon (only 2 counters) 2001-08-25 Philippe Elie <ph_e@club-internet.fr> * pp/oprofpp.c: * dae/op_start: use loop instead of fixed number of counter. 2001-08-24 Philippe Elie <ph_e@club-internet.fr> * pp/oprof_convert.c: add v4 --> v5 conversion 2001-08-23 Philippe Elie <ph_e@club-internet.fr> * oprofile.c: correct some comment. 2001-08-22 Philippe Elie <ph_e@club-internet.fr> * op_user.h: * dae/opd_proc.c: * dae/opd_util.c: * dae/opd_util.h: * dae/oprofiled.h: * dae/oprofiled.c: * dae/oprofiled.c: row to column file format, lot of changes. 2001-08-21 Philippe Elie <ph_e@club-internet.fr> * op_events.c: Add Athlon string/unit maks description 2001-08-20 Philippe Elie <ph_e@club-internet.fr> * op_events.c: change in handling of search/check events * dae/oprofiled.c: * dae/oprofiled.h: * oprofile.c: * oprofile.h: * pp/oprofpp.c: * pp/oprofpp.h: reflects caller/prototype, lot of changes. 2001-08-31 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: * op_x86.c: * oprofile.h: * oprofile.c: a prototype detector for SMP hardware, some small cleanup 2001-08-20 Dave Jones <davej@suse.de> * doc/oprofile.sgml: Updated to reflect new Athlon/Duron capabilities. * pp/oprof_convert.c: * pp/oprofpp.c: use EXIT_FAILURE | EXIT_SUCCESS in exit() calls. * oprofile.c: Make non-exported functions static and remove duplicate definitions. 2001-08-19 John Levon <moz@compsoc.man.ac.uk> * dae/op_start: handle celeries in cpu type 2001-08-19 John Levon <moz@compsoc.man.ac.uk> * op_init.c: * oprofile.h: * oprofile.c: small tidies of the Athlon support 2001-08-19 Dave Jones <davej@suse.de> * op_events.c: * op_init.c: * oprofile.h: * oprofile.c: * dae/op_start: * dae/oprofiled.h: * dae/oprofiled.c: initial Athlon support 2001-08-19 Philippe Elie <ph_e@club-internet.fr> * oprofile.c: use symbolic constant for all apic setup, no generated code change 2001-08-18 Philippe Elie <ph_e@club-internet.fr> * Makefile.in: * dae/Makefile.in: * pp/Makefile.in: * doc/Makefile.in: * gui/Makefile.in: add uninstall target 2001-08-18 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: tiny cleanup 2001-08-17 Philippe Elie <ph_e@club-internet.fr> * dae/opd_proc.c: * TODO: minor cleanup. 2001-08-16 Philippe Elie <ph_e@club-internet.fr> * gui/oprofile: * dae/op_start: * doc/oprofile.1.in: document and use op_dump 2001-08-16 John Levon <moz@compsoc.man.ac.uk> * configure.in: bump version to 0.0.5cvs 2001-08-16 John Levon <moz@compsoc.man.ac.uk> * all Makefile.in: mkdir install files 2001-08-15 Philippe Elie <ph_e@club-internet.fr> * dae/opd_proc.c: fix a FILE* leak in opd_get_ascii_maps() 2001-08-14 John Levon <moz@compsoc.man.ac.uk> * op_syscalls.c: don't return negative hashes ! revert dname len "fix" use a much better hash function * dae/opd_proc.c: protect against negative hashes 2001-08-14 John Levon <moz@compsoc.man.ac.uk> * op_syscalls.c: some small fixes * oprofile.c: add back unmasking code during set_gate, but only LVTPC 2001-08-11 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: 2.4.8 doesn't either. *sigh*. looks like we need some autoconfery :( 2001-08-11 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: 2.4.7-linus doesn't include the Andrew Morton complete_and_exit(). Hopefully this will make it into 2.4.8, I'm banking on this. 2001-08-11 John Levon <moz@compsoc.man.ac.uk> * dae/op_dump: * doc/oprofile.sgml: * dae/Makefile.in: a little utility for dumping 2001-08-11 Dave Jones <davej@suse.de> * oprofile.h: * oprofile.c: back-compat code and use of new struct completion for the thread 2001-08-11 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: corner case where an a miss against a full count, we were attributing wrong (reported by Bob Montgomery) 2001-08-11 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: use a simple cli/sti when installing the NMI handler. It should work and avoids the unmasking problem. 2001-08-10 John Levon <moz@compsoc.man.ac.uk> * dae/oprofiled.h: fix header include (from Dave Jones) * op_syscalls.c: * oprofile.c: fix undefined symbol (from Dave Jones) 2001-08-10 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: small tidy in apic setup 2001-08-02 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: fix mod unload race, small fixes * dae/op_start: make sysctl error actually appear * doc/oprofile.sgml: document need for modutils 2.4.6 * op_syscalls.c: fix stupid mod use count problem 2001-07-28 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: d'oh, fat-fingered a slow memleak in the a-ksymoops modules fix 2001-07-27 Philippe Elie <ph_e@club-internet.fr> * pp/oprof_convert.c: fix bug when conversion skip more than one version. 2001-07-27 John Levon <moz@compsoc.man.ac.uk> * doc/Makefile.in: ln -s -> ln -sf * dae/opd_util.c: actually include the right header * dae/opd_util.h: compile freestanding from oprofiled.h 2001-07-26 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: fix comment * doc/oprofile.sgml: document symbolless modules not working * dae/Makefile.in: * dae/opd_proc.c: * dae/oprofiled.h: catch modules with no symbols via query_module() and ignore samples for them quickly 2001-07-25 Philippe Elie <ph_e@club-internet.fr> * dae/op_start: beautify the output of op_start --help * pp/op_to_source: ditto. better argument checking. * pp/oprof_convert.c: * pp/oprofpp.h: * dae/oprofiled.h: fix problem with opd_footer, don't bump opd_footer version number ! 2001-07-25 John Levon <moz@compsoc.man.ac.uk> * pp/Makefile.in: * pp/oprof_convert.c: convert to v4 * pp/oprofpp.c: use opd_strdup 2001-07-25 John Levon <moz@compsoc.man.ac.uk> * dae/opd_util.c: small tidy 2001-07-24 Philippe Elie <ph_e@club-internet.fr> * dae/opd_util.c: * dae/opd_util.h: add relative path name to absolute path name stuff * pp/oprofpp.c: use it. * pp/op_to_source: simplify code to reflect above change. 2001-07-25 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: fix uninitialised pointer access (reported by <bobm@fc.hp.com>) that could segfault oprofile in case of module load/unload activity * Makefile.in: * dae/opd_proc.c: * dae/opd_util.c: * dae/opd_util.h: * dae/oprofiled.c: * dae/oprofiled.h: * pp/Makefile.in: * pp/oprofpp.c: * pp/oprofpp.h: use mtime() instead of md5sum(). Still doesn't handle "./a; gcc -o a a.c; ./a" 2001-07-22 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.1.in: * doc/oprofile.sgml: * pp/opf_filter.h: * pp/opf_filter.cpp: * pp/opf_container.cpp: implement and document filtering for assembly output. 2001-07-21 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.sgml: * gui/oprofile: * oprofile.c: remove edge_detect support. * pp/oprofpp.c: check counter range for each event type. * oprofile.c: ditto. * gui/oprofile: ditto and save setup for each event type. * oprofile.h: op_check_range() : display the allowed range. 2001-07-18 Philippe Elie <ph_e@club-internet.fr> * dae/op_start: disable all counters before starting the setup. 2001-07-18 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: add in bit I forgot about not profiling ring 0 2001-07-18 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: added a warning about very low counter values (from Philippe, modified) 2001-07-15 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: * oprofile.h: * dae/op_start: * dae/oprofiled.c: * doc/oprofile.sgml: remove ability to set different values on different CPUs 2001-07-15 John Levon <moz@compsoc.man.ac.uk> * TODO: remove done thing 2001-07-15 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: backup old sample files if the profiling details (count, unit mask etc.) disagree. Fixes #435245 2001-07-15 Philippe Elie <ph_e@club-internet.fr> * dae/oprofiled.c: fix oprofiled --version to work even if the profiler is not already started. * gui/oprofile: many cleanup. Fix bug track #435248. Make the gui more independant on the number of counter. * pp/op_to_source: fix bug in command line arguments handling. * pp/opf_filter.h: * pp/opf_filter.cpp: * pp/opf_container.cpp: Apply some cleanup suggested by John, principally change few inheritance to composition. * pp/oprof_convert.c: fix --version. 2001-07-14 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.sgml: * doc/oprofile.1.in: minor doc fix. 2001-07-14 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: small tidies 2001-07-01 Philippe Elie <ph_e@club-internet.fr> * doc/oprofile.1.in: * doc/oprofile.sgml: document op_to_source, oprof_convert and the oprofile gui * gui/oprofile: onStartProfiling() check that count is in the allowed range. onStopProfiling() flush the samples 2001-07-14 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: dist fix 2001-07-14 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: make it clear we want vmlinux not vmlinuz * doc/html/: remove generated files from CVS * Makefile.in: changes to create HTML files on dist 2001-06-30 John Levon <moz@compsoc.man.ac.uk> * pp/Makefile.in: fix the fix * pp/opf_filter.h: very minor changes 2001-06-29 John Levon <moz@compsoc.man.ac.uk> * pp/Makefile.in: fix up for opf_filter * configure.in: add AC_PROG_CXX 2001-06-29 Philippe Elie <ph_e@club-internet.fr> * pp/opf_filter.cpp: * pp/opf_container.cpp: * pp/opf_filter.h: * pp/op_to_source: new file which provide a source annotation utility. * pp/Makefile.in: build and install opf_filter / op_to_source 2001-06-29 John Levon <moz@compsoc.man.ac.uk> * configure.in: * dae/opd_util.h: hide __attribute__((malloc)) warnings when necessary. Document --with-cc bug. 2001-06-29 Philippe Elie <ph_e@club-internet.fr> * gui/oprofile: more saving of the user setup. 2001-06-27 John Levon <moz@compsoc.man.ac.uk> * dae/opd_util.c: document get_line() restriction 2001-06-27 Philippe Elie <ph_e@club-internet.fr> * dae/oprofiled.c: fix cpu_speed_str/cpu_speed variable setup logic. * gui/oprofile: save advanced setup form to persistent storage. Add many validation. 2001-06-25 John Levon <moz@compsoc.man.ac.uk> * op_events.c: * pp/oprof_convert.c: add missing headers, remove CVS blip * dae/opd_util.h: specify malloc attribute. gives warnings on older compilers, who cares. I doubt this will help but it can't harm 2001-06-25 John Levon <moz@compsoc.man.ac.uk> * pp/oprof_convert.c: continue if an error with one file occurs * dae/op_stop: remove rmmod again - it is user's choice on when/whether to unload 2001-06-23 Philippe Elie <ph_e@club-internet.fr> * pp/op_start: add missing support for specifying the log filename. Get correct cpu speed information for smp as suggested by John. * dae/oprofiled.c: Correct a warning with some older version of the popt library. * pp/oprofpp: as above. * gui/oprofile: advanced setup form added. * pp/oprof_convert.c: version and help option support. 2001-06-23 John Levon <moz@compsoc.man.ac.uk> * pp/.cvsignore: add oprof_convert 2001-06-23 Philippe Elie <ph_e@club-internet.fr> * pp/oprof_convert.c: new utility to convert samples files when the opd_footer struct is changed. * pp/Makefile.in: reflect the above change. Tidy some unnecessary blank. * Makefile.in: Tidy some unnecessary blank/tabulation. 2001-06-23 John Levon <moz@compsoc.man.ac.uk> * README: update 2001-06-22 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: always have smp_apic_restore() 2001-06-22 John Levon <moz@compsoc.man.ac.uk> * various: made spacing more consistent in C source, removed unused utility functions. 2001-06-22 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: actually call smp_apic_restore() on UP * dae/op_start: don't remove the module immediately after inserting it ! 2001-06-22 Philippe Elie <ph_e@club-internet.fr> * dae/oprofiled.h, pp/oprofpp.h: change the opd_footer struct. Bump OPD_VERSION to reflect the file format change. * pp/oprofpp.c: reflect the above change * dae/oprofiled.c: reflect the above change, many options supressed because setup is read from the /proc/sys/dev/oprofile files. * dae/opd_proc: suppress some "extern variable" which no longer exist. * dae/op_start: reflect the above change 2001-06-22 Philippe Elie <ph_e@club-internet.fr> * dae/op_start: add --ctr[0|1]-edge-detect * gui/oprofile: add edge detect stuff * oprofile.c: add edge-detect stuff, the edge-detect is an experimental feature which do not work actually (no effect for now). Because this is experimental no documentation are provided on this option. 2001-06-22 John Levon <moz@compsoc.man.ac.uk> * configure.in: * dae/op_stop: * doc/oprofile.sgml: * op_init.c: * op_syscalls.c: * oprofile.h: * oprofile.c: add and document the ability to make the module unloadable. Not well tested (but seems to work). * doc/oprofile.sgml: document compile-time options better, thank Philippe 2001-06-21 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: remove stale comments. fix theoretical memory leaks when setting up the sysctls fails, small tidy 2001-06-19 John Levon <moz@compsoc.man.ac.uk> * README: * doc/oprofile.sgml: * doc/html/: s/sourceforge/sf/ 2001-06-16 Philippe Elie <ph_e@club-internet.fr> * op_events.c: op_check_events() fix two bad use of op_check_unit_mask(). op_get_um_desc() fix a typo. 2001-06-14 Philippe Elie <ph_e@club-internet.fr> * op_events.c: struct op_unit_mask, struct op_unit_desc allow up to seven unit masks. Reflect this change in data, op_check_unit_mask() and callers of op_check_unit_mask(). 2001-06-12 John Levon <moz@compsoc.man.ac.uk> * results/intro: tidy up * results/kernel-compile/time-aves.pl: fix regexps * results/latex/: results from the LaTeX runs 2001-06-09 Philippe Elie <ph_e@club-internet.fr> * dae/op_start: avoid chmod to a non existing directory and setup access mode from 700 to 755. Replace use of the sysctl utility by a do_sysctl() function. * gui/oprofile: some cleanup and bugfix. * pp/oprofpp.c: add new output options --list-all-symbols-details, --output-linenr-info * doc/oprofile.1.in: * doc/oprofile.sgml: update documentation about the new oprofpp option 2001-06-09 John Levon <moz@compsoc.man.ac.uk> * configure.in: fix build with CONFIG_MODVERSIONS enabled. 2001-06-04 John Levon <moz@compsoc.man.ac.uk> * dae/oprofiled.c: move logfile message to before close(1) to not need to use stderr 2001-06-03 John Levon <moz@compsoc.man.ac.uk> * gui/: new directory * Makefile.in: * configure.in: * gui/.cvsignore: * gui/Makefile.in: * gui/oprofile: Philippe's prototype tcl/tk startup script. Requires more work. 2001-06-03 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.h: remove libiberty header that was apparently breaking install on slackware 2001-06-03 John Levon <moz@compsoc.man.ac.uk> * README: update 2001-06-03 Philippe Elie <ph_e@club-internet.fr> * op_events.c: allow unit mask option to be bit mask 2001-06-01 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: actually use opd_get_count - fix bug with counter 1 reported results * dae/op_start: fix broken shell scripting * dae/oprofpp.c: fix list-symbols output 2001-04-30 John Levon <moz@compsoc.man.ac.uk> * dae/op_start: better error reporting * dae/opd_proc.c: fix indentation 2001-04-08 John Levon <moz@compsoc.man.ac.uk> * configure.in: 0.0.3 has been released. Bump cvs version to 0.0.4 2001-04-05 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: remove forced dumping. It was causing overhead spikes * doc/html/results.html: * doc/oprofile.sgml: * dae/op_start: Hopefully document dump clearly enough 2001-04-05 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: * op_syscalls.c: 2.4.3 and above have a rw mmap_sem 2001-04-05 John Levon <moz@compsoc.man.ac.uk> * doc/html/: added missing files 2001-04-05 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: * doc/html/resources.html: add URLs 2001-04-05 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.c: fix gprof output bug. It works OK now, but MULTIPLIER == 1 will break for some reason 2001-04-05 John Levon <moz@compsoc.man.ac.uk> * doc/oprofile.sgml: * doc/html/: finish SGML documentation (for now) 2001-04-04 John Levon <moz@compsoc.man.ac.uk> * doc/Makefile.in: * doc/oprofile.sgml: * doc/oprofile: start SGML documentation 2001-04-04 John Levon <moz@compsoc.man.ac.uk> * configure.in: * Makefile.in: * doc/Makefile.in: * doc/oprofile.1.in: add a manpage 2001-04-04 John Levon <moz@compsoc.man.ac.uk> * pp/oprofpp.c: get some sort of half-working output in gprof format. Currently the numbers are screwed up, need a major trawl through gprof source to see what's going on. 2001-04-04 John Levon <moz@compsoc.man.ac.uk> * dae/Makefile.in: * dae/md5.c: * dae/md5.h: * dae/opd_proc.c: * dae/oprofiled.h: * pp/Makefile.in: * pp/oprofpp.c: * pp/oprofpp.h: use md5sums to verify sample file integrity. Stored in each sample file footer are md5sums of the binary. These are checked by the daemon when re-using an old file, and by the post-processor. Bump OPD_VERSION to reflect the file format change. * dae/oprofiled.c: make start up more friendly * dae/op_start: make script more friendly 2001-03-10 John Levon <moz@compsoc.man.ac.uk> * dae/opd_proc.c: fixed some error messages * results/kernel-compile/raw/ccu.gnuplot: add 2001-02-05 John Levon <moz@compsoc.man.ac.uk> * TODO: update * results/intro: update * results/kernel-compile/: update, add FIG files * results/lmbench: lmbench results * results/output/kernel-ac12-output: add readprofile output 2001-02-04 John Levon <moz@compsoc.man.ac.uk> * TODO: update * op_syscalls.c: small re-org, some micro-optimisations to do_hash() * pp/oprofpp.c: clean up --list-symbol output a little * results/kernel-compile/overhead: update with results * results/kernel-compile/time-aves.pl: add gnuplot output * results/kernel-compile/raw/ : raw output files * results/output/ : new dir for example output * results/output/libc-2.1.92.so: output from libc profile * results/output/kernel-ac12-output: output from kernel profile * results/output/do_anonymous_page: detailed symbol profile * results/output/oprofile.module: output for oprofile module 2001-02-03 John Levon <moz@compsoc.man.ac.uk> * TODO: update * oprofile.h: * op_syscalls.c: make do_hash() non-recursive * oprofile.c: make thread wake up half as often * dae/opd_proc.c: quiesce dump sysctl make resilient against broken sample (don't exceed mmap) * pp/oprofpp.c: --gcc-demangle -> --demangle, just too annoying to live 2001-02-01 John Levon <moz@compsoc.man.ac.uk> * oprofile.h: add op_save_syscalls() * oprofile.c: let interrupt_sleep_on() die add kernel_only option sysctl dumps everything it can now * op_syscalls.c: add op_save_syscalls() * dae/opd_proc.c: * dae/oprofiled.c: * dae/op_start: add --kernel-only * doc/guide.lyx: mention --kernel-only * TODO: update 2001-02-01 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: split out op_init.c * autogen.sh: new file * configure.in: fix --with-cc. Split out op_init.c * op_init.c: new file, to allow rest -march=i686 * oprofile.c: cut out init stuff to op_init.c * opd_proc.c: more verbose * results/kernel-compile/time-aves.pl: work with other time format too 2001-01-25 John Levon <moz@compsoc.man.ac.uk> * configure.in: add --with-cc option * pp/oprofpp.c: fix const discard warnings 2001-01-25 John Levon <moz@compsoc.man.ac.uk> * configure.in: must check for liberty *after* libdl 2001-01-24 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: we're not using op_check_ctr() return value, so don't have one 2001-01-23 John Levon <moz@compsoc.man.ac.uk> * configure.in: * op_syscalls.c: * oprofile.c: * oprofile.h: stripped the NMI error handling stuff * op_events.c: fixed silly bug in the other place too :P * dae/oprofiled.c: improved error messages 2001-01-22 John Levon <moz@compsoc.man.ac.uk> * op_events.c: fix silly bug so you can set both counters at once * oprofile.c: don't disable/enable counters in the interrupt handler. It's expensive and doesn't really buy anything. Fix a silly EBUSY bug when open fails once. * dae/op_start: don't remove old sample files pass correct event to daemon for ctr1 2001-01-22 John Levon <moz@compsoc.man.ac.uk> * op_syscalls.c:do_hash(): use strcpy not strncpy. It's probably faster, and if d_name.len is corrupted the kernel has bigger things to worry about. 2001-01-22 John Levon <moz@compsoc.man.ac.uk> * dae/guide.lyx: * dae/guide.html: update docs a little 2001-01-22 John Levon <moz@compsoc.man.ac.uk> * dae/op_start: * op_user.h: bump up hash table size * results/kernel-compile/overhead: intro to kernel compile tests * results/kernel-compile/time-aves.pl: script to generate averages + overheads * op_syscalls.c: three fixes to do_hash(). It's going to be a pain to make iterative :( 2001-01-21 John Levon <moz@compsoc.man.ac.uk> * results/: Started a collection of results 2001-01-20 John Levon <moz@compsoc.man.ac.uk> * TODO: update * configure.in: add comment * Makefile.in: moved oprofile_k.c to op_syscalls.c, op_user.h added * op_syscalls.c: rename of oprofile_k.c map buffer is dead now use vmalloc() and friends for hash map Reworking of hash_map stuff into abb's linked hash map structure * op_user.h: new file representing shared structs etc. between daemon and kernel module Reworked OP_ flags in count. Reworked hash map structure * oprofile.c: get along with the new UP APIC stuff in 2.4.0ac9 remove extraneous lock_kernel() default buffer size added map buffer died Use up_and_exit() in kernel thread to fix zombies :P Set diethreaddie = 0 in start_thread() oprof_put_mapping() added we weren't turning OFF kernel/user counting when asked to * oprofile.h: move shared stuff to op_user.h increase the watermark to a much safer 768 * dae/Makefile.in: dependencies on op_user.h and version.h * dae/op_start: hide confusing output of op_stop --verbose option map buffer died * dae/opd_proc.c: --verbose option don't insist on new sample files Rework mapping code Be a little more forgiving with unstattable images * dae/opd_util.h: * dae/opd_util.c: add fatal flag to opd_get_fsize(). * dae/oprofiled.h: --verbose option move common code to op_user.h * dae/oprofiled.c: add --verbose option (very verbose !) map buffer died Add code for unpacking mapping notifications, rework mapping recognition * doc/guide.html: * doc/guide.lyx: some small updates * pp/oprofpp.c: fix segfault on failure to open binary. add --verbose option * pp/oprofpp.h: add --verbose option 2000-01-12 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: use standard kernel names for MSRs. Don't re-do fixmap if UP oopser patch is installed. Allow UP oopser to work if patches enabled, disable otherwise * oprofile.h: use standard kernel names for MSRs. * oprofile_k.c: only include fixmap code if necessary * configure.in: bump minor version 2000-12-15 John Levon <moz@compsoc.man.ac.uk> * configure.in: default to /lib/modules/`uname -r`/build as kernel source directory * doc/guide.lyx: * doc/guide.html: update documentation 2000-12-13 John Levon <moz@compsoc.man.ac.uk> * configure.in: bump minor version * oprofile.c: added KERN_<whatever> where needed, exclude the Pentium IV * pp/oprofpp.c: allow "oprofpp -l /bin/mv" and friends, some minor fixes 2000-12-12 John Levon <moz@compsoc.man.ac.uk> * Makefile.in: * configure.in: approximate working modversions a little more * op_events.c: op_help INST_RETIRED will print out the value now * op_ioctl.h: * oprofile.c: * oprofile.h: * oprofile_k.c: * dae/Makefile.in: * dae/op_start: * dae/op_stop: * dae/opd_proc.c: * dae/oprofctl.c: * dae/oprofctl.h: * dae/oprofiled.h: ioctl() didn't last long. Replaced with sysctls. This has had a knock-on effect of moving the start/stop mechanism into the driver open/close routines * dae/oprofiled.c: must open devices in "reverse" order now * oprofile_k.c: fix X86_FEATURE_PGE testing * oprofile.c: use daemonize() * pp/oprofpp.c: fix working on constant argv 2000-11-04 John Levon <moz@compsoc.man.ac.uk> * oprofile.c: what if signal happens later ? * dae/opd_util.c: clarify opd_read_device() API 2000-11-04 John Levon <moz@compsoc.man.ac.uk> * ChangeLog: started ChangeLog (cue gc koan) * op_ioctl.h: added FIXME comment * oprofile.c: slight cleanup * oprofile.h: cleanups, use u16 for data->ctrs, data->next * pp/oprofpp.c: added comments * pp/oprofpp.h: fixed #defines