criscv/Makefile

76 lines
1.9 KiB
Makefile
Raw Normal View History

# Compiler to use
2024-10-19 13:06:27 +02:00
CC ?= gcc
2024-10-19 17:16:36 +02:00
# Add debugging output
$(info CC is set to $(CC))
# Separate CFLAGS and LDFLAGS
2024-10-19 17:40:11 +02:00
CFLAGS = -Wall -Wextra -std=gnu17 -I include
2024-10-19 17:16:36 +02:00
LDFLAGS = -lelf
# Add potential additional library path (update this path if needed)
LIBRARY_PATH := /usr/lib/x86_64-linux-gnu
LDFLAGS += -L$(LIBRARY_PATH)
# Add debugging output
$(info CFLAGS is set to $(CFLAGS))
$(info LDFLAGS is set to $(LDFLAGS))
# Directory for build outputs
2024-10-14 19:48:56 +02:00
BUILD_DIR := build
# Name of the output program
2024-10-19 13:06:27 +02:00
PROGRAM_NAME ?= criscv
2024-10-14 19:48:56 +02:00
# 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)
2024-10-19 13:06:27 +02:00
# Default target: build the executable
2024-10-19 15:08:51 +02:00
all: CFLAGS += -O3
2024-10-19 13:06:27 +02:00
all: $(TARGET)
# Debug target
2024-10-19 15:08:51 +02:00
debug: CFLAGS += -O0 -g
2024-10-19 13:06:27 +02:00
debug: $(TARGET)
# Declare 'all' and 'clean' as phony targets (not files)
2024-10-19 15:08:51 +02:00
.PHONY: all debug clean
2024-10-14 19:48:56 +02:00
# Rule to link object files into the final executable
2024-10-14 19:48:56 +02:00
$(TARGET): $(OBJS) | $(BUILD_DIR)
2024-10-19 17:16:36 +02:00
@echo "Linking $(TARGET)"
@echo "Command: $(CC) $(CFLAGS) $^ -o $@ $(LDFLAGS)"
$(CC) $(CFLAGS) $^ -o $@ $(LDFLAGS)
@echo "Linking complete"
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-19 17:16:36 +02:00
@echo "Compiling $<"
@echo "Command: $(CC) $(CFLAGS) -c $< -o $@"
2024-10-14 19:48:56 +02:00
$(CC) $(CFLAGS) -c $< -o $@
2024-10-19 17:16:36 +02:00
@echo "Compilation complete"
2024-10-14 19:48:56 +02:00
# 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:
2024-10-19 17:16:36 +02:00
rm -rf $(BUILD_DIR)
# Add a new target to print library information
.PHONY: libinfo
libinfo:
@echo "Searching for libelf..."
@find /usr -name "libelf.so*" 2>/dev/null || echo "libelf not found in /usr"
@echo "Library search path:"
@echo $(LD_LIBRARY_PATH)
@echo "Compiler search path:"
$(CC) -print-search-dirs