Makefile 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. TARGET = lfs.a
  2. ifneq ($(wildcard test.c main.c),)
  3. override TARGET = lfs
  4. endif
  5. CC ?= gcc
  6. AR ?= ar
  7. SIZE ?= size
  8. NM ?= nm
  9. SRC += $(wildcard *.c bd/*.c)
  10. OBJ := $(SRC:.c=.o)
  11. DEP := $(SRC:.c=.d)
  12. ASM := $(SRC:.c=.s)
  13. ifdef DEBUG
  14. override CFLAGS += -O0 -g3
  15. else
  16. override CFLAGS += -Os
  17. endif
  18. ifdef WORD
  19. override CFLAGS += -m$(WORD)
  20. endif
  21. ifdef TRACE
  22. override CFLAGS += -DLFS_YES_TRACE
  23. endif
  24. override CFLAGS += -I.
  25. override CFLAGS += -std=c99 -Wall -pedantic
  26. override CFLAGS += -Wextra -Wshadow -Wjump-misses-init -Wundef
  27. ifdef VERBOSE
  28. override TFLAGS += -v
  29. override SFLAGS += -v
  30. endif
  31. all: $(TARGET)
  32. asm: $(ASM)
  33. size: $(OBJ)
  34. $(SIZE) -t $^
  35. code_size:
  36. ./scripts/code_size.py $(SFLAGS)
  37. test:
  38. ./scripts/test.py $(TFLAGS)
  39. .SECONDEXPANSION:
  40. test%: tests/test$$(firstword $$(subst \#, ,%)).toml
  41. ./scripts/test.py $@ $(TFLAGS)
  42. -include $(DEP)
  43. lfs: $(OBJ)
  44. $(CC) $(CFLAGS) $^ $(LFLAGS) -o $@
  45. %.a: $(OBJ)
  46. $(AR) rcs $@ $^
  47. %.o: %.c
  48. $(CC) -c -MMD $(CFLAGS) $< -o $@
  49. %.s: %.c
  50. $(CC) -S $(CFLAGS) $< -o $@
  51. clean:
  52. rm -f $(TARGET)
  53. rm -f $(OBJ)
  54. rm -f $(DEP)
  55. rm -f $(ASM)
  56. rm -f tests/*.toml.*
  57. rm -f sizes/*