blob: e6480d732d693d3b483569623ab7e350df236a84 [file] [log] [blame]
CFLAGS = -g -O2 -Wall $(CPPFLAGS)
TARGET = $(TOPDIR)/include/asm-ia64/offsets.h
mrproper: clean
rm -f $(TARGET)
rm -f print_offsets.s print_offsets offsets.h
fastdep: offsets.h
@if ! cmp -s offsets.h ${TARGET}; then \
echo -e "*** Updating ${TARGET}..."; \
cp offsets.h ${TARGET}; \
else \
echo "*** ${TARGET} is up to date"; \
# If we're cross-compiling, we use the cross-compiler to translate
# print_offsets.c into an assembly file and then awk to translate this
# file into offsets.h. This avoids having to use a simulator to
# generate this file. This is based on an idea suggested by Asit
# Mallick. If we're running natively, we can of course just build
# print_offsets and run it. --davidm
ifeq ($(CROSS_COMPILE),)
offsets.h: print_offsets
./print_offsets > offsets.h
comma := ,
print_offsets: emptyoffsets print_offsets.c FORCE_RECOMPILE
$(CC) $(CFLAGS) -DKBUILD_BASENAME=$(subst $(comma),_,$(subst -,_,$(*F))) print_offsets.c -o $@
offsets.h: print_offsets.s
$(AWK) -f print_offsets.awk $^ > $@
print_offsets.s: emptyoffsets print_offsets.c
$(CC) $(CFLAGS) -DKBUILD_BASENAME=$(subst $(comma),_,$(subst -,_,$(*F))) -S print_offsets.c -o $@
# The TARGET offsets.h is included by ptrace.h, which is included by
# print_offsets.c, so can't compile print_offsets.c to create offsets.h
# until we already have offsets.h. Break the chicken-and-egg cycle by
# creating a dummy offsets.h with sufficient define's to bootstrap
# the first compilation of print_offsets.c.
test -f ${TARGET} || echo '#define IA64_TASK_THREAD_OFFSET 0' > ${TARGET}
.PHONY: all modules modules_install