]> git.ipfire.org Git - thirdparty/glibc.git/blame - benchtests/Makefile
Test 64-byte alignment in memset benchtest
[thirdparty/glibc.git] / benchtests / Makefile
CommitLineData
f7a9f785 1# Copyright (C) 2013-2016 Free Software Foundation, Inc.
8cfdb7e0
SP
2# This file is part of the GNU C Library.
3
4# The GNU C Library is free software; you can redistribute it and/or
5# modify it under the terms of the GNU Lesser General Public
6# License as published by the Free Software Foundation; either
7# version 2.1 of the License, or (at your option) any later version.
8
9# The GNU C Library is distributed in the hope that it will be useful,
10# but WITHOUT ANY WARRANTY; without even the implied warranty of
11# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12# Lesser General Public License for more details.
13
14# You should have received a copy of the GNU Lesser General Public
15# License along with the GNU C Library; if not, see
16# <http://www.gnu.org/licenses/>.
17
8cfdb7e0 18# Makefile for benchmark tests. The only useful target here is `bench`.
3ce9e010 19# Add benchmark functions in alphabetical order.
8cfdb7e0 20
67fc5637
CD
21PYTHON := python
22
8cfdb7e0 23subdir := benchtests
a5f891ac
JM
24
25include ../Makeconfig
aad287f3
SP
26bench-math := acos acosh asin asinh atan atanh cos cosh exp exp2 log log2 \
27 modf pow rint sin sincos sinh sqrt tan tanh
bb9c256f
SP
28
29bench-pthread := pthread_once
30
aad287f3
SP
31bench-string := ffs ffsll
32
33bench := $(bench-math) $(bench-pthread) $(bench-string)
3ce9e010 34
c1f75dc3 35# String function benchmarks.
aad287f3
SP
36string-benchset := bcopy bzero memccpy memchr memcmp memcpy memmem memmove \
37 mempcpy memset rawmemchr stpcpy stpncpy strcasecmp strcasestr \
38 strcat strchr strchrnul strcmp strcpy strcspn strlen \
39 strncasecmp strncat strncmp strncpy strnlen strpbrk strrchr \
40 strspn strstr strcpy_chk stpcpy_chk memrchr strsep strtok \
41 strcoll
42wcsmbs-benchset := wcslen wcsnlen wcscpy wcpcpy wcsncpy wcpncpy wcscat wcsncat \
43 wcscmp wcsncmp wcschr wcschrnul wcsrchr wcsspn wcspbrk wcscspn \
44 wmemchr wmemset wmemcmp
45string-benchset-all := $(string-benchset) ${wcsmbs-benchset}
c1f75dc3 46
60ccaf75
LH
47# We have to generate locales
48LOCALES := en_US.UTF-8 tr_TR.UTF-8 cs_CZ.UTF-8 fa_IR.UTF-8 fr_FR.UTF-8 \
49 ja_JP.UTF-8 si_LK.UTF-8 en_GB.UTF-8 vi_VN.UTF-8 ar_SA.UTF-8 \
50 da_DK.UTF-8 pl_PL.UTF-8 pt_PT.UTF-8 el_GR.UTF-8 ru_RU.UTF-8 \
51 iw_IL.UTF-8 is_IS.UTF-8 es_ES.UTF-8 hi_IN.UTF-8 sv_SE.UTF-8 \
52 hu_HU.UTF-8 it_IT.UTF-8 sr_RS.UTF-8 zh_CN.UTF-8
53include ../gen-locales.mk
54
aad287f3 55stdlib-benchset := strtod
450a2e2d 56
aad287f3 57stdio-common-benchset := sprintf
608f8971 58
cb2f668d
WD
59math-benchset := math-inlines
60
aad287f3 61benchset := $(string-benchset-all) $(stdlib-benchset) $(stdio-common-benchset) \
cb2f668d 62 $(math-benchset)
c1f75dc3 63
f6c55796
WN
64CFLAGS-bench-ffs.c += -fno-builtin
65CFLAGS-bench-ffsll.c += -fno-builtin
66
b01ee67c
WN
67bench-malloc := malloc-thread
68
79520f4b 69$(addprefix $(objpfx)bench-,$(bench-math)): $(libm)
cb2f668d 70$(addprefix $(objpfx)bench-,$(math-benchset)): $(libm)
79520f4b 71$(addprefix $(objpfx)bench-,$(bench-pthread)): $(shared-thread-library)
b01ee67c 72$(objpfx)bench-malloc-thread: $(shared-thread-library)
7849ff93 73
8fc1bee5
SP
74\f
75
76# Rules to build and execute the benchmarks. Do not put any benchmark
77# parameters beyond this point.
78
c1f75dc3
SP
79# We don't want the benchmark programs to run in parallel since that could
80# affect their performance.
81.NOTPARALLEL:
82
8cfdb7e0 83include ../Rules
8fc1bee5
SP
84
85binaries-bench := $(addprefix $(objpfx)bench-,$(bench))
c1f75dc3 86binaries-benchset := $(addprefix $(objpfx)bench-,$(benchset))
b01ee67c 87binaries-bench-malloc := $(addprefix $(objpfx)bench-,$(bench-malloc))
8fc1bee5 88
d569c6ee
SP
89# The default duration: 10 seconds.
90ifndef BENCH_DURATION
91BENCH_DURATION := 10
92endif
93
50b818bf 94CPPFLAGS-nonlib += -DDURATION=$(BENCH_DURATION)
d569c6ee 95
43fe811b
SP
96# Use clock_gettime to measure performance of functions. The default is to use
97# HP_TIMING if it is available.
98ifdef USE_CLOCK_GETTIME
99CPPFLAGS-nonlib += -DUSE_CLOCK_GETTIME
100endif
101
56737508
SP
102DETAILED_OPT :=
103
104ifdef DETAILED
105DETAILED_OPT := -d
106endif
107
4856bcd2
SP
108# This makes sure CPPFLAGS-nonlib and CFLAGS-nonlib are passed
109# for all these modules.
b01ee67c
WN
110cpp-srcs-left := $(binaries-benchset:=.c) $(binaries-bench:=.c) \
111 $(binaries-bench-malloc:=.c)
4856bcd2
SP
112lib := nonlib
113include $(patsubst %,$(..)cppflags-iterator.mk,$(cpp-srcs-left))
114
970c602a
WN
115extra-objs += json-lib.o
116
43fe811b 117bench-deps := bench-skeleton.c bench-timing.h Makefile
acb4325f 118
8fc1bee5 119run-bench = $(test-wrapper-env) \
8540f6d2 120 $(run-program-env) \
87da630b 121 $($*-ENV) $(test-via-rtld-prefix) $${run}
8fc1bee5 122
cb5e4aad
SP
123timing-type := $(objpfx)bench-timing-type
124
a2964074
SP
125bench-clean:
126 rm -f $(binaries-bench) $(addsuffix .o,$(binaries-bench))
c1f75dc3 127 rm -f $(binaries-benchset) $(addsuffix .o,$(binaries-benchset))
b01ee67c 128 rm -f $(binaries-bench-malloc) $(addsuffix .o,$(binaries-bench-malloc))
cb5e4aad 129 rm -f $(timing-type) $(addsuffix .o,$(timing-type))
c1f75dc3 130
60ccaf75 131bench: $(timing-type) $(gen-locales) bench-set bench-func bench-malloc
c1f75dc3
SP
132
133bench-set: $(binaries-benchset)
134 for run in $^; do \
135 echo "Running $${run}"; \
136 $(run-bench) > $${run}.out; \
137 done
a2964074 138
b01ee67c
WN
139bench-malloc: $(binaries-bench-malloc)
140 run=$(objpfx)bench-malloc-thread; \
141 for thr in 1 8 16 32; do \
142 echo "Running $${run} $${thr}"; \
143 $(run-bench) $${thr} > $${run}-$${thr}.out; \
144 done
145
cb5e4aad
SP
146# Build and execute the benchmark functions. This target generates JSON
147# formatted bench.out. Each of the programs produce independent JSON output,
148# so one could even execute them individually and process it using any JSON
149# capable language or tool.
c1f75dc3 150bench-func: $(binaries-bench)
970c602a
WN
151 { timing_type=$$($(timing-type)); \
152 echo "{\"timing_type\": \"$${timing_type}\","; \
153 echo " \"functions\": {"; \
cb5e4aad
SP
154 for run in $^; do \
155 if ! [ "x$${run}" = "x$<" ]; then \
156 echo ","; \
157 fi; \
206a6699 158 echo "Running $${run}" >&2; \
56737508 159 $(run-bench) $(DETAILED_OPT); \
cb5e4aad 160 done; \
970c602a
WN
161 echo; \
162 echo " }"; \
cb5e4aad 163 echo "}"; } > $(objpfx)bench.out-tmp; \
8fc1bee5
SP
164 if [ -f $(objpfx)bench.out ]; then \
165 mv -f $(objpfx)bench.out $(objpfx)bench.out.old; \
166 fi; \
167 mv -f $(objpfx)bench.out-tmp $(objpfx)bench.out
67fc5637 168 $(PYTHON) scripts/validate_benchout.py $(objpfx)bench.out \
42b1161e 169 scripts/benchout.schema.json
8fc1bee5 170
b01ee67c
WN
171$(timing-type) $(binaries-bench) $(binaries-benchset) \
172 $(binaries-bench-malloc): %: %.o $(objpfx)json-lib.o \
8fc1bee5
SP
173 $(sort $(filter $(common-objpfx)lib%,$(link-libc))) \
174 $(addprefix $(csu-objpfx),start.o) $(+preinit) $(+postinit)
87da630b 175 $(+link-tests)
8fc1bee5 176
acb4325f 177$(objpfx)bench-%.c: %-inputs $(bench-deps)
8fc1bee5
SP
178 { if [ -n "$($*-INCLUDE)" ]; then \
179 cat $($*-INCLUDE); \
180 fi; \
67fc5637 181 $(PYTHON) scripts/bench.py $(patsubst %-inputs,%,$<); } > $@-tmp
8fc1bee5 182 mv -f $@-tmp $@