aboutsummaryrefslogtreecommitdiffstats
path: root/Documentation/perf_counter
diff options
context:
space:
mode:
Diffstat (limited to 'Documentation/perf_counter')
-rw-r--r--Documentation/perf_counter/Makefile207
-rw-r--r--Documentation/perf_counter/builtin-help.c2
-rw-r--r--Documentation/perf_counter/builtin-top.c17
-rw-r--r--Documentation/perf_counter/cache.h20
-rw-r--r--Documentation/perf_counter/config.c95
-rw-r--r--Documentation/perf_counter/path.c39
-rw-r--r--Documentation/perf_counter/perf.c3
-rw-r--r--Documentation/perf_counter/util.h14
8 files changed, 45 insertions, 352 deletions
diff --git a/Documentation/perf_counter/Makefile b/Documentation/perf_counter/Makefile
index 11809b943fc3..1b6026555547 100644
--- a/Documentation/perf_counter/Makefile
+++ b/Documentation/perf_counter/Makefile
@@ -138,16 +138,6 @@ all::
138# 138#
139# Define NO_PERL if you do not want Perl scripts or libraries at all. 139# Define NO_PERL if you do not want Perl scripts or libraries at all.
140# 140#
141# Define NO_TCLTK if you do not want Tcl/Tk GUI.
142#
143# The TCL_PATH variable governs the location of the Tcl interpreter
144# used to optimize perf-gui for your system. Only used if NO_TCLTK
145# is not set. Defaults to the bare 'tclsh'.
146#
147# The TCLTK_PATH variable governs the location of the Tcl/Tk interpreter.
148# If not set it defaults to the bare 'wish'. If it is set to the empty
149# string then NO_TCLTK will be forced (this is used by configure script).
150#
151# Define INTERNAL_QSORT to use Git's implementation of qsort(), which 141# Define INTERNAL_QSORT to use Git's implementation of qsort(), which
152# is a simplified version of the merge sort used in glibc. This is 142# is a simplified version of the merge sort used in glibc. This is
153# recommended if Git triggers O(n^2) behavior in your platform's qsort(). 143# recommended if Git triggers O(n^2) behavior in your platform's qsort().
@@ -215,12 +205,8 @@ TAR = tar
215FIND = find 205FIND = find
216INSTALL = install 206INSTALL = install
217RPMBUILD = rpmbuild 207RPMBUILD = rpmbuild
218TCL_PATH = tclsh
219TCLTK_PATH = wish
220PTHREAD_LIBS = -lpthread 208PTHREAD_LIBS = -lpthread
221 209
222export TCL_PATH TCLTK_PATH
223
224# sparse is architecture-neutral, which means that we need to tell it 210# sparse is architecture-neutral, which means that we need to tell it
225# explicitly what architecture to check for. Fix this up for yours.. 211# explicitly what architecture to check for. Fix this up for yours..
226SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__ 212SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__
@@ -529,10 +515,6 @@ ifdef NO_EXTERNAL_GREP
529 BASIC_CFLAGS += -DNO_EXTERNAL_GREP 515 BASIC_CFLAGS += -DNO_EXTERNAL_GREP
530endif 516endif
531 517
532ifeq ($(TCLTK_PATH),)
533NO_TCLTK=NoThanks
534endif
535
536ifeq ($(PERL_PATH),) 518ifeq ($(PERL_PATH),)
537NO_PERL=NoThanks 519NO_PERL=NoThanks
538endif 520endif
@@ -583,7 +565,6 @@ prefix_SQ = $(subst ','\'',$(prefix))
583 565
584SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH)) 566SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
585PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH)) 567PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH))
586TCLTK_PATH_SQ = $(subst ','\'',$(TCLTK_PATH))
587 568
588LIBS = $(PERFLIBS) $(EXTLIBS) 569LIBS = $(PERFLIBS) $(EXTLIBS)
589 570
@@ -607,14 +588,6 @@ ifneq (,$X)
607endif 588endif
608 589
609all:: 590all::
610ifndef NO_TCLTK
611 $(QUIET_SUBDIR0)perf-gui $(QUIET_SUBDIR1) perfexecdir='$(perfexec_instdir_SQ)' all
612 $(QUIET_SUBDIR0)perfk-perf $(QUIET_SUBDIR1) all
613endif
614ifndef NO_PERL
615 $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' all
616endif
617 $(QUIET_SUBDIR0)templates $(QUIET_SUBDIR1)
618 591
619please_set_SHELL_PATH_to_a_more_modern_shell: 592please_set_SHELL_PATH_to_a_more_modern_shell:
620 @$$(:) 593 @$$(:)
@@ -704,21 +677,6 @@ builtin-revert.o wt-status.o: wt-status.h
704$(LIB_FILE): $(LIB_OBJS) 677$(LIB_FILE): $(LIB_OBJS)
705 $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIB_OBJS) 678 $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIB_OBJS)
706 679
707doc:
708 $(MAKE) -C Documentation all
709
710man:
711 $(MAKE) -C Documentation man
712
713html:
714 $(MAKE) -C Documentation html
715
716info:
717 $(MAKE) -C Documentation info
718
719pdf:
720 $(MAKE) -C Documentation pdf
721
722TAGS: 680TAGS:
723 $(RM) TAGS 681 $(RM) TAGS
724 $(FIND) . -name '*.[hcS]' -print | xargs etags -a 682 $(FIND) . -name '*.[hcS]' -print | xargs etags -a
@@ -751,33 +709,12 @@ PERF-BUILD-OPTIONS: .FORCE-PERF-BUILD-OPTIONS
751 @echo NO_CURL=\''$(subst ','\'',$(subst ','\'',$(NO_CURL)))'\' >>$@ 709 @echo NO_CURL=\''$(subst ','\'',$(subst ','\'',$(NO_CURL)))'\' >>$@
752 @echo NO_PERL=\''$(subst ','\'',$(subst ','\'',$(NO_PERL)))'\' >>$@ 710 @echo NO_PERL=\''$(subst ','\'',$(subst ','\'',$(NO_PERL)))'\' >>$@
753 711
754### Detect Tck/Tk interpreter path changes
755ifndef NO_TCLTK
756TRACK_VARS = $(subst ','\'',-DTCLTK_PATH='$(TCLTK_PATH_SQ)')
757
758PERF-GUI-VARS: .FORCE-PERF-GUI-VARS
759 @VARS='$(TRACK_VARS)'; \
760 if test x"$$VARS" != x"`cat $@ 2>/dev/null`" ; then \
761 echo 1>&2 " * new Tcl/Tk interpreter location"; \
762 echo "$$VARS" >$@; \
763 fi
764
765.PHONY: .FORCE-PERF-GUI-VARS
766endif
767
768### Testing rules 712### Testing rules
769 713
770TEST_PROGRAMS += test-chmtime$X 714#
771TEST_PROGRAMS += test-ctype$X 715# None right now:
772TEST_PROGRAMS += test-date$X 716#
773TEST_PROGRAMS += test-delta$X 717# TEST_PROGRAMS += test-something$X
774TEST_PROGRAMS += test-dump-cache-tree$X
775TEST_PROGRAMS += test-genrandom$X
776TEST_PROGRAMS += test-match-trees$X
777TEST_PROGRAMS += test-parse-options$X
778TEST_PROGRAMS += test-path-utils$X
779TEST_PROGRAMS += test-sha1$X
780TEST_PROGRAMS += test-sigchain$X
781 718
782all:: $(TEST_PROGRAMS) 719all:: $(TEST_PROGRAMS)
783 720
@@ -787,25 +724,6 @@ all:: $(TEST_PROGRAMS)
787 724
788export NO_SVN_TESTS 725export NO_SVN_TESTS
789 726
790test: all
791 $(MAKE) -C t/ all
792
793test-ctype$X: ctype.o
794
795test-date$X: date.o ctype.o
796
797test-delta$X: diff-delta.o patch-delta.o
798
799test-parse-options$X: parse-options.o
800
801.PRECIOUS: $(patsubst test-%$X,test-%.o,$(TEST_PROGRAMS))
802
803test-%$X: test-%.o $(PERFLIBS)
804 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS)
805
806check-sha1:: test-sha1$X
807 ./test-sha1.sh
808
809check: common-cmds.h 727check: common-cmds.h
810 if sparse; \ 728 if sparse; \
811 then \ 729 then \
@@ -845,10 +763,6 @@ install: all
845 $(INSTALL) perf$X perf-upload-pack$X perf-receive-pack$X perf-upload-archive$X perf-shell$X perf-cvsserver '$(DESTDIR_SQ)$(bindir_SQ)' 763 $(INSTALL) perf$X perf-upload-pack$X perf-receive-pack$X perf-upload-archive$X perf-shell$X perf-cvsserver '$(DESTDIR_SQ)$(bindir_SQ)'
846 $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install 764 $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install
847 $(MAKE) -C perl prefix='$(prefix_SQ)' DESTDIR='$(DESTDIR_SQ)' install 765 $(MAKE) -C perl prefix='$(prefix_SQ)' DESTDIR='$(DESTDIR_SQ)' install
848ifndef NO_TCLTK
849 $(MAKE) -C perfk-perf install
850 $(MAKE) -C perf-gui perfexecdir='$(perfexec_instdir_SQ)' install
851endif
852ifneq (,$X) 766ifneq (,$X)
853 $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) perf$X)), $(RM) '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/$p';) 767 $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) perf$X)), $(RM) '$(DESTDIR_SQ)$(perfexec_instdir_SQ)/$p';)
854endif 768endif
@@ -865,32 +779,6 @@ endif
865 done } && \ 779 done } && \
866 ./check_bindir "z$$bindir" "z$$execdir" "$$bindir/perf-add$X" 780 ./check_bindir "z$$bindir" "z$$execdir" "$$bindir/perf-add$X"
867 781
868install-doc:
869 $(MAKE) -C Documentation install
870
871install-man:
872 $(MAKE) -C Documentation install-man
873
874install-html:
875 $(MAKE) -C Documentation install-html
876
877install-info:
878 $(MAKE) -C Documentation install-info
879
880install-pdf:
881 $(MAKE) -C Documentation install-pdf
882
883quick-install-doc:
884 $(MAKE) -C Documentation quick-install
885
886quick-install-man:
887 $(MAKE) -C Documentation quick-install-man
888
889quick-install-html:
890 $(MAKE) -C Documentation quick-install-html
891
892
893
894### Maintainer's dist rules 782### Maintainer's dist rules
895 783
896perf.spec: perf.spec.in 784perf.spec: perf.spec.in
@@ -904,38 +792,16 @@ dist: perf.spec perf-archive$(X) configure
904 @mkdir -p $(PERF_TARNAME) 792 @mkdir -p $(PERF_TARNAME)
905 @cp perf.spec configure $(PERF_TARNAME) 793 @cp perf.spec configure $(PERF_TARNAME)
906 @echo $(PERF_VERSION) > $(PERF_TARNAME)/version 794 @echo $(PERF_VERSION) > $(PERF_TARNAME)/version
907 @$(MAKE) -C perf-gui TARDIR=../$(PERF_TARNAME)/perf-gui dist-version
908 $(TAR) rf $(PERF_TARNAME).tar \ 795 $(TAR) rf $(PERF_TARNAME).tar \
909 $(PERF_TARNAME)/perf.spec \ 796 $(PERF_TARNAME)/perf.spec \
910 $(PERF_TARNAME)/configure \ 797 $(PERF_TARNAME)/configure \
911 $(PERF_TARNAME)/version \ 798 $(PERF_TARNAME)/version
912 $(PERF_TARNAME)/perf-gui/version
913 @$(RM) -r $(PERF_TARNAME) 799 @$(RM) -r $(PERF_TARNAME)
914 gzip -f -9 $(PERF_TARNAME).tar 800 gzip -f -9 $(PERF_TARNAME).tar
915 801
916rpm: dist 802rpm: dist
917 $(RPMBUILD) -ta $(PERF_TARNAME).tar.gz 803 $(RPMBUILD) -ta $(PERF_TARNAME).tar.gz
918 804
919htmldocs = perf-htmldocs-$(PERF_VERSION)
920manpages = perf-manpages-$(PERF_VERSION)
921dist-doc:
922 $(RM) -r .doc-tmp-dir
923 mkdir .doc-tmp-dir
924 $(MAKE) -C Documentation WEBDOC_DEST=../.doc-tmp-dir install-webdoc
925 cd .doc-tmp-dir && $(TAR) cf ../$(htmldocs).tar .
926 gzip -n -9 -f $(htmldocs).tar
927 :
928 $(RM) -r .doc-tmp-dir
929 mkdir -p .doc-tmp-dir/man1 .doc-tmp-dir/man5 .doc-tmp-dir/man7
930 $(MAKE) -C Documentation DESTDIR=./ \
931 man1dir=../.doc-tmp-dir/man1 \
932 man5dir=../.doc-tmp-dir/man5 \
933 man7dir=../.doc-tmp-dir/man7 \
934 install
935 cd .doc-tmp-dir && $(TAR) cf ../$(manpages).tar .
936 gzip -n -9 -f $(manpages).tar
937 $(RM) -r .doc-tmp-dir
938
939### Cleaning rules 805### Cleaning rules
940 806
941distclean: clean 807distclean: clean
@@ -951,74 +817,13 @@ clean:
951 $(RM) -r $(PERF_TARNAME) .doc-tmp-dir 817 $(RM) -r $(PERF_TARNAME) .doc-tmp-dir
952 $(RM) $(PERF_TARNAME).tar.gz perf-core_$(PERF_VERSION)-*.tar.gz 818 $(RM) $(PERF_TARNAME).tar.gz perf-core_$(PERF_VERSION)-*.tar.gz
953 $(RM) $(htmldocs).tar.gz $(manpages).tar.gz 819 $(RM) $(htmldocs).tar.gz $(manpages).tar.gz
954 $(MAKE) -C Documentation/ clean 820 $(RM) PERF-VERSION-FILE PERF-CFLAGS PERF-BUILD-OPTIONS
955 $(MAKE) -C templates/ clean
956 $(MAKE) -C t/ clean
957ifndef NO_TCLTK
958 $(MAKE) -C perfk-perf clean
959 $(MAKE) -C perf-gui clean
960endif
961 $(RM) PERF-VERSION-FILE PERF-CFLAGS PERF-GUI-VARS PERF-BUILD-OPTIONS
962 821
963.PHONY: all install clean strip 822.PHONY: all install clean strip
964.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell 823.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell
965.PHONY: .FORCE-PERF-VERSION-FILE TAGS tags cscope .FORCE-PERF-CFLAGS 824.PHONY: .FORCE-PERF-VERSION-FILE TAGS tags cscope .FORCE-PERF-CFLAGS
966.PHONY: .FORCE-PERF-BUILD-OPTIONS 825.PHONY: .FORCE-PERF-BUILD-OPTIONS
967 826
968### Check documentation
969#
970check-docs::
971 @(for v in $(ALL_PROGRAMS) $(BUILT_INS) perf perfk; \
972 do \
973 case "$$v" in \
974 perf-merge-octopus | perf-merge-ours | perf-merge-recursive | \
975 perf-merge-resolve | perf-merge-subtree | \
976 perf-fsck-objects | perf-init-db | \
977 perf-?*--?* ) continue ;; \
978 esac ; \
979 test -f "Documentation/$$v.txt" || \
980 echo "no doc: $$v"; \
981 sed -e '/^#/d' command-list.txt | \
982 grep -q "^$$v[ ]" || \
983 case "$$v" in \
984 perf) ;; \
985 *) echo "no link: $$v";; \
986 esac ; \
987 done; \
988 ( \
989 sed -e '/^#/d' \
990 -e 's/[ ].*//' \
991 -e 's/^/listed /' command-list.txt; \
992 ls -1 Documentation/perf*txt | \
993 sed -e 's|Documentation/|documented |' \
994 -e 's/\.txt//'; \
995 ) | while read how cmd; \
996 do \
997 case "$$how,$$cmd" in \
998 *,perf-citool | \
999 *,perf-gui | \
1000 *,perf-help | \
1001 documented,perfattributes | \
1002 documented,perfignore | \
1003 documented,perfmodules | \
1004 documented,perfcli | \
1005 documented,perf-tools | \
1006 documented,perfcore-tutorial | \
1007 documented,perfcvs-migration | \
1008 documented,perfdiffcore | \
1009 documented,perfglossary | \
1010 documented,perfhooks | \
1011 documented,perfrepository-layout | \
1012 documented,perftutorial | \
1013 documented,perftutorial-2 | \
1014 sentinel,not,matching,is,ok ) continue ;; \
1015 esac; \
1016 case " $(ALL_PROGRAMS) $(BUILT_INS) perf perfk " in \
1017 *" $$cmd "*) ;; \
1018 *) echo "removed but $$how: $$cmd" ;; \
1019 esac; \
1020 done ) | sort
1021
1022### Make sure built-ins do not have dups and listed in perf.c 827### Make sure built-ins do not have dups and listed in perf.c
1023# 828#
1024check-builtins:: 829check-builtins::
diff --git a/Documentation/perf_counter/builtin-help.c b/Documentation/perf_counter/builtin-help.c
index 125fcc2f4901..a136d619db37 100644
--- a/Documentation/perf_counter/builtin-help.c
+++ b/Documentation/perf_counter/builtin-help.c
@@ -417,11 +417,9 @@ static void show_html_page(const char *perf_cmd)
417 417
418int cmd_help(int argc, const char **argv, const char *prefix) 418int cmd_help(int argc, const char **argv, const char *prefix)
419{ 419{
420 int nonperf;
421 const char *alias; 420 const char *alias;
422 load_command_list("perf-", &main_cmds, &other_cmds); 421 load_command_list("perf-", &main_cmds, &other_cmds);
423 422
424 /* setup_perf_directory_gently(&nonperf); */
425 perf_config(perf_help_config, NULL); 423 perf_config(perf_help_config, NULL);
426 424
427 argc = parse_options(argc, argv, builtin_help_options, 425 argc = parse_options(argc, argv, builtin_help_options,
diff --git a/Documentation/perf_counter/builtin-top.c b/Documentation/perf_counter/builtin-top.c
index 9d2c769e5f83..601bddbc30d5 100644
--- a/Documentation/perf_counter/builtin-top.c
+++ b/Documentation/perf_counter/builtin-top.c
@@ -63,15 +63,6 @@
63 63
64#include "util.h" 64#include "util.h"
65 65
66#define _GNU_SOURCE
67#include <sys/types.h>
68#include <sys/stat.h>
69#include <sys/time.h>
70#include <unistd.h>
71#include <stdint.h>
72#include <stdlib.h>
73#include <string.h>
74#include <limits.h>
75#include <getopt.h> 66#include <getopt.h>
76#include <assert.h> 67#include <assert.h>
77#include <fcntl.h> 68#include <fcntl.h>
@@ -103,8 +94,6 @@
103#define PR_TASK_PERF_COUNTERS_DISABLE 31 94#define PR_TASK_PERF_COUNTERS_DISABLE 31
104#define PR_TASK_PERF_COUNTERS_ENABLE 32 95#define PR_TASK_PERF_COUNTERS_ENABLE 32
105 96
106#define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
107
108#define rdclock() \ 97#define rdclock() \
109({ \ 98({ \
110 struct timespec ts; \ 99 struct timespec ts; \
@@ -1077,7 +1066,7 @@ static void process_event(uint64_t ip, int counter)
1077 record_ip(ip, counter); 1066 record_ip(ip, counter);
1078} 1067}
1079 1068
1080static void process_options(int argc, char *argv[]) 1069static void process_options(int argc, char **argv)
1081{ 1070{
1082 int error = 0, counter; 1071 int error = 0, counter;
1083 1072
@@ -1255,7 +1244,7 @@ static void mmap_read(struct mmap_data *md)
1255 1244
1256 event_t event_copy; 1245 event_t event_copy;
1257 1246
1258 unsigned int size = event->header.size; 1247 size_t size = event->header.size;
1259 1248
1260 /* 1249 /*
1261 * Event straddles the mmap boundary -- header should always 1250 * Event straddles the mmap boundary -- header should always
@@ -1301,7 +1290,7 @@ static void mmap_read(struct mmap_data *md)
1301 md->prev = old; 1290 md->prev = old;
1302} 1291}
1303 1292
1304int cmd_top(int argc, const char **argv, const char *prefix) 1293int cmd_top(int argc, char **argv, const char *prefix)
1305{ 1294{
1306 struct pollfd event_array[MAX_NR_CPUS * MAX_COUNTERS]; 1295 struct pollfd event_array[MAX_NR_CPUS * MAX_COUNTERS];
1307 struct mmap_data mmap_array[MAX_NR_CPUS][MAX_COUNTERS]; 1296 struct mmap_data mmap_array[MAX_NR_CPUS][MAX_COUNTERS];
diff --git a/Documentation/perf_counter/cache.h b/Documentation/perf_counter/cache.h
index dc085640a57d..71080512fa86 100644
--- a/Documentation/perf_counter/cache.h
+++ b/Documentation/perf_counter/cache.h
@@ -94,4 +94,24 @@ static inline int is_absolute_path(const char *path)
94{ 94{
95 return path[0] == '/'; 95 return path[0] == '/';
96} 96}
97
98const char *make_absolute_path(const char *path);
99const char *make_nonrelative_path(const char *path);
100const char *make_relative_path(const char *abs, const char *base);
101int normalize_path_copy(char *dst, const char *src);
102int longest_ancestor_length(const char *path, const char *prefix_list);
103char *strip_path_suffix(const char *path, const char *suffix);
104
105extern char *mkpath(const char *fmt, ...) __attribute__((format (printf, 1, 2)));
106extern char *perf_path(const char *fmt, ...) __attribute__((format (printf, 1, 2)));
107
108extern char *mksnpath(char *buf, size_t n, const char *fmt, ...)
109 __attribute__((format (printf, 3, 4)));
110extern char *perf_snpath(char *buf, size_t n, const char *fmt, ...)
111 __attribute__((format (printf, 3, 4)));
112extern char *perf_pathdup(const char *fmt, ...)
113 __attribute__((format (printf, 1, 2)));
114
115extern size_t strlcpy(char *dest, const char *src, size_t size);
116
97#endif /* CACHE_H */ 117#endif /* CACHE_H */
diff --git a/Documentation/perf_counter/config.c b/Documentation/perf_counter/config.c
index 672d53959334..3dd13faa6a27 100644
--- a/Documentation/perf_counter/config.c
+++ b/Documentation/perf_counter/config.c
@@ -15,7 +15,6 @@ static FILE *config_file;
15static const char *config_file_name; 15static const char *config_file_name;
16static int config_linenr; 16static int config_linenr;
17static int config_file_eof; 17static int config_file_eof;
18static int zlib_compression_seen;
19 18
20const char *config_exclusive_filename = NULL; 19const char *config_exclusive_filename = NULL;
21 20
@@ -533,14 +532,6 @@ static int store_aux(const char* key, const char* value, void *cb)
533 return 0; 532 return 0;
534} 533}
535 534
536static int write_error(const char *filename)
537{
538 error("failed to write new configuration file %s", filename);
539
540 /* Same error code as "failed to rename". */
541 return 4;
542}
543
544static int store_write_section(int fd, const char* key) 535static int store_write_section(int fd, const char* key)
545{ 536{
546 const char *dot; 537 const char *dot;
@@ -673,7 +664,7 @@ int perf_config_set_multivar(const char* key, const char* value,
673{ 664{
674 int i, dot; 665 int i, dot;
675 int fd = -1, in_fd; 666 int fd = -1, in_fd;
676 int ret; 667 int ret = 0;
677 char* config_filename; 668 char* config_filename;
678 const char* last_dot = strrchr(key, '.'); 669 const char* last_dot = strrchr(key, '.');
679 670
@@ -872,90 +863,6 @@ write_err_out:
872 863
873} 864}
874 865
875static int section_name_match (const char *buf, const char *name)
876{
877 int i = 0, j = 0, dot = 0;
878 for (; buf[i] && buf[i] != ']'; i++) {
879 if (!dot && isspace(buf[i])) {
880 dot = 1;
881 if (name[j++] != '.')
882 break;
883 for (i++; isspace(buf[i]); i++)
884 ; /* do nothing */
885 if (buf[i] != '"')
886 break;
887 continue;
888 }
889 if (buf[i] == '\\' && dot)
890 i++;
891 else if (buf[i] == '"' && dot) {
892 for (i++; isspace(buf[i]); i++)
893 ; /* do_nothing */
894 break;
895 }
896 if (buf[i] != name[j++])
897 break;
898 }
899 return (buf[i] == ']' && name[j] == 0);
900}
901
902/* if new_name == NULL, the section is removed instead */
903int perf_config_rename_section(const char *old_name, const char *new_name)
904{
905 int ret = 0, remove = 0;
906 char *config_filename;
907 int out_fd;
908 char buf[1024];
909
910 if (config_exclusive_filename)
911 config_filename = strdup(config_exclusive_filename);
912 else
913 config_filename = perf_pathdup("config");
914 if (out_fd < 0) {
915 ret = error("could not lock config file %s", config_filename);
916 goto out;
917 }
918
919 if (!(config_file = fopen(config_filename, "rb"))) {
920 /* no config file means nothing to rename, no error */
921 goto unlock_and_out;
922 }
923
924 while (fgets(buf, sizeof(buf), config_file)) {
925 int i;
926 int length;
927 for (i = 0; buf[i] && isspace(buf[i]); i++)
928 ; /* do nothing */
929 if (buf[i] == '[') {
930 /* it's a section */
931 if (section_name_match (&buf[i+1], old_name)) {
932 ret++;
933 if (new_name == NULL) {
934 remove = 1;
935 continue;
936 }
937 store.baselen = strlen(new_name);
938 if (!store_write_section(out_fd, new_name)) {
939 goto out;
940 }
941 continue;
942 }
943 remove = 0;
944 }
945 if (remove)
946 continue;
947 length = strlen(buf);
948 if (write_in_full(out_fd, buf, length) != length) {
949 goto out;
950 }
951 }
952 fclose(config_file);
953 unlock_and_out:
954 out:
955 free(config_filename);
956 return ret;
957}
958
959/* 866/*
960 * Call this to report error for your variable that should not 867 * Call this to report error for your variable that should not
961 * get a boolean value (i.e. "[my] var" means "true"). 868 * get a boolean value (i.e. "[my] var" means "true").
diff --git a/Documentation/perf_counter/path.c b/Documentation/perf_counter/path.c
index 891b612ec1a9..a501a40dd2cb 100644
--- a/Documentation/perf_counter/path.c
+++ b/Documentation/perf_counter/path.c
@@ -161,45 +161,6 @@ int perf_mkstemp(char *path, size_t len, const char *template)
161} 161}
162 162
163 163
164static char *user_path(char *buf, char *path, int sz)
165{
166 struct passwd *pw;
167 char *slash;
168 int len, baselen;
169
170 if (!path || path[0] != '~')
171 return NULL;
172 path++;
173 slash = strchr(path, '/');
174 if (path[0] == '/' || !path[0]) {
175 pw = getpwuid(getuid());
176 }
177 else {
178 if (slash) {
179 *slash = 0;
180 pw = getpwnam(path);
181 *slash = '/';
182 }
183 else
184 pw = getpwnam(path);
185 }
186 if (!pw || !pw->pw_dir || sz <= strlen(pw->pw_dir))
187 return NULL;
188 baselen = strlen(pw->pw_dir);
189 memcpy(buf, pw->pw_dir, baselen);
190 while ((1 < baselen) && (buf[baselen-1] == '/')) {
191 buf[baselen-1] = 0;
192 baselen--;
193 }
194 if (slash && slash[1]) {
195 len = strlen(slash);
196 if (sz <= baselen + len)
197 return NULL;
198 memcpy(buf + baselen, slash, len + 1);
199 }
200 return buf;
201}
202
203const char *make_relative_path(const char *abs, const char *base) 164const char *make_relative_path(const char *abs, const char *base)
204{ 165{
205 static char buf[PATH_MAX + 1]; 166 static char buf[PATH_MAX + 1];
diff --git a/Documentation/perf_counter/perf.c b/Documentation/perf_counter/perf.c
index 9256f6a16446..63f8a892c0df 100644
--- a/Documentation/perf_counter/perf.c
+++ b/Documentation/perf_counter/perf.c
@@ -1,7 +1,7 @@
1#include "builtin.h" 1#include "builtin.h"
2#include "exec_cmd.h" 2#include "exec_cmd.h"
3#include "cache.h" 3#include "cache.h"
4//#include "quote.h" 4#include "quote.h"
5#include "run-command.h" 5#include "run-command.h"
6 6
7const char perf_usage_string[] = 7const char perf_usage_string[] =
@@ -132,7 +132,6 @@ static int handle_alias(int *argcp, const char ***argv)
132 const char** new_argv; 132 const char** new_argv;
133 const char *alias_command; 133 const char *alias_command;
134 char *alias_string; 134 char *alias_string;
135 int unused_nonperf;
136 135
137 alias_command = (*argv)[0]; 136 alias_command = (*argv)[0];
138 alias_string = alias_lookup(alias_command); 137 alias_string = alias_lookup(alias_command);
diff --git a/Documentation/perf_counter/util.h b/Documentation/perf_counter/util.h
index 13f8bdce7600..36e40c38e093 100644
--- a/Documentation/perf_counter/util.h
+++ b/Documentation/perf_counter/util.h
@@ -295,6 +295,20 @@ static inline char *gitstrchrnul(const char *s, int c)
295} 295}
296#endif 296#endif
297 297
298/*
299 * Wrappers:
300 */
301extern char *xstrdup(const char *str);
302extern void *xmalloc(size_t size);
303extern void *xmemdupz(const void *data, size_t len);
304extern char *xstrndup(const char *str, size_t len);
305extern void *xrealloc(void *ptr, size_t size);
306extern void *xcalloc(size_t nmemb, size_t size);
307extern void *xmmap(void *start, size_t length, int prot, int flags, int fd, off_t offset);
308extern ssize_t xread(int fd, void *buf, size_t len);
309extern ssize_t xwrite(int fd, const void *buf, size_t len);
310extern int xdup(int fd);
311extern FILE *xfdopen(int fd, const char *mode);
298static inline size_t xsize_t(off_t len) 312static inline size_t xsize_t(off_t len)
299{ 313{
300 return (size_t)len; 314 return (size_t)len;