ardix/Makefile

83 lines
2.6 KiB
Makefile
Raw Normal View History

2020-06-07 16:49:03 +02:00
#
# Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
#
# Redistribution and use in source and binary forms, with or without modification, are permitted
# provided that the following conditions are met:
#
# 1. Redistributions of source code must retain the above copyright notice, this list of
# conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright notice, this list of
# conditions and the following disclaimer in the documentation and/or other materials
# provided with the distribution.
# 3. Neither the name of the copyright holder nor the names of its contributors may be
# used to endorse or promote products derived from this software without specific prior
# written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
# FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
# WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
AVR_CC ?= $(shell which avr-gcc)
2020-06-10 16:59:42 +02:00
CC = $(AVR_CC)
2020-06-07 16:49:03 +02:00
AVR_LD ?= $(shell which avr-gcc)
2020-06-10 16:59:42 +02:00
LD = $(AVR_LD)
2020-06-07 16:49:03 +02:00
AVR_OBJCOPY ?= $(shell which avr-objcopy)
2020-06-10 16:59:42 +02:00
OBJCOPY = $(AVR_OBJCOPY)
2020-06-07 16:49:03 +02:00
EXTRA_CFLAGS ?=
CFLAGS = $(EXTRA_CFLAGS)
2020-06-10 16:59:42 +02:00
CFLAGS += -g -nodefaultlibs -fno-builtin
2020-06-07 16:49:03 +02:00
CFLAGS += -I$(PWD)/include
CFLAGS += -DARCH=$(ARCH)
CFLAGS += -mmcu=$(ARCH) -fpack-struct -std=gnu11
CFLAGS += -Wall \
-Wstrict-prototypes \
-Wredundant-decls \
-Wnested-externs -Wbad-function-cast \
-Wshadow \
-Wsign-compare -Wfloat-equal \
-Wunreachable-code \
-Wwrite-strings -Wconversion \
-Waggregate-return -Winline -Wcast-align
ifdef DEBUG
2020-06-10 16:59:42 +02:00
CFLAGS += -DDEBUG
2020-06-07 16:49:03 +02:00
endif
EXTRA_LDFLAGS ?=
LDFLAGS = $(EXTRA_LDFLAGS)
LDFLAGS += \
2020-06-10 16:59:42 +02:00
-mmcu=$(ARCH) \
2020-06-07 16:49:03 +02:00
-nodefaultlibs
2020-06-10 16:59:42 +02:00
ARDIX_ASM_SOURCES =
include arch/Makefile
2020-06-07 16:49:03 +02:00
ARDIX_SOURCES =
include init/Makefile
ARDIX_OBJS = $(ARDIX_SOURCES:.c=.o)
2020-06-10 16:59:42 +02:00
ARDIX_ASM_OBJS = $(ARDIX_ASM_SOURCES:.S=.o)
2020-06-07 16:49:03 +02:00
2020-06-10 16:59:42 +02:00
%.o: %.S | %.c
$(CC) -c -Os -o $@ $(CFLAGS) $<
2020-06-07 16:49:03 +02:00
2020-06-10 16:59:42 +02:00
ardix.elf: $(ARDIX_OBJS) $(ARDIX_ASM_OBJS)
$(LD) $(LDFLAGS) -o $@ $^
2020-06-07 16:49:03 +02:00
ardix.hex: ardix.elf
2020-06-10 16:59:42 +02:00
$(OBJCOPY) -O ihex -R .eeprom $^ $@
2020-06-07 16:49:03 +02:00
clean:
2020-06-10 16:59:42 +02:00
rm -f ardix.elf ardix.hex $(ARDIX_OBJS) $(ARDIX_ASM_OBJS)
2020-06-07 16:49:03 +02:00
all: ardix.hex