criscv/Makefile

55 lines
1.4 KiB
Makefile
Raw Normal View History

# Compiler to use
2024-10-14 19:48:56 +02:00
CC := gcc
# Compiler flags:
# -Wall: Enable all warnings
# -Wextra: Enable extra warnings
# -std=gnu23: Use GNU C23 standard
# -I include: Add 'include' directory to the include path
# -O3: Optimize code (level 3)
# -Wno-unused-variable: Disable warnings for unused variables
ifeq ($(DEBUG),1)
CFLAGS := -Wall -Wextra -std=gnu23 -I include -O0 -g
else
CFLAGS := -Wall -Wextra -std=gnu23 -I include -O3 -Wno-unused-variable
endif
# Directory for build outputs
2024-10-14 19:48:56 +02:00
BUILD_DIR := build
# Name of the output program
2024-10-14 19:48:56 +02:00
PROGRAM_NAME := criscv
# Find all .c files in the source directory
SRCS := $(wildcard src/*.c)
# Generate corresponding .o file names in the build/obj directory
OBJS := $(patsubst src/%.c,$(BUILD_DIR)/obj/%.o,$(SRCS))
2024-10-14 19:48:56 +02:00
# Name of the final executable
TARGET := $(BUILD_DIR)/$(PROGRAM_NAME)
# Declare 'all' and 'clean' as phony targets (not files)
2024-10-14 19:48:56 +02:00
.PHONY: all clean
# Default target: build the executable
2024-10-14 19:48:56 +02:00
all: $(TARGET)
# Rule to link object files into the final executable
2024-10-14 19:48:56 +02:00
$(TARGET): $(OBJS) | $(BUILD_DIR)
$(CC) $(CFLAGS) $^ -o $@
du -b $(TARGET) # Size of the executable in bytes
2024-10-14 19:48:56 +02:00
# Rule to compile source files into object files
$(BUILD_DIR)/obj/%.o: src/%.c | $(BUILD_DIR)/obj
2024-10-14 19:48:56 +02:00
$(CC) $(CFLAGS) -c $< -o $@
# Create build directories if they don't exist
2024-10-14 19:48:56 +02:00
$(BUILD_DIR) $(BUILD_DIR)/obj:
mkdir -p $@
# Clean target: remove the build directory
2024-10-14 19:48:56 +02:00
clean:
rm -rf $(BUILD_DIR)