Risc-V-Asm/Makefile

94 lines
2.1 KiB
Makefile
Raw Normal View History

2024-04-01 11:09:45 +02:00
# Compiler and assembler
2024-04-05 16:02:24 +02:00
CROSS=riscv64-linux-gnu
CC = ${CROSS}-gcc
AS = ${CROSS}-as
LD = ${CROSS}-ld
OBJDUMP = ${CROSS}-objdump
SIZE = ${CROSS}-size
2024-04-01 11:09:45 +02:00
2024-04-05 16:02:24 +02:00
# Specify the target binary (call it whatever)
TARGET = bin.elf
2024-04-01 11:09:45 +02:00
# QEMU command and flags
2024-04-05 17:02:16 +02:00
# QEMU = qemu-riscv64-static
QEMU = qemu-system-riscv64
QEMU_FLAGS += --machine virt# # Use the virt machine
QEMU_FLAGS += --nographic# # No graphical output
2024-04-01 11:09:45 +02:00
2024-04-05 16:02:24 +02:00
# Flags for compiler and assembler
CFLAGS += -static# # Use static linking
CFLAGS += -nostartfiles# # Do not use standard startup files
CFLAGS += -nostdlib# # Do not use standard libraries
CFLAGS += -fno-builtin# # Do not use built-in functions
CFLAGS += -fno-common# # Do not use common sections
2025-01-15 23:39:07 +01:00
CFLAGS += -march=rv64im# # Use RV64I ISA, i.e., integer only
CFLAGS += -mabi=lp64# # Use LP64 ABI, i.e., 64-bit longs and pointers, 32-bit ints
2024-04-05 16:02:24 +02:00
CFLAGS += -Os# # Optimize for size
2024-12-09 12:25:56 +01:00
CFLAGS += -Wall -Wunused -O2
2024-04-05 16:02:24 +02:00
2024-04-05 17:02:16 +02:00
LDFLAGS += -T link.ld # Use the linker script
LDFLAGS += --no-dynamic-linker
LDFLAGS += -m elf64lriscv
LDFLAGS += -static
LDFLAGS += -nostdlib
LDFLAGS += -s
2024-04-05 16:02:24 +02:00
# Use GC=0 to disable garbage collection
ifneq ($(GC), 0)
CFLAGS += -ffreestanding
CFLAGS += -ffunction-sections -fdata-sections
CFLAGS += -Wl,--gc-sections
endif
# Debugging flags, passed as 'make DEBUG=1 <target>'
ifeq ($(DEBUG), 1)
CFLAGS += -g -O0
endif
2024-04-01 11:09:45 +02:00
# Assembly source files
AS_SRCS := $(wildcard *.s)
# Object files
OBJS := $(AS_SRCS:.s=.o)
# Default target
all: $(OBJS)
2024-04-05 17:02:16 +02:00
@$(LD) $(LDFLAGS) -o $(TARGET) $(OBJS)
2024-04-05 16:02:24 +02:00
@echo "LD $(OBJS)"
2024-04-01 11:09:45 +02:00
# Compile assembly sources
%.o: %.s
2024-04-05 16:02:24 +02:00
@$(CC) $(CFLAGS) -c -o $@ $<
@echo "CC $<"
2024-04-01 11:09:45 +02:00
2024-04-05 16:02:24 +02:00
# Run the binary in QEMU
2024-12-09 12:25:56 +01:00
run: all
2024-04-05 17:02:16 +02:00
@echo "To exit: Ctrl+A, X"
@$(QEMU) $(QEMU_FLAGS) -bios $(TARGET)
2024-04-05 16:02:24 +02:00
# View the text section of the binary
inspect: all
$(OBJDUMP) -dC $(TARGET)
sections: all
$(OBJDUMP) -h $(TARGET)
2024-04-05 16:02:24 +02:00
# View the disassembly
raw: all
$(OBJDUMP) -D $(TARGET)
# View the data section
data: all
$(OBJDUMP) -s $(TARGET) --section=.data
# Check the size of the compiled binary
size: all
$(SIZE) $(TARGET)
2024-04-01 11:09:45 +02:00
2024-04-07 14:56:53 +02:00
format:
clang-format -i *.s
2024-04-01 11:09:45 +02:00
# Clean up
clean:
2024-04-05 16:02:24 +02:00
rm -f $(TARGET) $(OBJS)