...slowly turning into a full-fledged trace overhaul...
When working on the documentation, I discovered GIT_TRACE_PACK_ACCESS,
which uses a completely separate trace implementation that is 3 times
faster by keeping the file open...so this round includes a performance
patch that brings the trace API up to speed.
Changes since v6:
[04-06]: New.
[07-08]: Separated the 'disable for test' aspect into a separate patch.
GIT_TRACE_BARE=1 is set in test-lib.sh rather than individual
tests. Moved static trace_bare variable from global scope into
prepare_trace_line().
[09]: Cast timeval.tv_usec to long to prevent compiler warning.
[11,13]: Factor out '#define TRACE_CONTEXT __FILE__' so that it can
be easily changed to __FUNCTION__.
[14]: Added GIT_TRACE_PERFORMANCE to Documentation/git.txt
[15-16]: New.
[01-03,10,12] are unchanged save resolving conflicts.
Karsten Blees (16):
trace: move trace declarations from cache.h to new trace.h
trace: consistently name the format parameter
trace: remove redundant printf format attribute
trace: improve trace performance
Documentation/git.txt: improve documentation of 'GIT_TRACE*' variables
sha1_file: change GIT_TRACE_PACK_ACCESS logging to use trace API
trace: add infrastructure to augment trace output with additional info
trace: disable additional trace output for unit tests
trace: add current timestamp to all trace output
trace: move code around, in preparation to file:line output
trace: add 'file:line' to all trace output
trace: add high resolution timer function to debug performance issues
trace: add trace_performance facility to debug performance issues
git: add performance tracing for git's main() function to debug
scripts
wt-status: simplify performance measurement by using getnanotime()
progress: simplify performance measurement by using getnanotime()
Documentation/git.txt | 59 +++++---
Makefile | 7 +
builtin/receive-pack.c | 2 +-
cache.h | 13 +-
commit.h | 1 +
config.mak.uname | 1 +
git-compat-util.h | 4 +
git.c | 2 +
pkt-line.c | 8 +-
progress.c | 71 +++++-----
sha1_file.c | 30 +---
shallow.c | 10 +-
t/test-lib.sh | 4 +
trace.c | 369 ++++++++++++++++++++++++++++++++++++++++---------
trace.h | 105 ++++++++++++++
wt-status.c | 14 +-
16 files changed, 524 insertions(+), 176 deletions(-)
create mode 100644 trace.h
--
2.0.0.406.ge74f8ff
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html