Projects
home:lf14:branches:Mega:23.09
glibc
_service:tar_scm:bench.mk
Sign Up
Log In
Username
Password
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File _service:tar_scm:bench.mk of Package glibc
objpfx = $(prefix)/$(ver)/usr/libexec/glibc-benchtests/ bench-math := acos acosh asin asinh atan atanh cos cosh exp exp2 ffs ffsll \ log log2 modf pow rint sin sincos sinh sqrt tan tanh bench-pthread := pthread_once bench := $(bench-math) $(bench-pthread) run-bench := $(prefix)/$(ver)/lib64/ld-linux-x86-64.so.2 --library-path $(prefix)/$(ver)/lib64 $${run} # String function benchmarks. string-bench := bcopy bzero memccpy memchr memcmp memcpy memmem memmove \ mempcpy memset rawmemchr stpcpy stpncpy strcasecmp strcasestr \ strcat strchr strchrnul strcmp strcpy strcspn strlen \ strncasecmp strncat strncmp strncpy strnlen strpbrk strrchr \ strspn strstr strcpy_chk stpcpy_chk memrchr strsep strtok string-bench-all := $(string-bench) stdlib-bench := strtod benchset := $(string-bench-all) $(stdlib-bench) bench-malloc := malloc-thread binaries-bench := $(addprefix $(objpfx)bench-,$(bench)) binaries-benchset := $(addprefix $(objpfx)bench-,$(benchset)) binaries-bench-malloc := $(addprefix $(objpfx)bench-,$(bench-malloc)) DETAILED_OPT := ifdef DETAILED DETAILED_OPT := -d endif bench: bench-set bench-func bench-malloc bench-set: $(binaries-benchset) for run in $^; do \ outfile=$(prefix)/$$(basename $${run}.$(ver).out); \ echo "Running $${run}"; \ $(run-bench) > $${outfile}.tmp; \ mv $${outfile}{.tmp,}; \ done bench-malloc: $(binaries-bench-malloc) run=$(objpfx)bench-malloc-thread; \ outfile=$(prefix)/$$(basename $${run}.$(ver).out); \ for thr in 1 8 16 32; do \ echo "Running $${run} $${thr}"; \ $(run-bench) $${thr} > $${outfile}.tmp; \ mv $${outfile}{.tmp,}; \ done # Build and execute the benchmark functions. This target generates JSON # formatted bench.out. Each of the programs produce independent JSON output, # so one could even execute them individually and process it using any JSON # capable language or tool. bench-func: $(binaries-bench) { echo "{\"timing_type\": \"hp-timing\","; \ echo " \"functions\": {"; \ for run in $^; do \ if ! [ "x$${run}" = "x$<" ]; then \ echo ","; \ fi; \ echo "Running $${run}" >&2; \ $(run-bench) $(DETAILED_OPT); \ done; \ echo; \ echo " }"; \ echo "}"; } > $(prefix)/bench.$(ver).out-tmp; \ if [ -f $(prefix)/bench.$(ver).out ]; then \ mv -f $(prefix)/bench.$(ver).out{,.old}; \ fi; \ mv -f $(prefix)/bench.$(ver).out{-tmp,} # scripts/validate_benchout.py bench.out \ # scripts/benchout.schema.json
Locations
Projects
Search
Status Monitor
Help
Open Build Service
OBS Manuals
API Documentation
OBS Portal
Reporting a Bug
Contact
Mailing List
Forums
Chat (IRC)
Twitter
Open Build Service (OBS)
is an
openSUSE project
.
浙ICP备2022010568号-2