| ## |
| ## SPDX-License-Identifier: GPL-2.0-only |
| |
| # NOTE: You need to add your libpci.a version to CFLAGS below if |
| # pci-userspace.c does not build. |
| # |
| # If you are building on AMD64, you have to use /usr/lib64/libpci.a instead of |
| # /usr/lib/... |
| # |
| |
| TOP ?= ../.. |
| OUT ?= build |
| |
| CC ?= gcc |
| CFLAGS ?= -O2 -g -fomit-frame-pointer |
| |
| CFLAGS += -Wall -Wundef -Wstrict-prototypes -Wmissing-prototypes |
| CFLAGS += -Wwrite-strings -Wredundant-decls -Wstrict-aliasing -Wshadow -Wextra |
| CFLAGS += -Wno-unused-but-set-variable |
| |
| # TODO check host architecture |
| CBCFLAGS = -Wno-sign-compare -Wno-unused-parameter -Wno-format |
| |
| INCLUDES = -Iinclude -I$(OUT)/include |
| INCLUDES += -I$(TOP)/src/device/oprom/include/ |
| INCLUDES += -I$(TOP)/src/device/oprom/yabel |
| INCLUDES += -include $(TOP)/src/commonlib/include/commonlib/loglevel.h |
| INCLUDES += -include stdtypes.h -include pci-userspace.h |
| INCLUDES += -include $(TOP)/src/include/kconfig.h |
| |
| CBINCLUDES = -I$(TOP)/src -include include/stdtypes.h -include $(TOP)/src/include/endian.h |
| CBINCLUDES += -include stdio.h -include sys/io.h |
| |
| SOURCE = testbios.c |
| SOURCE += pci-userspace.c |
| SOURCE += device.c |
| |
| X86EMU = x86emu/sys.c x86emu/decode.c x86emu/ops.c x86emu/ops2.c |
| X86EMU += x86emu/prim_ops.c x86emu/fpu.c x86emu/debug.c |
| |
| X86EMU += yabel/interrupt.c |
| X86EMU += yabel/mem.c |
| X86EMU += yabel/io.c |
| X86EMU += yabel/pmm.c |
| X86EMU += yabel/biosemu.c |
| X86EMU += yabel/debug.c |
| #X86EMU += yabel/device.c # For now we need a local copy :-( |
| |
| |
| |
| X86EMU_DIR = $(TOP)/src/device/oprom |
| X86EMU_SOURCE = $(addprefix $(X86EMU_DIR)/, $(X86EMU)) |
| OBJECTS:=$(addprefix $(OUT)/,$(SOURCE:.c=.o)) $(addprefix $(OUT)/, $(X86EMU:.c=.o)) |
| |
| LIBS=-lpci |
| |
| all: dep testbios |
| |
| $(OBJECTS): includes |
| |
| testbios: $(OBJECTS) |
| printf " LINK $(notdir $@)\n" |
| $(CC) $(CFLAGS) -o $@ $^ $(LIBS) |
| |
| dep: $(SOURCE) $(X86EMU_SOURCE) Makefile |
| $(CC) $(CFLAGS) $(INCLUDES) -MM $(SOURCE) > .dependencies |
| $(CC) $(CFLAGS) $(INCLUDES) $(CBCFLAGS) $(CBINCLUDES) -MM $(X86EMU_SOURCE) >> .dependencies |
| |
| # Make all the dummy include files (that are in reality |
| # covered by all the -include statements above) |
| includes: |
| mkdir -p $(OUT)/include/device |
| mkdir -p $(OUT)/include/arch |
| touch $(OUT)/include/device/device.h |
| touch $(OUT)/include/device/pci.h |
| touch $(OUT)/include/device/pci_ops.h |
| touch $(OUT)/include/device/resource.h |
| touch $(OUT)/include/arch/io.h |
| touch $(OUT)/include/timer.h |
| touch $(OUT)/include/types.h |
| |
| clean: |
| rm -f $(OBJECTS) *~ testbios |
| rm -rf $(OUT) |
| |
| distclean: clean |
| rm -f .dependencies |
| |
| $(OUT)/%.o: $(X86EMU_DIR)/%.c |
| printf " CC (x86emu) $(notdir $<)\n" |
| mkdir -p $(dir $@) |
| $(CC) $(CFLAGS) $(CBCFLAGS) $(INCLUDES) $(CBINCLUDES) -c -o $@ $< |
| |
| $(OUT)/%.o: %.c |
| printf " CC $(notdir $<)\n" |
| mkdir -p $(dir $@) |
| $(CC) $(CFLAGS) $(INCLUDES) -c -o $@ $< |
| |
| .PHONY: all includes clean distclean |
| .SILENT: |
| |
| -include .dependencies |