diff options
author | Mattias Andrée <maandree@kth.se> | 2023-12-05 00:03:04 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@kth.se> | 2023-12-05 00:03:04 +0100 |
commit | 58dd684c4e86944301959a140dbed9746df35779 (patch) | |
tree | a2702ea4f66b2a58711ee22eb7449c74b1ecf0d1 /Makefile | |
parent | First commit (diff) | |
download | libsyscalls-58dd684c4e86944301959a140dbed9746df35779.tar.gz libsyscalls-58dd684c4e86944301959a140dbed9746df35779.tar.bz2 libsyscalls-58dd684c4e86944301959a140dbed9746df35779.tar.xz |
Second commit
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
-rw-r--r-- | Makefile | 38 |
1 files changed, 35 insertions, 3 deletions
@@ -1,3 +1,4 @@ +# See LICENSE file for copyright and license details. .POSIX: # Choose either yes or no (determines whether system call, @@ -50,6 +51,9 @@ include $(CONFIGFILE) #extended for each support operating system with the operating system's name as appropriate for filenames OPERATING_SYSTEMS = +#extended with supported architectures for each operating system +TEST_ENV = + #extended for each support operating system with the number of syscall parameters they use NPARAMS = @@ -81,9 +85,26 @@ SUBHDR =\ libsyscalls/internal-end.h\ libsyscalls/short-enums.h +TESTUTILS =\ + testutil/get-datatype-description.tu\ + testutil/get-error.tu\ + testutil/get-section-fraction.tu\ + testutil/get-signals.tu\ + testutil/get-syscall-errors.tu\ + testutil/get-syscall-range.tu\ + testutil/is-section-half.tu\ + testutil/is-section-quarter.tu\ + testutil/is-datatype-struct.tu\ + testutil/list-errors.tu\ + testutil/perror-all.tu\ + testutil/perror-bad.tu\ + testutil/strerror-all.tu\ + testutil/strerror-bad.tu + + .SUFFIXES: -.SUFFIXES: .lo .o .c +.SUFFIXES: .lo .o .c .tu include linux/$(LINUX_SUPPORT).mk @@ -93,11 +114,14 @@ include $(CONFIGFILE) # Reloading the user's config as the makefiles for the OS # may have made changes to what is supported +TEST_ENV += SUPPORTED_OSES="$(OPERATING_SYSTEMS)" + LOBJ = $(OBJ:.o=.lo) $(OBJ): $(HDR) $(LOBJ): $(HDR) +$(TESTUTILS): $(HDR) libsyscalls.a .c.o: $(CC) -c -o $@ $< $(CFLAGS) $(IMPORTANT_CFLAGS) $(CPPFLAGS) $(IMPORTANT_CPPFLAGS) @@ -105,6 +129,9 @@ $(LOBJ): $(HDR) .c.lo: $(CC) -fPIC -c -o $@ $< $(CFLAGS) $(IMPORTANT_CFLAGS) $(CPPFLAGS) $(IMPORTANT_CPPFLAGS) +.c.tu: + $(CC) -o $@ $< libsyscalls.a $(CFLAGS) $(CPPFLAGS) + libsyscalls.a: $(OBJ) @rm -f -- $@ $(AR) rc $@ $(OBJ) @@ -113,6 +140,11 @@ libsyscalls.a: $(OBJ) libsyscalls.$(LIBEXT): $(LOBJ) $(CC) $(LIBFLAGS) -o $@ $(LOBJ) $(LDFLAGS) + +check: $(TESTUTILS) + env CPP="$(CPP)" $(TEST_ENV) ./test + + install: libsyscalls.a libsyscalls.$(LIBEXT) mkdir -p -- "$(DESTDIR)$(PREFIX)/lib" mkdir -p -- "$(DESTDIR)$(PREFIX)/include/libsyscalls" @@ -143,7 +175,7 @@ buildclean: semiclean semiclean: -rm -f -- *.o *.lo *.su *.gch *.gcov *.gcno *.gcda .*.tmp -rm -f -- */*.o */*.lo */*.su */*.gch */*.gcov */*.gcno */*.gcda - -rm -f -- *.a *.so *.so.* *.dll *.dylib *.$(LIBEXT) + -rm -f -- *.a *.so *.so.* *.dll *.dylib *.$(LIBEXT) */*.tu -rm -f -- libsyscalls/short-enums.h -.PHONY: all download install uninstall clean semiclean +.PHONY: all download check install uninstall clean semiclean |