summaryrefslogtreecommitdiffstats
path: root/mk
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2023-12-03 19:23:35 +0100
committerMattias Andrée <maandree@kth.se>2023-12-03 19:23:35 +0100
commitc131f122778c62f920a99bbf854ced4a37ee8b03 (patch)
tree14c933f98f4d64dffb0a594bc40dd5121c6c5a8e /mk
downloadlibsyscalls-c131f122778c62f920a99bbf854ced4a37ee8b03.tar.gz
libsyscalls-c131f122778c62f920a99bbf854ced4a37ee8b03.tar.bz2
libsyscalls-c131f122778c62f920a99bbf854ced4a37ee8b03.tar.xz
First commit
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'mk')
-rw-r--r--mk/generate.mk127
-rw-r--r--mk/linux.mk6
-rw-r--r--mk/macos.mk6
-rw-r--r--mk/windows.mk6
4 files changed, 145 insertions, 0 deletions
diff --git a/mk/generate.mk b/mk/generate.mk
new file mode 100644
index 0000000..ec33cdc
--- /dev/null
+++ b/mk/generate.mk
@@ -0,0 +1,127 @@
+NPARAMS != printf '%d\n' 1 $(NPARAMS) | sort -n | sed -n '$$p'
+
+IMPORTANT_CPPFLAGS += -DNPARAMS="$(NPARAMS)"
+
+GET_SYSCALL_RANGE_GEN != printf 'generated/get_syscall_range.%s.c\n' $(OPERATING_SYSTEMS)
+
+
+libsyscalls_get_syscall_range.o: $(GET_SYSCALL_RANGE_GEN) generated/get_syscall_range.c
+libsyscalls_get_syscall_range.lo: $(GET_SYSCALL_RANGE_GEN) generated/get_syscall_range.c
+
+libsyscalls_get_syscall_display_info.o: generated/symbols.c
+libsyscalls_get_syscall_display_info.lo: generated/symbols.c
+
+libsyscalls_get_signals.o: generated/signals.c
+libsyscalls_get_signals.lo: generated/signals.c
+
+libsyscalls_get_syscall_errors.o: generated/errors.c
+libsyscalls_get_syscall_errors.lo: generated/errors.c
+
+libsyscalls_get_datatype_description.o: generated/types.c
+libsyscalls_get_datatype_description.lo: generated/types.c
+
+
+$(GET_SYSCALL_RANGE_GEN): get_syscall_range.template.c mk/generate.mk
+ mkdir -p -- generated
+ set -e; \
+ lowercase="$$(printf '%s\n' "$@" | cut -d . -f 2)"; \
+ uppercase="$$(printf '%s\n' "$$lowercase" | tr '[a-z]' '[A-Z]')"; \
+ sed -e "s/zzz/$$lowercase/g" -e "s/ZZZ/$$uppercase/g" < get_syscall_range.template.c > $@
+
+generated/get_syscall_range.c: Makefile mk/generate.mk
+ printf '\43include "get_syscall_range.%s.c"\n' $(OPERATING_SYSTEMS) > $@
+
+generated/symbols.c: Makefile mk/generate.mk
+ mkdir -p -- generated
+ printf '\43include "../%s/symbols.c"\n' $(OPERATING_SYSTEMS) > $@
+
+generated/signals.c: Makefile mk/generate.mk
+ mkdir -p -- generated
+ printf '\43include "../%s/signals.c"\n' $(OPERATING_SYSTEMS) > $@
+
+generated/errors.c: Makefile mk/generate.mk
+ mkdir -p -- generated
+ printf '\43include "../%s/errors.c"\n' $(OPERATING_SYSTEMS) > $@
+
+generated/types.c: Makefile mk/generate.mk
+ mkdir -p -- generated
+ printf '\43include "../%s/types.c"\n' $(OPERATING_SYSTEMS) > $@
+
+generated/arches.h: Makefile mk/generate.mk
+ mkdir -p -- generated
+ printf '\43include "%s-arches.h"\n' $(OPERATING_SYSTEMS) > $@
+
+generated/oses.h: Makefile mk/generate.mk
+ mkdir -p -- generated
+ set -e;\
+ for os in $(OPERATING_SYSTEMS); do\
+ printf '%s\n' "$$(printf '%s\n' "$$os" | tr '[a-z]' '[A-Z]')" "$$os";\
+ done |\
+ (printf '\43define LIST_OSES(X, D)\\\n' &&\
+ xargs printf '\tX(%s, %s) D\\\n';\
+ ) | sed '$$s/ D\\//' > $@
+
+generated/lowercase.h: libsyscalls.h mk/generate.mk
+ mkdir -p -- generated
+ sed -n 's/^\s*LIBSYSCALLS_CAT_\([A-Z0-9_]\+\).*$$/\1/p' < libsyscalls.h \
+ | grep -v '^\(SUPPORT_PENDING\|NOT_IMPLEMENTED\)$$' \
+ | while read uppercase; do \
+ printf '\43define LOWERCASE_%s %s\n' \
+ "$$uppercase" \
+ "$$(printf '%s\n' "$$uppercase" | tr '[A-Z]' '[a-z]')"; \
+ done > $@
+
+libsyscalls/short-enums.h: libsyscalls.h mk/generate.mk
+ rm -f -- $@
+ printf '\43%s\n' > $@ \
+ 'ifndef LIBSYSCALLS_H' \
+ ' error Do not include this header file directly' \
+ 'endif'
+ sed -n 's/^.*\b\(enum_libsyscalls_[A-Za-z0-9_]\+\)\([^A-Za-z0-9_].*\|\)$$/\1/p' < libsyscalls.h \
+ | sort -u \
+ | xargs printf 'typedef unsigned short int %s;\n' \
+ >> $@
+ chmod -- a-w $@
+
+generated/macros.h: common.h mk/generate.mk
+ set -e;\
+ for find in COUNT_ARG_PAIRS PARAMS_BUILD_TYPES; do \
+ text="$$(sed -n 's/^\s*\x23\s*define\s\+'"$$find"'_1(/&/p' < common.h)"; \
+ i=1; while (( i <= $(NPARAMS) )); do \
+ j=$$(( i + 1 )); \
+ printf '%s\n' "$$text" | sed -e "s/_2/_$$j/g" -e "s/_1/_$$i/g"; \
+ i=$$j; \
+ done; \
+ done > $@;
+ (set -e; \
+ nparamspairs="$$(i=1; while (( i <= $(NPARAMS) )); do printf '%s\n' $$i $$i; : $$(( i++ )); done)"; \
+ printf '\43define PARAMS_BUILD_MASK(MASK, ...)\\\n'; \
+ printf '\t0 PARAMS_BUILD_MASK_(MASK, _, 0'; \
+ printf ', _, %s%s' $$nparamspairs; \
+ printf ')\n'; \
+ printf '\43define PARAMS_BUILD_MASK_(MASK'; \
+ printf ', A%s, x%s' $$nparamspairs; \
+ printf ', ...)'; \
+ printf '\\\n\tMASK\43\43_\43\43A%s(1U << %s)' $$nparamspairs; \
+ printf '\n'; \
+ ) >> $@
+ (set -e; \
+ for a in IN OUT SYM; do b=; \
+ for b in "$$b" "$$b"_IN; do \
+ for b in "$$b" "$$b"_OUT; do \
+ for b in "$$b" "$$b"_SYM; do \
+ c=; if printf '%s\n' "$$b" | grep "$$a" >/dev/null; then \
+ c=' |X'; \
+ fi; \
+ printf '\43define %s%s(X)%s\n' "$$a" "$$b" "$$c"; \
+ done; done; done; \
+ done) | sed 's/_IN_OUT/_BI/' | sed 's/\(\s[A-Z]\+\)(/\1__(/' >> $@
+
+
+SELF_CHECK_COMMAND = test "$(NPARAMS)" -le 16
+SELF_CHECK_RULE != if ! $(SELF_CHECK_COMMAND); then printf 'self-check\n'; fi
+libsyscalls.a: $(SELF_CHECK_RULE)
+libsyscalls.$(LIBEXT): $(SELF_CHECK_RULE)
+self-check:; $(SELF_CHECK_COMMAND)
+
+.PHONY: self-check
diff --git a/mk/linux.mk b/mk/linux.mk
new file mode 100644
index 0000000..ad58f69
--- /dev/null
+++ b/mk/linux.mk
@@ -0,0 +1,6 @@
+LIBEXT = so
+LIBFLAGS = -shared -Wl,-soname,lib$(LIB_NAME).$(LIBEXT).$(LIB_MAJOR)
+LIBMAJOREXT = $(LIBEXT).$(LIB_MAJOR)
+LIBMINOREXT = $(LIBEXT).$(LIB_VERSION)
+
+FIX_INSTALL_NAME = :
diff --git a/mk/macos.mk b/mk/macos.mk
new file mode 100644
index 0000000..e222491
--- /dev/null
+++ b/mk/macos.mk
@@ -0,0 +1,6 @@
+LIBEXT = dylib
+LIBFLAGS = -dynamiclib -Wl,-compatibility_version,$(LIB_MAJOR) -Wl,-current_version,$(LIB_VERSION)
+LIBMAJOREXT = $(LIB_MAJOR).$(LIBEXT)
+LIBMINOREXT = $(LIB_VERSION).$(LIBEXT)
+
+FIX_INSTALL_NAME = install_name_tool -id "$(PREFIX)/lib/libsyscalls.$(LIBMAJOREXT)"
diff --git a/mk/windows.mk b/mk/windows.mk
new file mode 100644
index 0000000..ed5ec8d
--- /dev/null
+++ b/mk/windows.mk
@@ -0,0 +1,6 @@
+LIBEXT = dll
+LIBFLAGS = -shared
+LIBMAJOREXT = $(LIB_MAJOR).$(LIBEXT)
+LIBMINOREXT = $(LIB_VERSION).$(LIBEXT)
+
+FIX_INSTALL_NAME = :