about summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1999-10-05 05:32:24 +0000
committerUlrich Drepper <drepper@redhat.com>1999-10-05 05:32:24 +0000
commit926de5eb779ca8b33e7bbfb588afa442fab69714 (patch)
tree2ba68e875fcd7ca1a72aa6b7221a168aca9b7640
parent43fc8f18c7898966fce3cc4a19908a61a8186f07 (diff)
downloadglibc-926de5eb779ca8b33e7bbfb588afa442fab69714.tar.gz
glibc-926de5eb779ca8b33e7bbfb588afa442fab69714.tar.xz
glibc-926de5eb779ca8b33e7bbfb588afa442fab69714.zip
Update.
	* malloc/Makefile ($(objpfx)memprof): Fix typo in rule.

	* malloc/memprof.sh: Take options to control memprofstat.
-rw-r--r--ChangeLog4
-rw-r--r--malloc/Makefile2
-rwxr-xr-xmalloc/memprof.sh107
3 files changed, 110 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index ca0dacc7a2..5a4d7fce51 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
 1999-10-04  Ulrich Drepper  <drepper@cygnus.com>
 
+	* malloc/Makefile ($(objpfx)memprof): Fix typo in rule.
+
+	* malloc/memprof.sh: Take options to control memprofstat.
+
 	* malloc/Makefile: Add rule to generate memprof script.
 	* malloc/memprof.sh: New file.
 
diff --git a/malloc/Makefile b/malloc/Makefile
index dfbf333c79..90c7fc4531 100644
--- a/malloc/Makefile
+++ b/malloc/Makefile
@@ -101,7 +101,7 @@ $(objpfx)mtrace: mtrace.pl
 
 $(objpfx)memprof: memprof.sh
 	rm -f $@.new
-	sed -e 's|@BASH@|$(BASH)|' -e 's|@VERSION@|$(VERSION)|' \
+	sed -e 's|@BASH@|$(BASH)|' -e 's|@VERSION@|$(version)|' \
 	    -e 's|@LIBDIR@|$(libdir)|' -e 's|@BINDIR@|$(bindir)|' $^ > $@.new \
 	&& rm -f $@ && mv $@.new $@ && chmod +x $@
 
diff --git a/malloc/memprof.sh b/malloc/memprof.sh
index f34d1f1680..c30ec985e8 100755
--- a/malloc/memprof.sh
+++ b/malloc/memprof.sh
@@ -29,11 +29,23 @@ do_usage() {
 
 do_help() {
   echo $"Usage: memprof [OPTION]... PROGRAM [PROGRAMOPTION...]
+Profile memory usage of PROGRAM.
+
       --help              print this help and exit
       --version           print version information and exit
       --progname          name of the program file to profile
       --png=FILE          generate PNG graphic and store it in FILE
       --data=FILE         generate binary data file and store it in FILE
+      --unbuffered        don't buffer output
+      --buffer=SIZE       collect SIZE entries before writing them out
+      --no-timer          don't collect additional information though timer
+
+   The following options only apply when generating graphical output:
+      --time-based        make graph linear in time
+      --total             also draw graph of total memory use
+      --title=STRING      use STRING as title of the graph
+      --x-size=SIZE       make graphic SIZE pixels wide
+      --y-size=SIZE       make graphic SIZE pixels high
 Report bugs using the \`glibcbug' script to <bugs@gnu.org>."
   exit 0
 }
@@ -57,14 +69,91 @@ while test $# -gt 0; do
     do_help
     ;;
   --pr | --pro | --prog | --progn | --progna | --prognam | --progname)
+    if test $# -eq 1; then
+      usage
+    fi
+    shift
     progname="$1"
     ;;
+  --pr=* | --pro=* | --prog=* | --progn=* | --progna=* | --prognam=* | --progname=*)
+    progname=${1##*=}
+    ;;
   --pn | --png)
+    if test $# -eq 1; then
+      usage
+    fi
+    shift
     png="$1"
     ;;
+  --pn=* | --png=*)
+    png=${1##*=}
+    ;;
   --d | --da | --dat | --data)
+    if test $# -eq 1; then
+      usage
+    fi
+    shift
     data="$1"
     ;;
+  --d=* | --da=* | --dat=* | --data=*)
+    data=${1##*=}
+    ;;
+  --u | --un | --unb | --unbu | --unbuf | --unbuff | --unbuffe | --unbuffer | --unbuffere | --unbuffered)
+    buffer=1
+    ;;
+  --b | --bu | --buf | --buff | --buffe | --buffer)
+    if test $# -eq 1; then
+      usage
+    fi
+    shift
+    buffer="$1"
+    ;;
+  --b=* | --bu=* | --buf=* | --buff=* | --buffe=* | --buffer=*)
+    buffer=${1##*=}
+    ;;
+  --n | --no | --no- | --no-t | --no-ti | --no-tim | --no-time | --no-timer)
+    notimer=yes
+    ;;
+  --tim | --time | --time- | --time-b | --time-ba | --time-bas | --time-base | --time-based)
+    memprofstat_args="$memprofstat_args -t"
+    ;;
+  --to | --tot | --tota | --total)
+    memprofstat_args="$memprofstat_args -T"
+    ;;
+  --tit | --titl | --title)
+    if test $# -eq 1; then
+      usage
+    fi
+    shift
+    memprofstat_args="$memprofstat_args -s $1"
+    ;;
+  --tit=* | --titl=* | --title=*)
+    memprofstat_args="$memprofstat_args -s ${1##*=}"
+    ;;
+  --x | --x- | --x-s | --x-si | --x-siz | --x-size)
+    if test $# -eq 1; then
+      usage
+    fi
+    shift
+    memprofstat_args="$memprofstat_args -x $1"
+    ;;
+  --x=* | --x-=* | --x-s=* | --x-si=* | --x-siz=* | --x-size=*)
+    memprofstat_args="$memprofstat_args -x ${1##*=}"
+    ;;
+  --y | --y- | --y-s | --y-si | --y-siz | --y-size)
+    if test $# -eq 1; then
+      usage
+    fi
+    shift
+    memprofstat_args="$memprofstat_args -y $1"
+    ;;
+  --y=* | --y-=* | --y-s=* | --y-si=* | --y-siz=* | --y-size=*)
+    memprofstat_args="$memprofstat_args -y ${1##*=}"
+    ;;
+  --p | --p=* | --t | --t=* | --ti | --ti=*)
+    echo >&2 $"memprof: option \`${1##*=}' is ambiguous"
+    usage
+    ;;
   --)
     # Stop processing arguments.
     shift
@@ -100,6 +189,16 @@ if test -n "$datafile"; then
   add_env="$add_env MEMPROF_OUTPUT=$datafile"
 fi
 
+# Set buffer size.
+if test -n "$buffer"; then
+  add_env="$add_env MEMPROF_BUFFER_SIZE=$buffer"
+fi
+
+# Disable timers.
+if test -n "$notimer"; then
+  add_env="$add_env MEMPROF_NO_TIMER=yes"
+fi
+
 # Execute the program itself.
 eval $add_env $*
 result=$?
@@ -107,10 +206,14 @@ result=$?
 # Generate the PNG data file is wanted and there is something to generate
 # it from.
 if test -n "$png" -a -s "$datafile"; then
-  eval $memprofstat $datafile $png
+  # Append extension .png if it isn't already there.
+  if test $png = ${png%*.png}; then
+    png="$png.png"
+  fi
+  eval $memprofstat $memprofstat_args $datafile $png
 fi
 
-if test -z $data -a -n $datafile; then
+if test -z "$data" -a -n $datafile; then
   rm -f $datafile
 fi