This makes the m68k make rules usable from other makefiles. This also adds scsp start address macros. The sound.c example-fragment is deleted, as a better version now exists in saturn-examples.
59 lines
1.1 KiB
Makefile
59 lines
1.1 KiB
Makefile
LIB ?= .
|
|
OPT ?= -Og
|
|
|
|
ARCH = -march=68000 -mcpu=68000
|
|
|
|
AARCH = $(ARCH)
|
|
AFLAGS = -g -gdwarf-4
|
|
|
|
CARCH = $(ARCH) -mtune=68000
|
|
CFLAGS += -falign-functions=4 -ffunction-sections -fdata-sections -fshort-enums -ffreestanding -nostdlib
|
|
CFLAGS += -Wall -Werror -Wfatal-errors -Wno-error=unused-variable -g -gdwarf-4 $(OPT)
|
|
LDFLAGS = --gc-sections --no-warn-rwx-segment --print-memory-usage --entry=start
|
|
CXXFLAGS = -fno-exceptions -fno-rtti
|
|
|
|
TARGET = m68k-none-elf-
|
|
CC = $(TARGET)gcc
|
|
CXX = $(TARGET)g++
|
|
AS = $(TARGET)as
|
|
LD = $(TARGET)ld
|
|
OBJCOPY = $(TARGET)objcopy
|
|
OBJDUMP = $(TARGET)objdump
|
|
|
|
define BUILD_BINARY_O
|
|
$(OBJCOPY) \
|
|
-I binary -O elf32-m68k -B m68k \
|
|
--rename-section .data=.data.$(basename $@) \
|
|
$< $@
|
|
endef
|
|
|
|
all: main.bin
|
|
|
|
%.o: %.s
|
|
$(AS) $(AARCH) $(AFLAGS) $< -o $@
|
|
|
|
%.o: %.S
|
|
$(CC) $(CFLAGS) $(CARCH) -c $< -o $@
|
|
|
|
%.o: %.c
|
|
$(CC) $(CFLAGS) $(CARCH) -c $< -o $@
|
|
|
|
%.o: %.cpp
|
|
$(CXX) $(CFLAGS) $(CXXFLAGS) $(CARCH) -c $< -o $@
|
|
|
|
%.elf:
|
|
$(LD) $(LDFLAGS) -T $(LIB)/m68k/m68k.lds $^ -o $@
|
|
|
|
%.bin: %.elf
|
|
$(OBJCOPY) -O binary $< $@
|
|
|
|
#OBJ = vectors.o main.o
|
|
|
|
clean:
|
|
rm -f *.iso *.o *.bin *.elf *.cue
|
|
|
|
.SUFFIXES:
|
|
.INTERMEDIATE:
|
|
.SECONDARY:
|
|
.PHONY: all clean
|