Revision 183
Added by markw about 11 years ago
| Makefile | ||
|---|---|---|
|
CP = $(BASE)-objcopy
|
||
|
DUMP = $(BASE)-objdump
|
||
|
|
||
|
HOST_CC = gcc
|
||
|
HOST_LD = gcc
|
||
|
|
||
|
HOST_CFLAGS = -g -DLINUX_BUILD -DLITTLE_ENDIAN -fno-builtin
|
||
|
HOST_CFLAGS += -W -Wall
|
||
|
HOST_LDFLAGS = -g
|
||
|
|
||
|
#HOST_CFLAGS += -m32
|
||
|
#HOST_LDFLAGS += -m32
|
||
|
|
||
|
HOST_CFLAGS += $(shell pkg-config --cflags ncurses)
|
||
|
HOST_LDFLAGS += $(shell pkg-config --libs ncurses)
|
||
|
|
||
|
# we use mincrt0.s from here
|
||
|
STARTUP_DIR = .
|
||
|
|
||
| ... | ... | |
|
CHAMELEON_DIR = chameleon
|
||
|
MCC_DIR = mcc
|
||
|
MIST_DIR = mist
|
||
|
LINUXSIM_DIR = linux
|
||
|
|
||
|
AEON_LITE_BUILD_DIR = $(BUILD_DIR)/$(AEON_LITE_DIR)
|
||
|
DE1_BUILD_DIR = $(BUILD_DIR)/$(DE1_DIR)
|
||
|
CHAMELEON_BUILD_DIR = $(BUILD_DIR)/$(CHAMELEON_DIR)
|
||
|
MCC_BUILD_DIR = $(BUILD_DIR)/$(MCC_DIR)
|
||
|
MIST_BUILD_DIR = $(BUILD_DIR)/$(MIST_DIR)
|
||
|
LINUXSIM_BUILD_DIR = $(BUILD_DIR)/$(LINUXSIM_DIR)
|
||
|
|
||
|
#MINSTARTUP_SRC = mincrt0.s
|
||
|
MINSTARTUP_SRC = mycrt0.s
|
||
|
MINSTARTUP_OBJ = $(patsubst $(STARTUP_DIR)/%.s,$(BUILD_DIR)/%.o,$(MINSTARTUP_SRC))
|
||
|
|
||
|
COMMON_SRC = main.c regs.c freeze.c joystick.c fileutils.c fileselector.c atari_drive_emulator.c pokey/uart.c hexdump.c printf/printf.c fat/pff_file.c fat/pff.c common/utils.c
|
||
|
COMMON_SRC = main.c freeze.c fileutils.c fileselector.c atari_drive_emulator.c pokey/uart.c hexdump.c printf/printf.c fat/pff_file.c fat/pff.c common/utils.c
|
||
|
ZPU_SRC = regs.c joystick.c
|
||
|
SDCARD_SRC = sd_direct/diskio_mmc.c sd_direct/spi.c sd_direct/mmc2.c
|
||
|
|
||
|
AEON_LITE_PRJ = AEON_LITE
|
||
|
AEON_LITE_SRC = $(COMMON_SRC) $(SDCARD_SRC) de1/dirs.c
|
||
|
AEON_LITE_SRC = $(COMMON_SRC) $(SDCARD_SRC) $(ZPU_SRC) de1/dirs.c
|
||
|
AEON_LITE_OBJ = $(patsubst %.c,$(AEON_LITE_BUILD_DIR)/%.o,$(AEON_LITE_SRC))
|
||
|
|
||
|
DE1_PRJ = DE1
|
||
|
DE1_SRC = $(COMMON_SRC) $(SDCARD_SRC) de1/dirs.c
|
||
|
DE1_SRC = $(COMMON_SRC) $(SDCARD_SRC) $(ZPU_SRC) de1/dirs.c
|
||
|
DE1_OBJ = $(patsubst %.c,$(DE1_BUILD_DIR)/%.o,$(DE1_SRC))
|
||
|
|
||
|
CHAMELEON_PRJ = CHAMELEON
|
||
|
CHAMELEON_SRC = $(COMMON_SRC) $(SDCARD_SRC) chameleon/dirs.c
|
||
|
CHAMELEON_SRC = $(COMMON_SRC) $(SDCARD_SRC) $(ZPU_SRC) chameleon/dirs.c
|
||
|
CHAMELEON_OBJ = $(patsubst %.c,$(CHAMELEON_BUILD_DIR)/%.o,$(CHAMELEON_SRC))
|
||
|
|
||
|
MCC_PRJ = MCC216
|
||
|
MCC_SRC = $(COMMON_SRC) $(SDCARD_SRC) mcc/dirs.c
|
||
|
MCC_SRC = $(COMMON_SRC) $(SDCARD_SRC) $(ZPU_SRC) mcc/dirs.c
|
||
|
MCC_OBJ = $(patsubst %.c,$(MCC_BUILD_DIR)/%.o,$(MCC_SRC))
|
||
|
|
||
|
MIST_PRJ = MIST
|
||
|
MIST_SRC = $(COMMON_SRC) mist/diskio_sectorrequest.c mist/dirs.c
|
||
|
MIST_SRC = $(COMMON_SRC) $(ZPU_SRC) mist/diskio_sectorrequest.c mist/dirs.c
|
||
|
MIST_OBJ = $(patsubst %.c,$(MIST_BUILD_DIR)/%.o,$(MIST_SRC))
|
||
|
|
||
|
LINKMAP = ./standalone_simple.ld
|
||
|
|
||
|
LINUXSIM_EXE = linuxsim
|
||
|
LINUXSIM_SRC = $(COMMON_SRC) linux/main.c linux/mmc.c \
|
||
|
sd_direct/diskio_mmc.c linux/dirs.c linux/linux_memory.c linux/curses_screen.c \
|
||
|
linux/linux_helper.c
|
||
|
|
||
|
LINUXSIM_OBJ = $(patsubst %.c,$(LINUXSIM_BUILD_DIR)/%.o,$(LINUXSIM_SRC))
|
||
|
|
||
|
# Commandline options for each tool.
|
||
|
|
||
|
#ZPUOPTS= -mno-poppcrel -mno-pushspadd -mno-callpcrel -mno-shortop -mno-neg # No-neg requires bugfixed toolchain
|
||
| ... | ... | |
|
ZPUOPTS =
|
||
|
CFLAGS = -I. -Isd_direct -Iprintf -Ifat -Icommon -Isdram_common -c -g -Os $(ZPUOPTS) -DDISABLE_UART_RX
|
||
|
|
||
|
HOST_CFLAGS += -I. -Isd_direct -Iprintf -Ifat -Icommon -Isdram_common -DDISABLE_UART_RX
|
||
|
|
||
|
LFLAGS = -nostartfiles -Wl,--relax -g -Os
|
||
|
#LFLAGS = -nostartfiles -Os
|
||
|
|
||
| ... | ... | |
|
|
||
|
mist: $(BUILD_DIR) $(MIST_PRJ).bin $(MIST_PRJ).rpt
|
||
|
|
||
|
.PHONY: linux
|
||
|
linux: $(BUILD_DIR) $(LINUXSIM_EXE)
|
||
|
|
||
|
clean:
|
||
|
rm -rf $(BUILD_DIR)/* *.hex *.elf *.map *.lst *.srec *.bin *.rpt
|
||
|
rm -rf $(BUILD_DIR)/* *.hex *.elf *.map *.lst *.srec *.bin *.rpt $(LINUXSIM_EXE)
|
||
|
|
||
|
|
||
|
# Convert ELF binary to bin file.
|
||
| ... | ... | |
|
$(MIST_PRJ).elf: $(MINSTARTUP_OBJ) $(MIST_OBJ)
|
||
|
$(LD) $(LFLAGS) -T $(LINKMAP) -o $@ $+ $(LIBS)
|
||
|
|
||
|
$(LINUXSIM_EXE): $(LINUXSIM_OBJ)
|
||
|
$(HOST_LD) $(HOST_LDFLAGS) -o $@ $+
|
||
|
|
||
|
$(AEON_LITE_BUILD_DIR)/%.o: %.c Makefile
|
||
|
mkdir -p `dirname $@`
|
||
|
$(CC) -I$(AEON_LITE_DIR) $(CFLAGS) -o $@ -c $<
|
||
| ... | ... | |
|
mkdir -p `dirname $@`
|
||
|
$(CC) -I$(MIST_DIR) $(CFLAGS) -o $@ -c $<
|
||
|
|
||
|
$(LINUXSIM_BUILD_DIR)/%.o: %.c Makefile
|
||
|
@mkdir -p `dirname $@`
|
||
|
$(HOST_CC) -I$(LINUXSIM_DIR) $(HOST_CFLAGS) -o $@ -c $<
|
||
|
|
||
|
$(BUILD_DIR)/%.o: %.s
|
||
|
$(AS) -o $@ $<
|
||
|
|
||
Patch from Hias for local ncurses output. 0001-initial-version-of-linux-firmware-simulator.patch