mirror of
https://github.com/lowRISC/ibex.git
synced 2025-06-29 01:33:09 -04:00
Simple system is a basic verilator top-level testbench for running executables. It has functionality for outputting text to a log file and for the software to terminate the simulation
69 lines
1.7 KiB
Makefile
69 lines
1.7 KiB
Makefile
# Copyright lowRISC contributors.
|
|
# Licensed under the Apache License, Version 2.0, see LICENSE for details.
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
COMMON_DIR := $(shell dirname $(realpath $(lastword $(MAKEFILE_LIST))))
|
|
|
|
COMMON_SRCS = $(wildcard $(COMMON_DIR)/*.c)
|
|
INCS := -I$(COMMON_DIR)
|
|
|
|
# ARCH = rv32im # to disable compressed instructions
|
|
ARCH ?= rv32imc
|
|
|
|
ifdef PROGRAM
|
|
PROGRAM_C := $(PROGRAM).c
|
|
endif
|
|
|
|
SRCS = $(COMMON_SRCS) $(PROGRAM_C) $(EXTRA_SRCS)
|
|
|
|
C_SRCS = $(filter %.c, $(SRCS))
|
|
ASM_SRCS = $(filter %.S, $(SRCS))
|
|
|
|
CC = riscv32-unknown-elf-gcc
|
|
|
|
OBJCOPY ?= $(subst gcc,objcopy,$(wordlist 1,1,$(CC)))
|
|
OBJDUMP ?= $(subst gcc,objdump,$(wordlist 1,1,$(CC)))
|
|
|
|
LINKER_SCRIPT ?= $(COMMON_DIR)/link.ld
|
|
CRT ?= $(COMMON_DIR)/crt0.S
|
|
CFLAGS ?= -march=$(ARCH) -mabi=ilp32 -static -mcmodel=medany -Wall -g -Os\
|
|
-fvisibility=hidden -nostdlib -nostartfiles -ffreestanding $(PROGRAM_CFLAGS)
|
|
|
|
OBJS := ${C_SRCS:.c=.o} ${ASM_SRCS:.S=.o} ${CRT:.S=.o}
|
|
DEPS = $(OBJS:%.o=%.d)
|
|
|
|
ifdef PROGRAM
|
|
OUTFILES := $(PROGRAM).elf $(PROGRAM).vmem $(PROGRAM).bin $(PROGRAM).dis
|
|
else
|
|
OUTFILES := $(OBJS)
|
|
endif
|
|
|
|
all: $(OUTFILES)
|
|
|
|
$(PROGRAM).elf: $(OBJS) $(LINKER_SCRIPT)
|
|
$(CC) $(CFLAGS) -T $(LINKER_SCRIPT) $(OBJS) -o $@ $(LIBS)
|
|
|
|
%.dis: %.elf
|
|
$(OBJDUMP) -fhSD $^ > $@
|
|
|
|
# Note: this target requires the srecord package to be installed.
|
|
# XXX: This could be replaced by objcopy once
|
|
# https://sourceware.org/bugzilla/show_bug.cgi?id=19921
|
|
# is widely available.
|
|
%.vmem: %.bin
|
|
srec_cat $^ -binary -offset 0x0000 -byte-swap 4 -o $@ -vmem
|
|
|
|
%.bin: %.elf
|
|
$(OBJCOPY) -O binary $^ $@
|
|
|
|
%.o: %.c
|
|
$(CC) $(CFLAGS) -MMD -c $(INCS) -o $@ $<
|
|
|
|
%.o: %.S
|
|
$(CC) $(CFLAGS) -MMD -c $(INCS) -o $@ $<
|
|
|
|
clean:
|
|
$(RM) -f $(OBJS) $(DEPS)
|
|
|
|
distclean: clean
|
|
$(RM) -f $(OUTFILES)
|