1 # Makefile fragment - requires GNU make
3 # Copyright (c) 2019-2021, Arm Limited.
4 # SPDX-License-Identifier: MIT
10 all-string bench-string check-string install-string clean-string:
11 @echo "*** Please set ARCH in config.mk. ***"
15 string-lib-srcs := $(wildcard $(S)/$(ARCH)/*.[cS])
16 string-test-srcs := $(wildcard $(S)/test/*.c)
17 string-bench-srcs := $(wildcard $(S)/bench/*.c)
19 string-includes := $(patsubst $(S)/%,build/%,$(wildcard $(S)/include/*.h))
22 build/lib/libstringlib.so \
23 build/lib/libstringlib.a \
26 build/bin/test/memcpy \
27 build/bin/test/memmove \
28 build/bin/test/memset \
29 build/bin/test/memchr \
30 build/bin/test/memrchr \
31 build/bin/test/memcmp \
32 build/bin/test/__mtag_tag_region \
33 build/bin/test/__mtag_tag_zero_region \
34 build/bin/test/strcpy \
35 build/bin/test/stpcpy \
36 build/bin/test/strcmp \
37 build/bin/test/strchr \
38 build/bin/test/strrchr \
39 build/bin/test/strchrnul \
40 build/bin/test/strlen \
41 build/bin/test/strnlen \
42 build/bin/test/strncmp
45 build/bin/bench/memcpy \
46 build/bin/bench/strlen
48 string-lib-objs := $(patsubst $(S)/%,$(B)/%.o,$(basename $(string-lib-srcs)))
49 string-test-objs := $(patsubst $(S)/%,$(B)/%.o,$(basename $(string-test-srcs)))
50 string-bench-objs := $(patsubst $(S)/%,$(B)/%.o,$(basename $(string-bench-srcs)))
54 $(string-lib-objs:%.o=%.os) \
65 all-string: $(string-libs) $(string-tests) $(string-benches) $(string-includes)
67 $(string-objs): $(string-includes)
68 $(string-objs): CFLAGS_ALL += $(string-cflags)
70 $(string-test-objs): CFLAGS_ALL += -D_GNU_SOURCE
72 build/lib/libstringlib.so: $(string-lib-objs:%.o=%.os)
73 $(CC) $(CFLAGS_ALL) $(LDFLAGS) -shared -o $@ $^
75 build/lib/libstringlib.a: $(string-lib-objs)
80 build/bin/test/%: $(B)/test/%.o build/lib/libstringlib.a
81 $(CC) $(CFLAGS_ALL) $(LDFLAGS) -static -o $@ $^ $(LDLIBS)
83 build/bin/bench/%: $(B)/bench/%.o build/lib/libstringlib.a
84 $(CC) $(CFLAGS_ALL) $(LDFLAGS) -static -o $@ $^ $(LDLIBS)
86 build/include/%.h: $(S)/include/%.h
89 build/bin/%.sh: $(S)/test/%.sh
92 string-tests-out = $(string-tests:build/bin/test/%=build/string/test/%.out)
94 build/string/test/%.out: build/bin/test/%
95 $(EMULATOR) $^ | tee $@.tmp
98 check-string: $(string-tests-out)
101 bench-string: $(string-benches)
102 $(EMULATOR) build/bin/bench/strlen
103 $(EMULATOR) build/bin/bench/memcpy
106 $(string-libs:build/lib/%=$(DESTDIR)$(libdir)/%) \
107 $(string-includes:build/include/%=$(DESTDIR)$(includedir)/%)
110 rm -f $(string-files)
113 .PHONY: all-string bench-string check-string install-string clean-string