674bb3bf65
Add support for AST2400 Super I/O. The device doesn't have an ID register, so probe for scratch register not to read as 0xff. Tested on platform which has an AST2400. Change-Id: I86af69c6b2ccefe2c88eef875bc858239df834f1 Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/32984 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Kyösti Mälkki <kyosti.malkki@gmail.com>
112 lines
3 KiB
Makefile
112 lines
3 KiB
Makefile
##
|
|
## This file is part of the superiotool project.
|
|
##
|
|
## Copyright (C) 2007-2010 Uwe Hermann <uwe@hermann-uwe.de>
|
|
##
|
|
## This program is free software; you can redistribute it and/or modify
|
|
## it under the terms of the GNU General Public License as published by
|
|
## the Free Software Foundation; either version 2 of the License, or
|
|
## (at your option) any later version.
|
|
##
|
|
## This program is distributed in the hope that it will be useful,
|
|
## but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
## GNU General Public License for more details.
|
|
##
|
|
|
|
PROGRAM = superiotool
|
|
|
|
CC ?= gcc
|
|
INSTALL ?= /usr/bin/env install
|
|
PREFIX ?= /usr/local
|
|
|
|
# Set the superiotool version string to the output of 'git describe'.
|
|
|
|
VERSION := -D'SUPERIOTOOL_VERSION="$(shell git describe 2>/dev/null)"'
|
|
|
|
CFLAGS += -O2 -Wall -Wstrict-prototypes -Wundef -Wstrict-aliasing \
|
|
-Werror-implicit-function-declaration -ansi -pedantic $(VERSION)
|
|
LDFLAGS += -lz
|
|
|
|
OBJS = superiotool.o serverengines.o ali.o exar.o fintek.o ite.o nsc.o \
|
|
nuvoton.o smsc.o winbond.o infineon.o aspeed.o
|
|
|
|
OS_ARCH = $(shell uname)
|
|
ifeq ($(OS_ARCH), Darwin)
|
|
LIBS = -framework IOKit -framework DirectHW -lpci -lz
|
|
endif
|
|
ifeq ($(OS_ARCH), FreeBSD)
|
|
CFLAGS = -O2 -Wall -Werror -Wstrict-prototypes -Wundef -Wstrict-aliasing \
|
|
-Werror-implicit-function-declaration -ansi $(VERSION) \
|
|
-I/usr/local/include
|
|
LDFLAGS += -L/usr/local/lib
|
|
LIBS = -lz
|
|
endif
|
|
ifeq ($(OS_ARCH), NetBSD)
|
|
CFLAGS += -I/usr/pkg/include
|
|
LDFLAGS += -L/usr/pkg/lib -Wl,-rpath-link,/usr/pkg/lib
|
|
LIBS = -lz -l$(shell uname -p)
|
|
endif
|
|
|
|
# Support for PCI-attached "Super I/Os" (e.g. in VIA VT82686A/B).
|
|
CONFIG_PCI = yes
|
|
|
|
ifeq ($(CONFIG_PCI), yes)
|
|
CFLAGS += -DPCI_SUPPORT
|
|
OBJS += pci.o via.o amd.o
|
|
LIBS += -lpci
|
|
ifeq ($(OS_ARCH),NetBSD)
|
|
LIBS += -lpciutils
|
|
endif
|
|
endif
|
|
|
|
all: pciutils $(PROGRAM)
|
|
|
|
superiotool.o: *.c superiotool.h
|
|
|
|
$(PROGRAM): $(OBJS) superiotool.h
|
|
$(CC) $(LDFLAGS) -o $(PROGRAM) $(OBJS) $(LIBS)
|
|
|
|
install: $(PROGRAM)
|
|
mkdir -p $(DESTDIR)$(PREFIX)/sbin
|
|
$(INSTALL) $(PROGRAM) $(DESTDIR)$(PREFIX)/sbin
|
|
mkdir -p $(DESTDIR)$(PREFIX)/share/man/man8
|
|
$(INSTALL) -p -m644 $(PROGRAM).8 $(DESTDIR)$(PREFIX)/share/man/man8
|
|
|
|
clean:
|
|
rm -f $(PROGRAM) *.o junit.xml
|
|
|
|
distclean: clean
|
|
|
|
.PHONY: all install clean distclean
|
|
|
|
ifeq ($(CONFIG_PCI), yes)
|
|
define LIBPCI_TEST
|
|
/* Avoid a failing test due to libpci header symbol shadowing breakage */
|
|
#define index shadow_workaround_index
|
|
#ifdef __NetBSD__
|
|
#include <pciutils/pci.h>
|
|
#else
|
|
#include <pci/pci.h>
|
|
#endif
|
|
struct pci_access *pacc;
|
|
int main(int argc, char **argv)
|
|
{
|
|
(void) argc;
|
|
(void) argv;
|
|
pacc = pci_alloc();
|
|
return 0;
|
|
}
|
|
endef
|
|
export LIBPCI_TEST
|
|
|
|
pciutils:
|
|
@printf "\nChecking for pciutils and zlib... "
|
|
@echo "$$LIBPCI_TEST" > .test.c
|
|
@$(CC) $(CFLAGS) .test.c -o .test $(LIBS) >/dev/null 2>&1 && \
|
|
printf "found.\n" || ( printf "not found.\n\n"; \
|
|
printf "Please install pciutils-devel and zlib-devel.\n"; \
|
|
printf "See README for more information.\n\n"; \
|
|
rm -f .test.c .test; exit 1)
|
|
@rm -rf .test.c .test .test.dSYM
|
|
endif
|