mirror of
https://review.coreboot.org/flashrom.git
synced 2025-04-26 22:52:34 +02:00
Portability fixes and cleanups
Move Mac OS X IOKit/DirectHW availability checks in the Makefile from compiler check to pciutils check. Print the compiler error messages for feature detection. Add DOS libpci in the Makefile includes only if a PCI-based programmer was requested. Restrict mmap usage in ich_descriptors_tool to Unix style systems. Build ich_descriptors_tool with the correct .exe extension on DOS/Windows. Build ich_descriptors_tool by default on x86. (Patch by Stefan Tauner) Print the Windows version instead of "unknown machine" on Windows. Don't #define our own __DARWIN__, use the standard OS X detection method. Update the README. Add more generated files to svn:ignore Corresponding to flashrom svn r1567. Signed-off-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net> Acked-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net>
This commit is contained in:
parent
b6304c1a1a
commit
60d9bd267e
71
Makefile
71
Makefile
@ -2,7 +2,7 @@
|
|||||||
# This file is part of the flashrom project.
|
# This file is part of the flashrom project.
|
||||||
#
|
#
|
||||||
# Copyright (C) 2005 coresystems GmbH <stepan@coresystems.de>
|
# Copyright (C) 2005 coresystems GmbH <stepan@coresystems.de>
|
||||||
# Copyright (C) 2009,2010 Carl-Daniel Hailfinger
|
# Copyright (C) 2009,2010,2012 Carl-Daniel Hailfinger
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# 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
|
# it under the terms of the GNU General Public License as published by
|
||||||
@ -20,6 +20,12 @@
|
|||||||
|
|
||||||
PROGRAM = flashrom
|
PROGRAM = flashrom
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Defaults for the toolchain.
|
||||||
|
|
||||||
|
# If you want to cross-compile, just run e.g.
|
||||||
|
# make CC=i586-pc-msdosdjgpp-gcc
|
||||||
|
# You may have to specify STRIP/AR/RANLIB as well.
|
||||||
CC ?= gcc
|
CC ?= gcc
|
||||||
STRIP ?= strip
|
STRIP ?= strip
|
||||||
INSTALL = install
|
INSTALL = install
|
||||||
@ -31,12 +37,17 @@ EXPORTDIR ?= .
|
|||||||
AR ?= ar
|
AR ?= ar
|
||||||
RANLIB ?= ranlib
|
RANLIB ?= ranlib
|
||||||
|
|
||||||
|
# If your compiler spits out excessive warnings, run make WARNERROR=no
|
||||||
|
# You shouldn't have to change this flag.
|
||||||
WARNERROR ?= yes
|
WARNERROR ?= yes
|
||||||
|
|
||||||
ifeq ($(WARNERROR), yes)
|
ifeq ($(WARNERROR), yes)
|
||||||
CFLAGS += -Werror
|
CFLAGS += -Werror
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# General OS/architecture specific settings.
|
||||||
|
|
||||||
# HOST_OS is only used to work around local toolchain issues.
|
# HOST_OS is only used to work around local toolchain issues.
|
||||||
HOST_OS ?= $(shell uname)
|
HOST_OS ?= $(shell uname)
|
||||||
ifeq ($(HOST_OS), MINGW32_NT-5.1)
|
ifeq ($(HOST_OS), MINGW32_NT-5.1)
|
||||||
@ -47,7 +58,7 @@ ifneq ($(HOST_OS), SunOS)
|
|||||||
STRIP_ARGS = -s
|
STRIP_ARGS = -s
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Determine the destination processor architecture.
|
# Determine the destination OS.
|
||||||
# IMPORTANT: The following line must be placed before TARGET_OS is ever used
|
# IMPORTANT: The following line must be placed before TARGET_OS is ever used
|
||||||
# (of course), but should come after any lines setting CC because the line
|
# (of course), but should come after any lines setting CC because the line
|
||||||
# below uses CC itself.
|
# below uses CC itself.
|
||||||
@ -55,25 +66,27 @@ override TARGET_OS := $(strip $(shell LC_ALL=C $(CC) $(CPPFLAGS) -E os.h 2>/dev/
|
|||||||
|
|
||||||
ifeq ($(TARGET_OS), Darwin)
|
ifeq ($(TARGET_OS), Darwin)
|
||||||
CPPFLAGS += -I/opt/local/include -I/usr/local/include
|
CPPFLAGS += -I/opt/local/include -I/usr/local/include
|
||||||
# DirectHW framework can be found in the DirectHW library.
|
LDFLAGS += -L/opt/local/lib -L/usr/local/lib
|
||||||
LDFLAGS += -framework IOKit -framework DirectHW -L/opt/local/lib -L/usr/local/lib
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(TARGET_OS), FreeBSD)
|
ifeq ($(TARGET_OS), FreeBSD)
|
||||||
CPPFLAGS += -I/usr/local/include
|
CPPFLAGS += -I/usr/local/include
|
||||||
LDFLAGS += -L/usr/local/lib
|
LDFLAGS += -L/usr/local/lib
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(TARGET_OS), OpenBSD)
|
ifeq ($(TARGET_OS), OpenBSD)
|
||||||
CPPFLAGS += -I/usr/local/include
|
CPPFLAGS += -I/usr/local/include
|
||||||
LDFLAGS += -L/usr/local/lib
|
LDFLAGS += -L/usr/local/lib
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(TARGET_OS), DOS)
|
ifeq ($(TARGET_OS), DOS)
|
||||||
EXEC_SUFFIX := .exe
|
EXEC_SUFFIX := .exe
|
||||||
CPPFLAGS += -I../libgetopt -I../libpci/include
|
CPPFLAGS += -I../libgetopt
|
||||||
# DJGPP has odd uint*_t definitions which cause lots of format string warnings.
|
# DJGPP has odd uint*_t definitions which cause lots of format string warnings.
|
||||||
CPPFLAGS += -Wno-format
|
CPPFLAGS += -Wno-format
|
||||||
# FIXME Check if we can achieve the same effect with -L../libgetopt -lgetopt
|
# FIXME Check if we can achieve the same effect with -L../libgetopt -lgetopt
|
||||||
LIBS += ../libgetopt/libgetopt.a
|
LIBS += ../libgetopt/libgetopt.a
|
||||||
# Bus Pirate, Serprog and Pony-SPI are not supported under DOS (missing serial support).
|
# Bus Pirate, Serprog and PonyProg are not supported under DOS (missing serial support).
|
||||||
ifeq ($(CONFIG_BUSPIRATE_SPI), yes)
|
ifeq ($(CONFIG_BUSPIRATE_SPI), yes)
|
||||||
UNSUPPORTED_FEATURES += CONFIG_BUSPIRATE_SPI=yes
|
UNSUPPORTED_FEATURES += CONFIG_BUSPIRATE_SPI=yes
|
||||||
else
|
else
|
||||||
@ -263,18 +276,23 @@ override CONFIG_SATAMV = no
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Flash chip drivers and bus support infrastructure.
|
||||||
|
|
||||||
CHIP_OBJS = jedec.o stm50flw0x0x.o w39.o w29ee011.o \
|
CHIP_OBJS = jedec.o stm50flw0x0x.o w39.o w29ee011.o \
|
||||||
sst28sf040.o m29f400bt.o 82802ab.o pm49fl00x.o \
|
sst28sf040.o m29f400bt.o 82802ab.o pm49fl00x.o \
|
||||||
sst49lfxxxc.o sst_fwhub.o flashchips.o spi.o spi25.o \
|
sst49lfxxxc.o sst_fwhub.o flashchips.o spi.o spi25.o \
|
||||||
a25.o at25.o opaque.o sfdp.o en29lv640b.o
|
a25.o at25.o opaque.o sfdp.o en29lv640b.o
|
||||||
|
|
||||||
LIB_OBJS = layout.o
|
###############################################################################
|
||||||
|
# Library code.
|
||||||
|
|
||||||
CLI_OBJS = flashrom.o cli_classic.o cli_output.o print.o
|
LIB_OBJS = layout.o flashrom.o udelay.o programmer.o
|
||||||
|
|
||||||
PROGRAMMER_OBJS = udelay.o programmer.o
|
###############################################################################
|
||||||
|
# Frontend related stuff.
|
||||||
|
|
||||||
all: pciutils features $(PROGRAM)$(EXEC_SUFFIX)
|
CLI_OBJS = cli_classic.o cli_output.o print.o
|
||||||
|
|
||||||
# Set the flashrom version string from the highest revision number
|
# Set the flashrom version string from the highest revision number
|
||||||
# of the checked out flashrom files.
|
# of the checked out flashrom files.
|
||||||
@ -375,6 +393,9 @@ endif
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# Programmer drivers and programmer support infrastructure.
|
||||||
|
|
||||||
ifeq ($(CONFIG_INTERNAL), yes)
|
ifeq ($(CONFIG_INTERNAL), yes)
|
||||||
FEATURE_CFLAGS += -D'CONFIG_INTERNAL=1'
|
FEATURE_CFLAGS += -D'CONFIG_INTERNAL=1'
|
||||||
PROGRAMMER_OBJS += processor_enable.o chipset_enable.o board_enable.o cbtable.o dmi.o internal.o
|
PROGRAMMER_OBJS += processor_enable.o chipset_enable.o board_enable.o cbtable.o dmi.o internal.o
|
||||||
@ -530,12 +551,19 @@ LIBS += -l$(shell uname -p)
|
|||||||
else
|
else
|
||||||
ifeq ($(TARGET_OS), DOS)
|
ifeq ($(TARGET_OS), DOS)
|
||||||
# FIXME There needs to be a better way to do this
|
# FIXME There needs to be a better way to do this
|
||||||
|
CPPFLAGS += -I../libpci/include
|
||||||
LIBS += ../libpci/lib/libpci.a
|
LIBS += ../libpci/lib/libpci.a
|
||||||
else
|
else
|
||||||
LIBS += -lpci
|
LIBS += -lpci
|
||||||
ifeq ($(TARGET_OS), OpenBSD)
|
ifeq ($(TARGET_OS), OpenBSD)
|
||||||
# For (i386|amd64)_iopl(2).
|
# For (i386|amd64)_iopl(2).
|
||||||
LIBS += -l$(shell uname -m)
|
LIBS += -l$(shell uname -m)
|
||||||
|
else
|
||||||
|
ifeq ($(TARGET_OS), Darwin)
|
||||||
|
# DirectHW framework can be found in the DirectHW library.
|
||||||
|
LIBS += -framework IOKit -framework DirectHW
|
||||||
|
else
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
@ -554,6 +582,11 @@ FEATURE_LIBS += $(shell LC_ALL=C grep -q "NEEDLIBZ := yes" .libdeps && printf "%
|
|||||||
LIBFLASHROM_OBJS = $(CHIP_OBJS) $(PROGRAMMER_OBJS) $(LIB_OBJS)
|
LIBFLASHROM_OBJS = $(CHIP_OBJS) $(PROGRAMMER_OBJS) $(LIB_OBJS)
|
||||||
OBJS = $(CLI_OBJS) $(LIBFLASHROM_OBJS)
|
OBJS = $(CLI_OBJS) $(LIBFLASHROM_OBJS)
|
||||||
|
|
||||||
|
all: pciutils features $(PROGRAM)$(EXEC_SUFFIX)
|
||||||
|
ifeq ($(ARCH), x86)
|
||||||
|
@+$(MAKE) -C util/ich_descriptors_tool/ TARGET_OS=$(TARGET_OS) EXEC_SUFFIX=$(EXEC_SUFFIX)
|
||||||
|
endif
|
||||||
|
|
||||||
$(PROGRAM)$(EXEC_SUFFIX): $(OBJS)
|
$(PROGRAM)$(EXEC_SUFFIX): $(OBJS)
|
||||||
$(CC) $(LDFLAGS) -o $(PROGRAM)$(EXEC_SUFFIX) $(OBJS) $(FEATURE_LIBS) $(LIBS)
|
$(CC) $(LDFLAGS) -o $(PROGRAM)$(EXEC_SUFFIX) $(OBJS) $(FEATURE_LIBS) $(LIBS)
|
||||||
|
|
||||||
@ -574,6 +607,7 @@ TAROPTIONS = $(shell LC_ALL=C tar --version|grep -q GNU && echo "--owner=root --
|
|||||||
# We don't use EXEC_SUFFIX here because we want to clean everything.
|
# We don't use EXEC_SUFFIX here because we want to clean everything.
|
||||||
clean:
|
clean:
|
||||||
rm -f $(PROGRAM) $(PROGRAM).exe libflashrom.a *.o *.d
|
rm -f $(PROGRAM) $(PROGRAM).exe libflashrom.a *.o *.d
|
||||||
|
@+$(MAKE) -C util/ich_descriptors_tool/ clean
|
||||||
|
|
||||||
distclean: clean
|
distclean: clean
|
||||||
rm -f .features .libdeps
|
rm -f .features .libdeps
|
||||||
@ -597,7 +631,7 @@ export COMPILER_TEST
|
|||||||
compiler: featuresavailable
|
compiler: featuresavailable
|
||||||
@printf "Checking for a C compiler... "
|
@printf "Checking for a C compiler... "
|
||||||
@echo "$$COMPILER_TEST" > .test.c
|
@echo "$$COMPILER_TEST" > .test.c
|
||||||
@$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) .test.c -o .test$(EXEC_SUFFIX) >/dev/null 2>&1 && \
|
@$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) .test.c -o .test$(EXEC_SUFFIX) >/dev/null && \
|
||||||
echo "found." || ( echo "not found."; \
|
echo "found." || ( echo "not found."; \
|
||||||
rm -f .test.c .test$(EXEC_SUFFIX); exit 1)
|
rm -f .test.c .test$(EXEC_SUFFIX); exit 1)
|
||||||
@rm -f .test.c .test$(EXEC_SUFFIX)
|
@rm -f .test.c .test$(EXEC_SUFFIX)
|
||||||
@ -631,17 +665,17 @@ ifeq ($(CHECK_LIBPCI), yes)
|
|||||||
pciutils: compiler
|
pciutils: compiler
|
||||||
@printf "Checking for libpci headers... "
|
@printf "Checking for libpci headers... "
|
||||||
@echo "$$LIBPCI_TEST" > .test.c
|
@echo "$$LIBPCI_TEST" > .test.c
|
||||||
@$(CC) -c $(CPPFLAGS) $(CFLAGS) .test.c -o .test.o >/dev/null 2>&1 && \
|
@$(CC) -c $(CPPFLAGS) $(CFLAGS) .test.c -o .test.o >/dev/null && \
|
||||||
echo "found." || ( echo "not found."; echo; \
|
echo "found." || ( echo "not found."; echo; \
|
||||||
echo "Please install libpci headers (package pciutils-devel)."; \
|
echo "Please install libpci headers (package pciutils-devel)."; \
|
||||||
echo "See README for more information."; echo; \
|
echo "See README for more information."; echo; \
|
||||||
rm -f .test.c .test.o; exit 1)
|
rm -f .test.c .test.o; exit 1)
|
||||||
@printf "Checking if libpci is present and sufficient... "
|
@printf "Checking if libpci is present and sufficient... "
|
||||||
@printf "" > .libdeps
|
@printf "" > .libdeps
|
||||||
@$(CC) $(LDFLAGS) .test.o -o .test$(EXEC_SUFFIX) $(LIBS) >/dev/null 2>&1 && \
|
@$(CC) $(LDFLAGS) .test.o -o .test$(EXEC_SUFFIX) $(LIBS) >/dev/null && \
|
||||||
echo "yes." || ( echo "no."; \
|
echo "yes." || ( echo "no."; \
|
||||||
printf "Checking if libz+libpci are present and sufficient..."; \
|
printf "Checking if libz+libpci are present and sufficient..."; \
|
||||||
$(CC) $(LDFLAGS) .test.o -o .test$(EXEC_SUFFIX) $(LIBS) -lz >/dev/null 2>&1 && \
|
$(CC) $(LDFLAGS) .test.o -o .test$(EXEC_SUFFIX) $(LIBS) -lz >/dev/null && \
|
||||||
( echo "yes."; echo "NEEDLIBZ := yes" > .libdeps ) || ( echo "no."; echo; \
|
( echo "yes."; echo "NEEDLIBZ := yes" > .libdeps ) || ( echo "no."; echo; \
|
||||||
echo "Please install libpci (package pciutils) and/or libz."; \
|
echo "Please install libpci (package pciutils) and/or libz."; \
|
||||||
echo "See README for more information."; echo; \
|
echo "See README for more information."; echo; \
|
||||||
@ -657,10 +691,13 @@ endif
|
|||||||
# If a user does not explicitly request a non-working feature, we should
|
# If a user does not explicitly request a non-working feature, we should
|
||||||
# silently disable it. However, if a non-working (does not compile) feature
|
# silently disable it. However, if a non-working (does not compile) feature
|
||||||
# is explicitly requested, we should bail out with a descriptive error message.
|
# is explicitly requested, we should bail out with a descriptive error message.
|
||||||
ifeq ($(UNSUPPORTED_FEATURES), )
|
# We also have to check that at least one programmer driver is enabled.
|
||||||
featuresavailable:
|
|
||||||
else
|
|
||||||
featuresavailable:
|
featuresavailable:
|
||||||
|
ifeq ($(PROGRAMMER_OBJS),)
|
||||||
|
@echo "You have to enable at least one programmer driver!"
|
||||||
|
@false
|
||||||
|
endif
|
||||||
|
ifneq ($(UNSUPPORTED_FEATURES), )
|
||||||
@echo "The following features are unavailable on your machine: $(UNSUPPORTED_FEATURES)"
|
@echo "The following features are unavailable on your machine: $(UNSUPPORTED_FEATURES)"
|
||||||
@false
|
@false
|
||||||
endif
|
endif
|
||||||
|
33
README
33
README
@ -93,14 +93,18 @@ To compile on OpenBSD, use:
|
|||||||
To compile and run on Darwin/Mac OS X:
|
To compile and run on Darwin/Mac OS X:
|
||||||
|
|
||||||
Install DirectHW from coresystems GmbH.
|
Install DirectHW from coresystems GmbH.
|
||||||
DirectHW is available at http://www.coresystems.de/en/directhw .
|
DirectHW is available at http://www.coreboot.org/DirectHW .
|
||||||
|
|
||||||
To cross-compile on Linux for DOS:
|
To cross-compile on Linux for DOS:
|
||||||
|
|
||||||
Get RPMs of the cross compiler from the DJGPP site and install them:
|
Get packages of the DJGPP cross compiler and install them:
|
||||||
|
djgpp-filesystem djgpp-gcc djgpp-cpp djgpp-runtime djgpp-binutils
|
||||||
|
As an alternative, the DJGPP web site offers packages for download as well:
|
||||||
djcross-binutils-2.19.1-10ap.i386.rpm
|
djcross-binutils-2.19.1-10ap.i386.rpm
|
||||||
djcross-gcc-4.3.2-8ap.i686.rpm
|
djcross-gcc-4.3.2-8ap.i686.rpm
|
||||||
djcrx-2.04pre_20090725-13ap.i386.rpm
|
djcrx-2.04pre_20090725-13ap.i386.rpm
|
||||||
|
The cross toolchain packages for your distribution may have slightly different
|
||||||
|
names (look for packages named *djgpp*).
|
||||||
Download pciutils 3.1.5 and apply http://assembler.cz/flashrom/pciutils.patch
|
Download pciutils 3.1.5 and apply http://assembler.cz/flashrom/pciutils.patch
|
||||||
Download and compile http://assembler.cz/flashrom/libgetopt/
|
Download and compile http://assembler.cz/flashrom/libgetopt/
|
||||||
Compile pciutils, see README.DJGPP for instructions.
|
Compile pciutils, see README.DJGPP for instructions.
|
||||||
@ -108,7 +112,7 @@ To cross-compile on Linux for DOS:
|
|||||||
../libpci should contain pciutils source and binaries.
|
../libpci should contain pciutils source and binaries.
|
||||||
../libgetopt should contain getopt.a from libgetopt.
|
../libgetopt should contain getopt.a from libgetopt.
|
||||||
Run either (change settings where appropriate)
|
Run either (change settings where appropriate)
|
||||||
make CC=i586-pc-msdosdjgpp-gcc STRIP=i586-pc-msdosdjgpp-strip OS_ARCH=DOS
|
make CC=i586-pc-msdosdjgpp-gcc STRIP=i586-pc-msdosdjgpp-strip
|
||||||
or (above settings hardcoded)
|
or (above settings hardcoded)
|
||||||
make djgpp-dos
|
make djgpp-dos
|
||||||
You might have to add WARNERROR=no to the make command line.
|
You might have to add WARNERROR=no to the make command line.
|
||||||
@ -116,17 +120,22 @@ To cross-compile on Linux for DOS:
|
|||||||
http://homer.rice.edu/~sandmann/cwsdpmi/csdpmi7b.zip and make sure
|
http://homer.rice.edu/~sandmann/cwsdpmi/csdpmi7b.zip and make sure
|
||||||
CWSDPMI.EXE is in the current directory.
|
CWSDPMI.EXE is in the current directory.
|
||||||
|
|
||||||
|
To cross-compile on Linux for Windows:
|
||||||
|
|
||||||
|
Get packages of the MinGW cross compiler and install them:
|
||||||
|
mingw32-filesystem mingw32-cross-cpp mingw32-cross-binutils mingw32-cross-gcc
|
||||||
|
mingw32-runtime mingw32-headers
|
||||||
|
The cross toolchain packages for your distribution may have slightly different
|
||||||
|
names (look for packages named *mingw*).
|
||||||
|
PCI-based programmers (internal etc.) are not supported on Windows.
|
||||||
|
Run (change CC= and STRIP= settings where appropriate)
|
||||||
|
make CC=i686-w64-mingw32-gcc STRIP=i686-w64-mingw32-strip
|
||||||
|
|
||||||
Processor architecture dependent features:
|
Processor architecture dependent features:
|
||||||
|
|
||||||
On non-x86 architectures you have to disable a few programmers because they
|
On non-x86 architectures a few programmers don't work (yet) because they
|
||||||
use port-based I/O which is not directly available on non-x86. Please add
|
use port-based I/O which is not directly available on non-x86. Those
|
||||||
CONFIG_RAYER_SPI=no CONFIG_NIC3COM=no CONFIG_ATAHPT=no CONFIG_NICREALTEK=no \
|
programmers will be disabled automatically if you run "make".
|
||||||
CONFIG_NICNATSEMI=no
|
|
||||||
as parameters to the "make" invocation.
|
|
||||||
Besides that, the internal programmer is only supported on x86 and MIPS. On
|
|
||||||
other architectures, please add
|
|
||||||
CONFIG_INTERNAL=no
|
|
||||||
as parameter to the "make" invocation.
|
|
||||||
|
|
||||||
Installation
|
Installation
|
||||||
------------
|
------------
|
||||||
|
@ -211,7 +211,7 @@ int coreboot_init(void)
|
|||||||
struct lb_header *lb_table;
|
struct lb_header *lb_table;
|
||||||
struct lb_record *rec, *last;
|
struct lb_record *rec, *last;
|
||||||
|
|
||||||
#ifdef __DARWIN__
|
#if defined(__MACH__) && defined(__APPLE__)
|
||||||
/* This is a hack. DirectHW fails to map physical address 0x00000000.
|
/* This is a hack. DirectHW fails to map physical address 0x00000000.
|
||||||
* Why?
|
* Why?
|
||||||
*/
|
*/
|
||||||
|
35
flashrom.c
35
flashrom.c
@ -60,10 +60,6 @@ unsigned long flashbase;
|
|||||||
/* Is writing allowed with this programmer? */
|
/* Is writing allowed with this programmer? */
|
||||||
int programmer_may_write;
|
int programmer_may_write;
|
||||||
|
|
||||||
#if CONFIG_INTERNAL+CONFIG_DUMMY+CONFIG_NIC3COM+CONFIG_NICREALTEK+CONFIG_NICNATSEMI+CONFIG_GFXNVIDIA+CONFIG_DRKAISER+CONFIG_SATASII+CONFIG_ATAHPT+CONFIG_FT2232_SPI+CONFIG_SERPROG+CONFIG_BUSPIRATE_SPI+CONFIG_DEDIPROG+CONFIG_RAYER_SPI+CONFIG_PONY_SPI+CONFIG_NICINTEL+CONFIG_NICINTEL_SPI+CONFIG_OGP_SPI+CONFIG_SATAMV+CONFIG_LINUX_SPI < 1
|
|
||||||
#error You have to enable at least one programmer!
|
|
||||||
#endif
|
|
||||||
|
|
||||||
const struct programmer_entry programmer_table[] = {
|
const struct programmer_entry programmer_table[] = {
|
||||||
#if CONFIG_INTERNAL == 1
|
#if CONFIG_INTERNAL == 1
|
||||||
{
|
{
|
||||||
@ -1490,10 +1486,35 @@ void list_programmers_linebreak(int startcol, int cols, int paren)
|
|||||||
|
|
||||||
void print_sysinfo(void)
|
void print_sysinfo(void)
|
||||||
{
|
{
|
||||||
#if HAVE_UTSNAME == 1
|
#ifdef _WIN32
|
||||||
struct utsname osinfo;
|
SYSTEM_INFO si;
|
||||||
uname(&osinfo);
|
OSVERSIONINFOEX osvi;
|
||||||
|
|
||||||
|
memset(&si, 0, sizeof(SYSTEM_INFO));
|
||||||
|
memset(&osvi, 0, sizeof(OSVERSIONINFOEX));
|
||||||
|
msg_ginfo(" on Windows");
|
||||||
|
/* Tell Windows which version of the structure we want. */
|
||||||
|
osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFOEX);
|
||||||
|
if (GetVersionEx((OSVERSIONINFO*) &osvi))
|
||||||
|
msg_ginfo(" %lu.%lu", osvi.dwMajorVersion, osvi.dwMinorVersion);
|
||||||
|
else
|
||||||
|
msg_ginfo(" unknown version");
|
||||||
|
GetSystemInfo(&si);
|
||||||
|
switch (si.wProcessorArchitecture) {
|
||||||
|
case PROCESSOR_ARCHITECTURE_AMD64:
|
||||||
|
msg_ginfo(" (x86_64)");
|
||||||
|
break;
|
||||||
|
case PROCESSOR_ARCHITECTURE_INTEL:
|
||||||
|
msg_ginfo(" (x86)");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
msg_ginfo(" (unknown arch)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#elif HAVE_UTSNAME == 1
|
||||||
|
struct utsname osinfo;
|
||||||
|
|
||||||
|
uname(&osinfo);
|
||||||
msg_ginfo(" on %s %s (%s)", osinfo.sysname, osinfo.release,
|
msg_ginfo(" on %s %s (%s)", osinfo.sysname, osinfo.release,
|
||||||
osinfo.machine);
|
osinfo.machine);
|
||||||
#else
|
#else
|
||||||
|
@ -180,10 +180,6 @@ cpu_to_be(64)
|
|||||||
#include <asm/sunddi.h>
|
#include <asm/sunddi.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (defined(__MACH__) && defined(__APPLE__))
|
|
||||||
#define __DARWIN__
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Clarification about OUTB/OUTW/OUTL argument order:
|
/* Clarification about OUTB/OUTW/OUTL argument order:
|
||||||
* OUT[BWL](val, port)
|
* OUT[BWL](val, port)
|
||||||
*/
|
*/
|
||||||
@ -203,7 +199,7 @@ cpu_to_be(64)
|
|||||||
#define INW(x) __extension__ ({ u_int inw_tmp = (x); inw(inw_tmp); })
|
#define INW(x) __extension__ ({ u_int inw_tmp = (x); inw(inw_tmp); })
|
||||||
#define INL(x) __extension__ ({ u_int inl_tmp = (x); inl(inl_tmp); })
|
#define INL(x) __extension__ ({ u_int inl_tmp = (x); inl(inl_tmp); })
|
||||||
#else
|
#else
|
||||||
#if defined(__DARWIN__)
|
#if defined(__MACH__) && defined(__APPLE__)
|
||||||
/* Header is part of the DirectHW library. */
|
/* Header is part of the DirectHW library. */
|
||||||
#include <DirectHW/DirectHW.h>
|
#include <DirectHW/DirectHW.h>
|
||||||
#define off64_t off_t
|
#define off64_t off_t
|
||||||
@ -303,7 +299,7 @@ static inline uint32_t inl(uint16_t port)
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(__DARWIN__) && !defined(__FreeBSD__) && !defined(__FreeBSD_kernel__) && !defined(__DragonFly__) && !defined(__LIBPAYLOAD__)
|
#if !(defined(__MACH__) && defined(__APPLE__)) && !defined(__FreeBSD__) && !defined(__FreeBSD_kernel__) && !defined(__DragonFly__) && !defined(__LIBPAYLOAD__)
|
||||||
typedef struct { uint32_t hi, lo; } msr_t;
|
typedef struct { uint32_t hi, lo; } msr_t;
|
||||||
msr_t rdmsr(int addr);
|
msr_t rdmsr(int addr);
|
||||||
int wrmsr(int addr, msr_t msr);
|
int wrmsr(int addr, msr_t msr);
|
||||||
|
@ -129,7 +129,7 @@ int setup_cpu_msr(int cpu)
|
|||||||
void cleanup_cpu_msr(void)
|
void cleanup_cpu_msr(void)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
#elif defined(__DARWIN__)
|
#elif defined(__MACH__) && defined(__APPLE__)
|
||||||
|
|
||||||
#define MEM_DEV "DirectHW"
|
#define MEM_DEV "DirectHW"
|
||||||
|
|
||||||
@ -468,7 +468,7 @@ void cleanup_cpu_msr(void)
|
|||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#ifdef __DARWIN__
|
#if defined(__MACH__) && defined(__APPLE__)
|
||||||
int setup_cpu_msr(int cpu)
|
int setup_cpu_msr(int cpu)
|
||||||
{
|
{
|
||||||
// Always succeed for now
|
// Always succeed for now
|
||||||
|
@ -240,6 +240,7 @@ int rpci_write_long(struct pci_dev *dev, int reg, uint32_t data);
|
|||||||
|
|
||||||
/* print.c */
|
/* print.c */
|
||||||
#if CONFIG_NIC3COM+CONFIG_NICREALTEK+CONFIG_NICNATSEMI+CONFIG_GFXNVIDIA+CONFIG_DRKAISER+CONFIG_SATASII+CONFIG_ATAHPT+CONFIG_NICINTEL+CONFIG_NICINTEL_SPI+CONFIG_OGP_SPI+CONFIG_SATAMV >= 1
|
#if CONFIG_NIC3COM+CONFIG_NICREALTEK+CONFIG_NICNATSEMI+CONFIG_GFXNVIDIA+CONFIG_DRKAISER+CONFIG_SATASII+CONFIG_ATAHPT+CONFIG_NICINTEL+CONFIG_NICINTEL_SPI+CONFIG_OGP_SPI+CONFIG_SATAMV >= 1
|
||||||
|
/* Not needed for CONFIG_INTERNAL, but for all other PCI-based programmers. */
|
||||||
void print_supported_pcidevs(const struct pcidev_status *devs);
|
void print_supported_pcidevs(const struct pcidev_status *devs);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -637,7 +638,7 @@ void serprog_delay(int usecs);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* serial.c */
|
/* serial.c */
|
||||||
#if _WIN32
|
#ifdef _WIN32
|
||||||
typedef HANDLE fdtype;
|
typedef HANDLE fdtype;
|
||||||
#else
|
#else
|
||||||
typedef int fdtype;
|
typedef int fdtype;
|
||||||
|
@ -15,11 +15,16 @@ CFLAGS += -MMD -MP -MF $(DEPPATH)/$(@F).d
|
|||||||
CFLAGS += -D ICH_DESCRIPTORS_FROM_DUMP
|
CFLAGS += -D ICH_DESCRIPTORS_FROM_DUMP
|
||||||
CFLAGS += $(patsubst %,-I%,$(EXTRAINCDIRS))
|
CFLAGS += $(patsubst %,-I%,$(EXTRAINCDIRS))
|
||||||
|
|
||||||
|
ifeq ($(TARGET_OS), DOS)
|
||||||
|
# DJGPP has odd uint*_t definitions which cause lots of format string warnings.
|
||||||
|
CFLAGS += -Wno-format
|
||||||
|
endif
|
||||||
|
|
||||||
OBJ = $(OBJATH)/$(SRC:%.c=%.o)
|
OBJ = $(OBJATH)/$(SRC:%.c=%.o)
|
||||||
|
|
||||||
SHAREDOBJ = $(OBJATH)/$(notdir $(SHAREDSRC:%.c=%.o))
|
SHAREDOBJ = $(OBJATH)/$(notdir $(SHAREDSRC:%.c=%.o))
|
||||||
|
|
||||||
all:$(PROGRAM)
|
all:$(PROGRAM)$(EXEC_SUFFIX)
|
||||||
|
|
||||||
$(OBJ): $(OBJATH)/%.o : %.c
|
$(OBJ): $(OBJATH)/%.o : %.c
|
||||||
$(CC) $(CFLAGS) -o $@ -c $<
|
$(CC) $(CFLAGS) -o $@ -c $<
|
||||||
@ -29,11 +34,11 @@ $(OBJ): $(OBJATH)/%.o : %.c
|
|||||||
$(SHAREDOBJ): $(OBJATH)/%.o : $(SHAREDSRCDIR)/%.c
|
$(SHAREDOBJ): $(OBJATH)/%.o : $(SHAREDSRCDIR)/%.c
|
||||||
$(CC) $(CFLAGS) -o $@ -c $<
|
$(CC) $(CFLAGS) -o $@ -c $<
|
||||||
|
|
||||||
$(PROGRAM): $(OBJ) $(SHAREDOBJ)
|
$(PROGRAM)$(EXEC_SUFFIX): $(OBJ) $(SHAREDOBJ)
|
||||||
$(CC) -o $(PROGRAM) $(OBJ) $(SHAREDOBJ)
|
$(CC) -o $(PROGRAM)$(EXEC_SUFFIX) $(OBJ) $(SHAREDOBJ)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f $(PROGRAM)
|
rm -f $(PROGRAM) $(PROGRAM).exe
|
||||||
rm -rf $(DEPPATH) $(OBJATH)
|
rm -rf $(DEPPATH) $(OBJATH)
|
||||||
|
|
||||||
# Include the dependency files.
|
# Include the dependency files.
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <sys/mman.h>
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
@ -33,6 +32,13 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include "ich_descriptors.h"
|
#include "ich_descriptors.h"
|
||||||
|
/* Some DJGPP builds define __unix__ although they don't support mmap().
|
||||||
|
* Cygwin defines __unix__ and supports mmap(), but it does not work well.
|
||||||
|
*/
|
||||||
|
#if !defined(__MSDOS__) && !defined(_WIN32) && (defined(unix) || defined(__unix__) || defined(__unix)) || (defined(__MACH__) && defined(__APPLE__))
|
||||||
|
#define HAVE_MMAP 1
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
static void dump_file(const char *basename, const uint32_t *dump, unsigned int len, struct ich_desc_region *reg, unsigned int i)
|
static void dump_file(const char *basename, const uint32_t *dump, unsigned int len, struct ich_desc_region *reg, unsigned int i)
|
||||||
{
|
{
|
||||||
@ -161,16 +167,17 @@ int main(int argc, char *argv[])
|
|||||||
if (len < 0)
|
if (len < 0)
|
||||||
usage(argv, "Seeking to the end of the file failed");
|
usage(argv, "Seeking to the end of the file failed");
|
||||||
|
|
||||||
|
#ifdef HAVE_MMAP
|
||||||
buf = mmap(NULL, len, PROT_READ, MAP_PRIVATE, fd, 0);
|
buf = mmap(NULL, len, PROT_READ, MAP_PRIVATE, fd, 0);
|
||||||
if (buf == (void *) -1) {
|
if (buf == (void *) -1)
|
||||||
|
#endif
|
||||||
|
{
|
||||||
/* fallback for stupid OSes like cygwin */
|
/* fallback for stupid OSes like cygwin */
|
||||||
int ret;
|
|
||||||
buf = malloc(len);
|
buf = malloc(len);
|
||||||
if (!buf)
|
if (!buf)
|
||||||
usage(argv, "Could not allocate memory");
|
usage(argv, "Could not allocate memory");
|
||||||
lseek(fd, 0, SEEK_SET);
|
lseek(fd, 0, SEEK_SET);
|
||||||
ret = read(fd, buf, len);
|
if (len != read(fd, buf, len))
|
||||||
if (ret != len)
|
|
||||||
usage(argv, "Seeking to the end of the file failed");
|
usage(argv, "Seeking to the end of the file failed");
|
||||||
}
|
}
|
||||||
printf("The flash image has a size of %d [0x%x] bytes.\n", len, len);
|
printf("The flash image has a size of %d [0x%x] bytes.\n", len, len);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user