blob: e6e122bc4500b1488f9e88670190841202466e4a [file] [log] [blame]
Patrick Georgi593124d2020-05-10 19:44:08 +02001# SPDX-License-Identifier: GPL-2.0-or-later
Stefan Reinauer03646be2008-05-13 22:14:21 +00002
3PROGRAM = inteltool
4
Nico Huberaf83db22017-04-05 17:30:20 +02005top ?= $(abspath ../..)
6
Paul Menzel9ebd8ea2013-03-31 22:15:43 +02007CC ?= gcc
Yegor Timoshenkoc2e49412018-10-07 01:58:27 +00008INSTALL ?= /usr/bin/env install
Paul Menzel9ebd8ea2013-03-31 22:15:43 +02009PREFIX ?= /usr/local
Jacob Garber52f0e842019-07-19 12:27:27 -060010CFLAGS ?= -O2 -g -Wall -Wextra -Wmissing-prototypes
Paul Menzel9ebd8ea2013-03-31 22:15:43 +020011LDFLAGS += -lpci -lz
Stefan Reinauer03646be2008-05-13 22:14:21 +000012
Michael Niewöhnercc85ce02020-03-21 23:31:31 +010013CPPFLAGS += -I$(top)/util/inteltool
Julius Werner98eeb962019-12-11 15:47:42 -080014CPPFLAGS += -I$(top)/src/commonlib/include -I$(top)/src/commonlib/bsd/include
Michael Niewöhnera808d632020-03-13 23:25:28 +010015CPPFLAGS += -I$(top)/src/arch/x86/include
Julius Werner98eeb962019-12-11 15:47:42 -080016
Nico Hubercce508f2017-06-13 12:51:54 +020017
Nico Huber18980232017-04-07 12:26:07 +020018OBJS = inteltool.o pcr.o cpu.o gpio.o gpio_groups.o rootcmplx.o powermgt.o \
Iru Caiab5cac22019-07-14 23:04:05 +080019 memory.o pcie.o amb.o ivy_memory.o spi.o gfx.o ahci.o lpc.o iobp.o
Stefan Reinauer03646be2008-05-13 22:14:21 +000020
Stefan Reinauer1162f252008-12-04 15:18:20 +000021OS_ARCH = $(shell uname)
22ifeq ($(OS_ARCH), Darwin)
Paul Menzel9ebd8ea2013-03-31 22:15:43 +020023LDFLAGS += -framework DirectHW
Stefan Reinauer1162f252008-12-04 15:18:20 +000024endif
Idwer Vollering3f91d812010-10-24 13:50:13 +000025ifeq ($(OS_ARCH), FreeBSD)
Nico Hubercce508f2017-06-13 12:51:54 +020026CPPFLAGS += -I/usr/local/include
Idwer Vollering3f91d812010-10-24 13:50:13 +000027LDFLAGS += -L/usr/local/lib
28LIBS = -lz
29endif
Andrey Korolyov046d2172016-01-05 19:59:06 +030030ifeq ($(OS_ARCH), NetBSD)
Nico Hubercce508f2017-06-13 12:51:54 +020031CPPFLAGS += -I/usr/pkg/include
Andrey Korolyov046d2172016-01-05 19:59:06 +030032LDFLAGS += -L/usr/pkg/lib -Wl,-rpath-link,/usr/pkg/lib -lz -lpciutils -lpci -l$(shell uname -p)
33endif
Stefan Reinauer1162f252008-12-04 15:18:20 +000034
Stefan Reinauer03646be2008-05-13 22:14:21 +000035all: pciutils dep $(PROGRAM)
36
37$(PROGRAM): $(OBJS)
Nico Hubercce508f2017-06-13 12:51:54 +020038 $(CC) $(CFLAGS) $(CPPFLAGS) -o $(PROGRAM) $(OBJS) $(LDFLAGS)
Stefan Reinauer03646be2008-05-13 22:14:21 +000039
40clean:
Nico Hubercde2bdf2017-06-13 12:54:28 +020041 rm -f $(PROGRAM) *.o *~ junit.xml .dependencies
Stefan Reinauer03646be2008-05-13 22:14:21 +000042
43distclean: clean
Stefan Reinauer8b835972008-06-22 17:15:03 +000044 rm -f .dependencies
Uwe Hermann9a6b6b52008-05-14 21:20:55 +000045
Stefan Reinauer03646be2008-05-13 22:14:21 +000046dep:
Nico Hubercce508f2017-06-13 12:51:54 +020047 @$(CC) $(CFLAGS) $(CPPFLAGS) -MM *.c > .dependencies
Stefan Reinauer03646be2008-05-13 22:14:21 +000048
Stefan Taunerfba86bf2012-10-12 10:36:49 +020049define LIBPCI_TEST
50/* Avoid a failing test due to libpci header symbol shadowing breakage */
51#define index shadow_workaround_index
Andrey Korolyov046d2172016-01-05 19:59:06 +030052#ifdef __NetBSD__
53#include <pciutils/pci.h>
54#else
Stefan Taunerfba86bf2012-10-12 10:36:49 +020055#include <pci/pci.h>
Andrey Korolyov046d2172016-01-05 19:59:06 +030056#endif
Stefan Taunerfba86bf2012-10-12 10:36:49 +020057struct pci_access *pacc;
58int main(int argc, char **argv)
59{
60 (void) argc;
61 (void) argv;
62 pacc = pci_alloc();
63 return 0;
64}
65endef
66export LIBPCI_TEST
67
Stefan Reinauer03646be2008-05-13 22:14:21 +000068pciutils:
Stefan Reinauer1162f252008-12-04 15:18:20 +000069 @printf "\nChecking for pciutils and zlib... "
Stefan Taunerfba86bf2012-10-12 10:36:49 +020070 @echo "$$LIBPCI_TEST" > .test.c
Nico Hubercce508f2017-06-13 12:51:54 +020071 @$(CC) $(CFLAGS) $(CPPFLAGS) .test.c -o .test $(LDFLAGS) \
72 >/dev/null 2>&1 && \
73 printf "found.\n" || ( printf "not found.\n\n"; \
Stefan Reinauer1162f252008-12-04 15:18:20 +000074 printf "Please install pciutils-devel and zlib-devel.\n"; \
75 printf "See README for more information.\n\n"; \
Stefan Reinauer03646be2008-05-13 22:14:21 +000076 rm -f .test.c .test; exit 1)
Stefan Reinauer1162f252008-12-04 15:18:20 +000077 @rm -rf .test.c .test .test.dSYM
Stefan Reinauer03646be2008-05-13 22:14:21 +000078
79install: $(PROGRAM)
Maciej Gabryelski9d2902f2022-04-21 10:11:43 +020080 $(INSTALL) -d $(DESTDIR)$(PREFIX)/sbin
Stefan Reinauer1162f252008-12-04 15:18:20 +000081 $(INSTALL) $(PROGRAM) $(DESTDIR)$(PREFIX)/sbin
Maciej Gabryelski9d2902f2022-04-21 10:11:43 +020082 $(INSTALL) -d $(DESTDIR)$(PREFIX)/share/man/man8
Lubomir Rintelba1f9aa2014-01-28 16:52:48 +000083 $(INSTALL) -p -m644 $(PROGRAM).8 $(DESTDIR)$(PREFIX)/share/man/man8
Stefan Reinauer03646be2008-05-13 22:14:21 +000084
85.PHONY: all clean distclean dep pciutils
86
87-include .dependencies