blob: 26f978f9a220439a194d974888f1774f647f7692 [file] [log] [blame]
Ollie Lho184a4042005-11-26 21:55:36 +00001#
Uwe Hermannf78cff12009-06-12 14:05:25 +00002# This file is part of the flashrom project.
3#
4# Copyright (C) 2005 coresystems GmbH <stepan@coresystems.de>
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +00005# Copyright (C) 2009,2010 Carl-Daniel Hailfinger
Uwe Hermannf78cff12009-06-12 14:05:25 +00006#
7# This program is free software; you can redistribute it and/or modify
8# it under the terms of the GNU General Public License as published by
9# the Free Software Foundation; version 2 of the License.
10#
11# This program is distributed in the hope that it will be useful,
12# but WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14# GNU General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License
17# along with this program; if not, write to the Free Software
18# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Ollie Lho184a4042005-11-26 21:55:36 +000019#
Ronald G. Minnich5e5f75e2002-01-29 18:21:41 +000020
Ollie Lho184a4042005-11-26 21:55:36 +000021PROGRAM = flashrom
Ronald G. Minnicheaab50b2003-09-12 22:41:53 +000022
Uwe Hermannc2a9c9c2009-05-14 14:51:14 +000023CC ?= gcc
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +000024STRIP ?= strip
Christian Ruppertdb9d9f42009-05-14 14:17:07 +000025INSTALL = install
Paul Fox05dfbe62009-06-16 21:08:06 +000026DIFF = diff
Christian Ruppertdb9d9f42009-05-14 14:17:07 +000027PREFIX ?= /usr/local
Uwe Hermann56b2cb02009-05-21 15:59:58 +000028MANDIR ?= $(PREFIX)/share/man
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +000029CFLAGS ?= -Os -Wall -Wshadow
Carl-Daniel Hailfingera23041c2009-06-12 14:49:10 +000030EXPORTDIR ?= .
Patrick Georgi97bc95c2011-03-08 07:17:44 +000031AR ?= ar
32RANLIB ?= ranlib
Christian Ruppertdb9d9f42009-05-14 14:17:07 +000033
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +000034WARNERROR ?= yes
35
36ifeq ($(WARNERROR), yes)
37CFLAGS += -Werror
38endif
39
Carl-Daniel Hailfinger91199a12011-07-07 06:59:18 +000040# Determine the destination processor architecture
Stefan Tauner56787082011-08-18 02:27:19 +000041override ARCH := $(strip $(shell LC_ALL=C $(CC) -E arch.h|grep -v '^\#'))
Carl-Daniel Hailfinger91199a12011-07-07 06:59:18 +000042
43# FIXME We have to differentiate between host and target OS architecture.
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +000044OS_ARCH ?= $(shell uname)
Peter Stugea69c4472009-01-26 01:16:09 +000045ifneq ($(OS_ARCH), SunOS)
Adam Kaufman064b1f22007-02-06 19:47:50 +000046STRIP_ARGS = -s
47endif
Stefan Reinauerf79edb92009-01-26 01:23:31 +000048ifeq ($(OS_ARCH), Darwin)
Stefan Reinauer2fea3f32010-01-21 20:26:30 +000049CPPFLAGS += -I/opt/local/include -I/usr/local/include
Stefan Reinauer83704c52011-03-18 22:00:15 +000050# DirectHW framework can be found in the DirectHW library.
51LDFLAGS += -framework IOKit -framework DirectHW -L/opt/local/lib -L/usr/local/lib
Stefan Reinauerf79edb92009-01-26 01:23:31 +000052endif
Andriy Gapon65c1b862008-05-22 13:22:45 +000053ifeq ($(OS_ARCH), FreeBSD)
Stefan Reinauer2fea3f32010-01-21 20:26:30 +000054CPPFLAGS += -I/usr/local/include
Andriy Gapon65c1b862008-05-22 13:22:45 +000055LDFLAGS += -L/usr/local/lib
56endif
Carl-Daniel Hailfingerb63b0672010-07-02 17:12:50 +000057ifeq ($(OS_ARCH), OpenBSD)
58CPPFLAGS += -I/usr/local/include
59LDFLAGS += -L/usr/local/lib
60endif
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +000061ifeq ($(OS_ARCH), DOS)
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +000062EXEC_SUFFIX := .exe
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +000063CPPFLAGS += -I../libgetopt -I../libpci/include
Carl-Daniel Hailfinger5bdf2982010-06-14 12:42:05 +000064# FIXME Check if we can achieve the same effect with -L../libgetopt -lgetopt
65LIBS += ../libgetopt/libgetopt.a
Carl-Daniel Hailfinger5d3fcb92010-06-14 18:40:59 +000066# Bus Pirate and Serprog are not supported under DOS (missing serial support).
67ifeq ($(CONFIG_BUSPIRATE_SPI), yes)
68UNSUPPORTED_FEATURES += CONFIG_BUSPIRATE_SPI=yes
69else
70override CONFIG_BUSPIRATE_SPI = no
71endif
72ifeq ($(CONFIG_SERPROG), yes)
73UNSUPPORTED_FEATURES += CONFIG_SERPROG=yes
74else
75override CONFIG_SERPROG = no
76endif
77# Dediprog and FT2232 are not supported under DOS (missing USB support).
78ifeq ($(CONFIG_DEDIPROG), yes)
79UNSUPPORTED_FEATURES += CONFIG_DEDIPROG=yes
80else
81override CONFIG_DEDIPROG = no
82endif
83ifeq ($(CONFIG_FT2232_SPI), yes)
84UNSUPPORTED_FEATURES += CONFIG_FT2232_SPI=yes
85else
86override CONFIG_FT2232_SPI = no
87endif
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +000088endif
Ollie Lho184a4042005-11-26 21:55:36 +000089
Uwe Hermannd5e85d62011-07-03 19:44:12 +000090ifeq ($(OS_ARCH), MINGW32_NT-5.1)
91# Explicitly set CC = gcc on MinGW, otherwise: "cc: command not found".
92CC = gcc
93# MinGW doesn't have the ffs() function, but we can use gcc's __builtin_ffs().
94CFLAGS += -Dffs=__builtin_ffs
95# libusb-win32/libftdi stuff is usually installed in /usr/local.
96CPPFLAGS += -I/usr/local/include
97LDFLAGS += -L/usr/local/lib
98# Serprog is not supported under Windows/MinGW (missing sockets support).
99ifeq ($(CONFIG_SERPROG), yes)
100UNSUPPORTED_FEATURES += CONFIG_SERPROG=yes
101else
102override CONFIG_SERPROG = no
103endif
104# For now we disable all PCI-based programmers on Windows/MinGW (no libpci).
105ifeq ($(CONFIG_INTERNAL), yes)
106UNSUPPORTED_FEATURES += CONFIG_INTERNAL=yes
107else
108override CONFIG_INTERNAL = no
109endif
110ifeq ($(CONFIG_RAYER_SPI), yes)
111UNSUPPORTED_FEATURES += CONFIG_RAYER_SPI=yes
112else
113override CONFIG_RAYER_SPI = no
114endif
115ifeq ($(CONFIG_NIC3COM), yes)
116UNSUPPORTED_FEATURES += CONFIG_NIC3COM=yes
117else
118override CONFIG_NIC3COM = no
119endif
120ifeq ($(CONFIG_GFXNVIDIA), yes)
121UNSUPPORTED_FEATURES += CONFIG_GFXNVIDIA=yes
122else
123override CONFIG_GFXNVIDIA = no
124endif
125ifeq ($(CONFIG_SATASII), yes)
126UNSUPPORTED_FEATURES += CONFIG_SATASII=yes
127else
128override CONFIG_SATASII = no
129endif
130ifeq ($(CONFIG_ATAHPT), yes)
131UNSUPPORTED_FEATURES += CONFIG_ATAHPT=yes
132else
133override CONFIG_ATAHPT = no
134endif
135ifeq ($(CONFIG_DRKAISER), yes)
136UNSUPPORTED_FEATURES += CONFIG_DRKAISER=yes
137else
138override CONFIG_DRKAISER = no
139endif
140ifeq ($(CONFIG_NICREALTEK), yes)
141UNSUPPORTED_FEATURES += CONFIG_NICREALTEK=yes
142else
143override CONFIG_NICREALTEK = no
144endif
145ifeq ($(CONFIG_NICNATSEMI), yes)
146UNSUPPORTED_FEATURES += CONFIG_NICNATSEMI=yes
147else
148override CONFIG_NICNATSEMI = no
149endif
150ifeq ($(CONFIG_NICINTEL), yes)
151UNSUPPORTED_FEATURES += CONFIG_NICINTEL=yes
152else
153override CONFIG_NICINTEL = no
154endif
155ifeq ($(CONFIG_NICINTEL_SPI), yes)
156UNSUPPORTED_FEATURES += CONFIG_NICINTEL_SPI=yes
157else
158override CONFIG_NICINTEL_SPI = no
159endif
160ifeq ($(CONFIG_OGP_SPI), yes)
161UNSUPPORTED_FEATURES += CONFIG_OGP_SPI=yes
162else
163override CONFIG_OGP_SPI = no
164endif
165ifeq ($(CONFIG_SATAMV), yes)
166UNSUPPORTED_FEATURES += CONFIG_SATAMV=yes
167else
168override CONFIG_SATAMV = no
169endif
170endif
171
Patrick Georgi97bc95c2011-03-08 07:17:44 +0000172ifeq ($(OS_ARCH), libpayload)
173CC:=CC=i386-elf-gcc lpgcc
174AR:=i386-elf-ar
175RANLIB:=i386-elf-ranlib
176CPPFLAGS += -DSTANDALONE
177ifeq ($(CONFIG_DUMMY), yes)
178UNSUPPORTED_FEATURES += CONFIG_DUMMY=yes
179else
180override CONFIG_DUMMY = no
181endif
182ifeq ($(CONFIG_BUSPIRATE_SPI), yes)
183UNSUPPORTED_FEATURES += CONFIG_BUSPIRATE_SPI=yes
184else
185override CONFIG_BUSPIRATE_SPI = no
186endif
187ifeq ($(CONFIG_SERPROG), yes)
188UNSUPPORTED_FEATURES += CONFIG_SERPROG=yes
189else
190override CONFIG_SERPROG = no
191endif
192# Dediprog and FT2232 are not supported with libpayload (missing libusb support)
193ifeq ($(CONFIG_DEDIPROG), yes)
194UNSUPPORTED_FEATURES += CONFIG_DEDIPROG=yes
195else
196override CONFIG_DEDIPROG = no
197endif
198ifeq ($(CONFIG_FT2232_SPI), yes)
199UNSUPPORTED_FEATURES += CONFIG_FT2232_SPI=yes
200else
201override CONFIG_FT2232_SPI = no
202endif
203endif
204
Uwe Hermann21b10c62011-07-29 12:13:01 +0000205ifeq ($(ARCH), "ppc")
206# There's no PCI port I/O support on PPC/PowerPC, yet.
207ifeq ($(CONFIG_NIC3COM), yes)
208UNSUPPORTED_FEATURES += CONFIG_NIC3COM=yes
209else
210override CONFIG_NIC3COM = no
211endif
212ifeq ($(CONFIG_NICREALTEK), yes)
213UNSUPPORTED_FEATURES += CONFIG_NICREALTEK=yes
214else
215override CONFIG_NICREALTEK = no
216endif
217ifeq ($(CONFIG_NICNATSEMI), yes)
218UNSUPPORTED_FEATURES += CONFIG_NICNATSEMI=yes
219else
220override CONFIG_NICNATSEMI = no
221endif
222ifeq ($(CONFIG_RAYER_SPI), yes)
223UNSUPPORTED_FEATURES += CONFIG_RAYER_SPI=yes
224else
225override CONFIG_RAYER_SPI = no
226endif
227ifeq ($(CONFIG_ATAHPT), yes)
228UNSUPPORTED_FEATURES += CONFIG_ATAHPT=yes
229else
230override CONFIG_ATAHPT = no
231endif
232ifeq ($(CONFIG_SATAMV), yes)
233UNSUPPORTED_FEATURES += CONFIG_SATAMV=yes
234else
235override CONFIG_SATAMV = no
236endif
237endif
238
Carl-Daniel Hailfinger91882402010-12-05 16:33:59 +0000239CHIP_OBJS = jedec.o stm50flw0x0x.o w39.o w29ee011.o \
Sean Nelson35727f72010-01-28 23:55:12 +0000240 sst28sf040.o m29f400bt.o 82802ab.o pm49fl00x.o \
Carl-Daniel Hailfinger7a3bd8f2011-05-19 00:06:06 +0000241 sst49lfxxxc.o sst_fwhub.o flashchips.o spi.o spi25.o sharplhf00l04.o \
242 a25.o at25.o
Sean Nelson5d134642009-12-24 16:54:21 +0000243
244LIB_OBJS = layout.o
245
Sean Nelson51e97d72010-01-07 20:09:33 +0000246CLI_OBJS = flashrom.o cli_classic.o cli_output.o print.o
Sean Nelson5d134642009-12-24 16:54:21 +0000247
Carl-Daniel Hailfingercc1802d2010-01-06 10:21:00 +0000248PROGRAMMER_OBJS = udelay.o programmer.o
Ollie Lho184a4042005-11-26 21:55:36 +0000249
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000250all: pciutils features $(PROGRAM)$(EXEC_SUFFIX)
Ollie Lho184a4042005-11-26 21:55:36 +0000251
Carl-Daniel Hailfinger9e675852009-05-04 12:29:59 +0000252# Set the flashrom version string from the highest revision number
253# of the checked out flashrom files.
Carl-Daniel Hailfingera23041c2009-06-12 14:49:10 +0000254# Note to packagers: Any tree exported with "make export" or "make tarball"
255# will not require subversion. The downloadable snapshots are already exported.
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +0000256SVNVERSION := $(shell LC_ALL=C svnversion -cn . 2>/dev/null | sed -e "s/.*://" -e "s/\([0-9]*\).*/\1/" | grep "[0-9]" || LC_ALL=C svn info . 2>/dev/null | awk '/^Revision:/ {print $$2 }' | grep "[0-9]" || LC_ALL=C git svn info . 2>/dev/null | awk '/^Revision:/ {print $$2 }' | grep "[0-9]" || echo unknown)
Carl-Daniel Hailfingera23041c2009-06-12 14:49:10 +0000257
Carl-Daniel Hailfinger4deb8c62011-07-26 20:43:13 +0000258RELEASE := 0.9.4
Carl-Daniel Hailfinger48e5e092009-08-31 16:25:08 +0000259VERSION := $(RELEASE)-r$(SVNVERSION)
260RELEASENAME ?= $(VERSION)
Carl-Daniel Hailfingera23041c2009-06-12 14:49:10 +0000261
262SVNDEF := -D'FLASHROM_VERSION="$(VERSION)"'
Bernhard Walle201bde32008-01-21 15:24:22 +0000263
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000264# Always enable internal/onboard support for now.
265CONFIG_INTERNAL ?= yes
266
Carl-Daniel Hailfinger6be74112009-08-12 16:17:41 +0000267# Always enable serprog for now. Needs to be disabled on Windows.
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000268CONFIG_SERPROG ?= yes
269
Carl-Daniel Hailfingere7fdd6e2010-07-21 10:26:01 +0000270# RayeR SPIPGM hardware support
271CONFIG_RAYER_SPI ?= yes
272
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000273# Always enable 3Com NICs for now.
274CONFIG_NIC3COM ?= yes
275
Carl-Daniel Hailfingerbf3af292010-07-29 14:41:46 +0000276# Enable NVIDIA graphics cards. Note: write and erase do not work properly.
277CONFIG_GFXNVIDIA ?= yes
Uwe Hermann2bc98f62009-09-30 18:29:55 +0000278
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000279# Always enable SiI SATA controllers for now.
280CONFIG_SATASII ?= yes
281
Uwe Hermannddd5c9e2010-02-21 21:17:00 +0000282# Highpoint (HPT) ATA/RAID controller support.
283# IMPORTANT: This code is not yet working!
284CONFIG_ATAHPT ?= no
285
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000286# Always enable FT2232 SPI dongles for now.
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000287CONFIG_FT2232_SPI ?= yes
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000288
289# Always enable dummy tracing for now.
290CONFIG_DUMMY ?= yes
291
292# Always enable Dr. Kaiser for now.
293CONFIG_DRKAISER ?= yes
Carl-Daniel Hailfinger6be74112009-08-12 16:17:41 +0000294
Joerg Fischer5665ef32010-05-21 21:54:07 +0000295# Always enable Realtek NICs for now.
296CONFIG_NICREALTEK ?= yes
297
Andrew Morganc29c2e72010-06-07 22:37:54 +0000298# Disable National Semiconductor NICs until support is complete and tested.
299CONFIG_NICNATSEMI ?= no
300
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000301# Always enable Intel NICs for now.
302CONFIG_NICINTEL ?= yes
303
Idwer Vollering004f4b72010-09-03 18:21:21 +0000304# Always enable SPI on Intel NICs for now.
305CONFIG_NICINTEL_SPI ?= yes
306
Mark Marshall90021f22010-12-03 14:48:11 +0000307# Always enable SPI on OGP cards for now.
308CONFIG_OGP_SPI ?= yes
309
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000310# Always enable Bus Pirate SPI for now.
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000311CONFIG_BUSPIRATE_SPI ?= yes
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000312
Carl-Daniel Hailfingerd38fac82010-01-19 11:15:48 +0000313# Disable Dediprog SF100 until support is complete and tested.
314CONFIG_DEDIPROG ?= no
315
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000316# Always enable Marvell SATA controllers for now.
317CONFIG_SATAMV ?= yes
318
Carl-Daniel Hailfinger6161ff12009-11-16 21:22:24 +0000319# Disable wiki printing by default. It is only useful if you have wiki access.
Uwe Hermann2db77a02010-06-04 17:07:39 +0000320CONFIG_PRINT_WIKI ?= no
Carl-Daniel Hailfinger9c8476b2009-09-16 12:19:03 +0000321
Carl-Daniel Hailfinger9e3a6c42010-10-08 12:40:09 +0000322# Bitbanging SPI infrastructure, default off unless needed.
323ifeq ($(CONFIG_RAYER_SPI), yes)
324override CONFIG_BITBANG_SPI = yes
325else
326ifeq ($(CONFIG_INTERNAL), yes)
327override CONFIG_BITBANG_SPI = yes
328else
329ifeq ($(CONFIG_NICINTEL_SPI), yes)
330override CONFIG_BITBANG_SPI = yes
331else
Mark Marshall90021f22010-12-03 14:48:11 +0000332ifeq ($(CONFIG_OGP_SPI), yes)
333override CONFIG_BITBANG_SPI = yes
334else
Carl-Daniel Hailfinger9e3a6c42010-10-08 12:40:09 +0000335CONFIG_BITBANG_SPI ?= no
336endif
337endif
338endif
Mark Marshall90021f22010-12-03 14:48:11 +0000339endif
Carl-Daniel Hailfinger9e3a6c42010-10-08 12:40:09 +0000340
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000341ifeq ($(CONFIG_INTERNAL), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000342FEATURE_CFLAGS += -D'CONFIG_INTERNAL=1'
Carl-Daniel Hailfingerb5b161b2010-06-04 19:05:39 +0000343PROGRAMMER_OBJS += processor_enable.o chipset_enable.o board_enable.o cbtable.o dmi.o internal.o
Carl-Daniel Hailfinger91199a12011-07-07 06:59:18 +0000344ifeq ($(ARCH),"x86")
David Hendricks4e748392011-02-28 23:58:15 +0000345PROGRAMMER_OBJS += it87spi.o it85spi.o ichspi.o sb600spi.o wbsio_spi.o mcp6x_spi.o
Carl-Daniel Hailfinger91199a12011-07-07 06:59:18 +0000346else
347endif
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000348NEED_PCI := yes
349endif
350
Carl-Daniel Hailfinger6be74112009-08-12 16:17:41 +0000351ifeq ($(CONFIG_SERPROG), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000352FEATURE_CFLAGS += -D'CONFIG_SERPROG=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000353PROGRAMMER_OBJS += serprog.o
Carl-Daniel Hailfinger5bdf2982010-06-14 12:42:05 +0000354NEED_SERIAL := yes
355NEED_NET := yes
Carl-Daniel Hailfinger6be74112009-08-12 16:17:41 +0000356endif
357
Carl-Daniel Hailfingere7fdd6e2010-07-21 10:26:01 +0000358ifeq ($(CONFIG_RAYER_SPI), yes)
359FEATURE_CFLAGS += -D'CONFIG_RAYER_SPI=1'
360PROGRAMMER_OBJS += rayer_spi.o
361# Actually, NEED_PCI is wrong. NEED_IOPORT_ACCESS would be more correct.
362NEED_PCI := yes
363endif
364
Carl-Daniel Hailfinger547872b2009-09-28 13:15:16 +0000365ifeq ($(CONFIG_BITBANG_SPI), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000366FEATURE_CFLAGS += -D'CONFIG_BITBANG_SPI=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000367PROGRAMMER_OBJS += bitbang_spi.o
Carl-Daniel Hailfinger547872b2009-09-28 13:15:16 +0000368endif
369
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000370ifeq ($(CONFIG_NIC3COM), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000371FEATURE_CFLAGS += -D'CONFIG_NIC3COM=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000372PROGRAMMER_OBJS += nic3com.o
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000373NEED_PCI := yes
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000374endif
Carl-Daniel Hailfinger6be74112009-08-12 16:17:41 +0000375
Uwe Hermann2bc98f62009-09-30 18:29:55 +0000376ifeq ($(CONFIG_GFXNVIDIA), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000377FEATURE_CFLAGS += -D'CONFIG_GFXNVIDIA=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000378PROGRAMMER_OBJS += gfxnvidia.o
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000379NEED_PCI := yes
Uwe Hermann2bc98f62009-09-30 18:29:55 +0000380endif
381
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000382ifeq ($(CONFIG_SATASII), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000383FEATURE_CFLAGS += -D'CONFIG_SATASII=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000384PROGRAMMER_OBJS += satasii.o
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000385NEED_PCI := yes
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000386endif
387
Uwe Hermannddd5c9e2010-02-21 21:17:00 +0000388ifeq ($(CONFIG_ATAHPT), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000389FEATURE_CFLAGS += -D'CONFIG_ATAHPT=1'
Uwe Hermannddd5c9e2010-02-21 21:17:00 +0000390PROGRAMMER_OBJS += atahpt.o
391NEED_PCI := yes
392endif
393
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000394ifeq ($(CONFIG_FT2232_SPI), yes)
Carl-Daniel Hailfingerc1f00c52010-01-09 14:18:01 +0000395FTDILIBS := $(shell pkg-config --libs libftdi 2>/dev/null || printf "%s" "-lftdi -lusb")
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000396# This is a totally ugly hack.
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000397FEATURE_CFLAGS += $(shell LC_ALL=C grep -q "FTDISUPPORT := yes" .features && printf "%s" "-D'CONFIG_FT2232_SPI=1'")
Jörg Mayer8776db22009-11-16 14:05:13 +0000398FEATURE_LIBS += $(shell LC_ALL=C grep -q "FTDISUPPORT := yes" .features && printf "%s" "$(FTDILIBS)")
Sean Nelson5d134642009-12-24 16:54:21 +0000399PROGRAMMER_OBJS += ft2232_spi.o
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000400endif
401
402ifeq ($(CONFIG_DUMMY), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000403FEATURE_CFLAGS += -D'CONFIG_DUMMY=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000404PROGRAMMER_OBJS += dummyflasher.o
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000405endif
406
407ifeq ($(CONFIG_DRKAISER), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000408FEATURE_CFLAGS += -D'CONFIG_DRKAISER=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000409PROGRAMMER_OBJS += drkaiser.o
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000410NEED_PCI := yes
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000411endif
Carl-Daniel Hailfinger6be74112009-08-12 16:17:41 +0000412
Joerg Fischer5665ef32010-05-21 21:54:07 +0000413ifeq ($(CONFIG_NICREALTEK), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000414FEATURE_CFLAGS += -D'CONFIG_NICREALTEK=1'
Joerg Fischer5665ef32010-05-21 21:54:07 +0000415PROGRAMMER_OBJS += nicrealtek.o
416NEED_PCI := yes
417endif
418
Andrew Morganc29c2e72010-06-07 22:37:54 +0000419ifeq ($(CONFIG_NICNATSEMI), yes)
420FEATURE_CFLAGS += -D'CONFIG_NICNATSEMI=1'
421PROGRAMMER_OBJS += nicnatsemi.o
422NEED_PCI := yes
423endif
424
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000425ifeq ($(CONFIG_NICINTEL), yes)
426FEATURE_CFLAGS += -D'CONFIG_NICINTEL=1'
427PROGRAMMER_OBJS += nicintel.o
428NEED_PCI := yes
429endif
430
Idwer Vollering004f4b72010-09-03 18:21:21 +0000431ifeq ($(CONFIG_NICINTEL_SPI), yes)
432FEATURE_CFLAGS += -D'CONFIG_NICINTEL_SPI=1'
433PROGRAMMER_OBJS += nicintel_spi.o
434NEED_PCI := yes
435endif
436
Mark Marshall90021f22010-12-03 14:48:11 +0000437ifeq ($(CONFIG_OGP_SPI), yes)
438FEATURE_CFLAGS += -D'CONFIG_OGP_SPI=1'
439PROGRAMMER_OBJS += ogp_spi.o
440NEED_PCI := yes
441endif
442
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000443ifeq ($(CONFIG_BUSPIRATE_SPI), yes)
444FEATURE_CFLAGS += -D'CONFIG_BUSPIRATE_SPI=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000445PROGRAMMER_OBJS += buspirate_spi.o
Carl-Daniel Hailfinger5bdf2982010-06-14 12:42:05 +0000446NEED_SERIAL := yes
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000447endif
448
Carl-Daniel Hailfingerd38fac82010-01-19 11:15:48 +0000449ifeq ($(CONFIG_DEDIPROG), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000450FEATURE_CFLAGS += -D'CONFIG_DEDIPROG=1'
Carl-Daniel Hailfingerd38fac82010-01-19 11:15:48 +0000451FEATURE_LIBS += -lusb
452PROGRAMMER_OBJS += dediprog.o
453endif
454
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000455ifeq ($(CONFIG_SATAMV), yes)
456FEATURE_CFLAGS += -D'CONFIG_SATAMV=1'
457PROGRAMMER_OBJS += satamv.o
458NEED_PCI := yes
459endif
460
Carl-Daniel Hailfinger5bdf2982010-06-14 12:42:05 +0000461ifeq ($(NEED_SERIAL), yes)
Sean Nelson5d134642009-12-24 16:54:21 +0000462LIB_OBJS += serial.o
Carl-Daniel Hailfinger5bdf2982010-06-14 12:42:05 +0000463endif
464
465ifeq ($(NEED_NET), yes)
466ifeq ($(OS_ARCH), SunOS)
467LIBS += -lsocket
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000468endif
Carl-Daniel Hailfingere51ea102009-11-23 19:20:11 +0000469endif
470
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000471ifeq ($(NEED_PCI), yes)
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +0000472CHECK_LIBPCI = yes
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000473FEATURE_CFLAGS += -D'NEED_PCI=1'
Carl-Daniel Hailfingerfb0828f2010-02-12 19:35:25 +0000474PROGRAMMER_OBJS += pcidev.o physmap.o hwaccess.o
Jonathan A. Kollasch3646c8f2010-01-08 21:18:08 +0000475ifeq ($(OS_ARCH), NetBSD)
Carl-Daniel Hailfinger460b2822010-06-04 23:24:57 +0000476# The libpci we want is called libpciutils on NetBSD and needs NetBSD libpci.
477LIBS += -lpciutils -lpci
478# For (i386|x86_64)_iopl(2).
479LIBS += -l$(shell uname -p)
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +0000480else
481ifeq ($(OS_ARCH), DOS)
482# FIXME There needs to be a better way to do this
Carl-Daniel Hailfinger5bdf2982010-06-14 12:42:05 +0000483LIBS += ../libpci/lib/libpci.a
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +0000484else
485LIBS += -lpci
Carl-Daniel Hailfingerb63b0672010-07-02 17:12:50 +0000486ifeq ($(OS_ARCH), OpenBSD)
487# For (i386|amd64)_iopl(2).
488LIBS += -l$(shell uname -m)
489endif
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +0000490endif
Jonathan A. Kollasch3646c8f2010-01-08 21:18:08 +0000491endif
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000492endif
493
Carl-Daniel Hailfinger9c8476b2009-09-16 12:19:03 +0000494ifeq ($(CONFIG_PRINT_WIKI), yes)
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000495FEATURE_CFLAGS += -D'CONFIG_PRINT_WIKI=1'
Sean Nelson5d134642009-12-24 16:54:21 +0000496CLI_OBJS += print_wiki.o
Carl-Daniel Hailfinger9c8476b2009-09-16 12:19:03 +0000497endif
498
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +0000499FEATURE_CFLAGS += $(shell LC_ALL=C grep -q "UTSNAME := yes" .features && printf "%s" "-D'HAVE_UTSNAME=1'")
500
Carl-Daniel Hailfingera472b8b2009-10-03 17:08:02 +0000501# We could use PULLED_IN_LIBS, but that would be ugly.
502FEATURE_LIBS += $(shell LC_ALL=C grep -q "NEEDLIBZ := yes" .libdeps && printf "%s" "-lz")
503
Patrick Georgi97bc95c2011-03-08 07:17:44 +0000504LIBFLASHROM_OBJS = $(CHIP_OBJS) $(PROGRAMMER_OBJS) $(LIB_OBJS)
505OBJS = $(CLI_OBJS) $(LIBFLASHROM_OBJS)
Sean Nelson5d134642009-12-24 16:54:21 +0000506
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000507$(PROGRAM)$(EXEC_SUFFIX): $(OBJS)
508 $(CC) $(LDFLAGS) -o $(PROGRAM)$(EXEC_SUFFIX) $(OBJS) $(FEATURE_LIBS) $(LIBS)
Ronald G. Minnich5e5f75e2002-01-29 18:21:41 +0000509
Patrick Georgi97bc95c2011-03-08 07:17:44 +0000510libflashrom.a: $(LIBFLASHROM_OBJS)
511 $(AR) rcs $@ $^
512 $(RANLIB) $@
513
Carl-Daniel Hailfinger8ef7dce2009-07-10 20:19:48 +0000514# TAROPTIONS reduces information leakage from the packager's system.
515# If other tar programs support command line arguments for setting uid/gid of
516# stored files, they can be handled here as well.
517TAROPTIONS = $(shell LC_ALL=C tar --version|grep -q GNU && echo "--owner=root --group=root")
Carl-Daniel Hailfingerb18ecbc2009-06-19 14:20:34 +0000518
Paul Fox05dfbe62009-06-16 21:08:06 +0000519%.o: %.c .features
Stefan Reinauere2f01582010-06-07 11:08:07 +0000520 $(CC) -MMD $(CFLAGS) $(CPPFLAGS) $(FEATURE_CFLAGS) $(SVNDEF) -o $@ -c $<
Clark Rawlins02016f72008-02-14 23:22:20 +0000521
Carl-Daniel Hailfingera0020df2010-05-30 22:35:14 +0000522# Make sure to add all names of generated binaries here.
523# This includes all frontends and libflashrom.
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000524# We don't use EXEC_SUFFIX here because we want to clean everything.
Ronald G. Minnich5e5f75e2002-01-29 18:21:41 +0000525clean:
Patrick Georgi97bc95c2011-03-08 07:17:44 +0000526 rm -f $(PROGRAM) $(PROGRAM).exe libflashrom.a *.o *.d
Ronald G. Minnicheaab50b2003-09-12 22:41:53 +0000527
Ollie Lho184a4042005-11-26 21:55:36 +0000528distclean: clean
Stefan Reinauere2f01582010-06-07 11:08:07 +0000529 rm -f .features .libdeps
Christian Ruppertdb9d9f42009-05-14 14:17:07 +0000530
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000531strip: $(PROGRAM)$(EXEC_SUFFIX)
532 $(STRIP) $(STRIP_ARGS) $(PROGRAM)$(EXEC_SUFFIX)
Ronald G. Minnicheaab50b2003-09-12 22:41:53 +0000533
Stefan Tauner56787082011-08-18 02:27:19 +0000534# to define test programs we use verbatim variables, which get exported
535# to environment variables and are referenced with $$<varname> later
536
537define COMPILER_TEST
538int main(int argc, char **argv)
539{
540 (void) argc;
541 (void) argv;
542 return 0;
543}
544endef
545export COMPILER_TEST
546
Carl-Daniel Hailfinger5d3fcb92010-06-14 18:40:59 +0000547compiler: featuresavailable
Paul Fox05dfbe62009-06-16 21:08:06 +0000548 @printf "Checking for a C compiler... "
Stefan Tauner56787082011-08-18 02:27:19 +0000549 @echo "$$COMPILER_TEST" > .test.c
550 @$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) .test.c -o .test$(EXEC_SUFFIX) >/dev/null 2>&1 && \
Carl-Daniel Hailfinger4cb7a962009-06-16 09:31:51 +0000551 echo "found." || ( echo "not found."; \
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000552 rm -f .test.c .test$(EXEC_SUFFIX); exit 1)
553 @rm -f .test.c .test$(EXEC_SUFFIX)
Carl-Daniel Hailfinger91199a12011-07-07 06:59:18 +0000554 @printf "ARCH is "
555 @# FreeBSD wc will output extraneous whitespace.
556 @echo $(ARCH)|wc -l|grep -q '^[[:blank:]]*1[[:blank:]]*$$' || \
557 ( echo "unknown. Aborting."; exit 1)
558 @printf "%s\n" '$(ARCH)'
Carl-Daniel Hailfinger4cb7a962009-06-16 09:31:51 +0000559
Stefan Tauner56787082011-08-18 02:27:19 +0000560define LIBPCI_TEST
561/* Avoid a failing test due to libpci header symbol shadowing breakage */
562#define index shadow_workaround_index
563#include <pci/pci.h>
564struct pci_access *pacc;
565int main(int argc, char **argv)
566{
567 (void) argc;
568 (void) argv;
569 pacc = pci_alloc();
570 return 0;
571}
572endef
573export LIBPCI_TEST
574
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +0000575ifeq ($(CHECK_LIBPCI), yes)
Carl-Daniel Hailfingerb18ecbc2009-06-19 14:20:34 +0000576pciutils: compiler
Carl-Daniel Hailfingera472b8b2009-10-03 17:08:02 +0000577 @printf "Checking for libpci headers... "
Stefan Tauner56787082011-08-18 02:27:19 +0000578 @echo "$$LIBPCI_TEST" > .test.c
Stefan Reinauer2fea3f32010-01-21 20:26:30 +0000579 @$(CC) -c $(CPPFLAGS) $(CFLAGS) .test.c -o .test.o >/dev/null 2>&1 && \
Carl-Daniel Hailfingera472b8b2009-10-03 17:08:02 +0000580 echo "found." || ( echo "not found."; echo; \
581 echo "Please install libpci headers (package pciutils-devel)."; \
582 echo "See README for more information."; echo; \
583 rm -f .test.c .test.o; exit 1)
Carl-Daniel Hailfinger9979eac2010-03-22 12:29:45 +0000584 @printf "Checking if libpci is present and sufficient... "
Carl-Daniel Hailfingera472b8b2009-10-03 17:08:02 +0000585 @printf "" > .libdeps
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000586 @$(CC) $(LDFLAGS) .test.o -o .test$(EXEC_SUFFIX) $(LIBS) >/dev/null 2>&1 && \
Carl-Daniel Hailfingera472b8b2009-10-03 17:08:02 +0000587 echo "yes." || ( echo "no."; \
Carl-Daniel Hailfinger9979eac2010-03-22 12:29:45 +0000588 printf "Checking if libz+libpci are present and sufficient..."; \
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000589 $(CC) $(LDFLAGS) .test.o -o .test$(EXEC_SUFFIX) $(LIBS) -lz >/dev/null 2>&1 && \
Carl-Daniel Hailfingera472b8b2009-10-03 17:08:02 +0000590 ( echo "yes."; echo "NEEDLIBZ := yes" > .libdeps ) || ( echo "no."; echo; \
Carl-Daniel Hailfinger9979eac2010-03-22 12:29:45 +0000591 echo "Please install libpci (package pciutils) and/or libz."; \
Carl-Daniel Hailfingera472b8b2009-10-03 17:08:02 +0000592 echo "See README for more information."; echo; \
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000593 rm -f .test.c .test.o .test$(EXEC_SUFFIX); exit 1) )
594 @rm -f .test.c .test.o .test$(EXEC_SUFFIX)
Carl-Daniel Hailfinger8a59ff02009-12-24 03:33:11 +0000595else
596pciutils: compiler
597 @printf "" > .libdeps
598endif
Stefan Reinauer53e96252005-12-01 16:19:24 +0000599
Carl-Daniel Hailfingerb18ecbc2009-06-19 14:20:34 +0000600.features: features
601
Carl-Daniel Hailfinger5d3fcb92010-06-14 18:40:59 +0000602# If a user does not explicitly request a non-working feature, we should
603# silently disable it. However, if a non-working (does not compile) feature
604# is explicitly requested, we should bail out with a descriptive error message.
605ifeq ($(UNSUPPORTED_FEATURES), )
606featuresavailable:
607else
608featuresavailable:
609 @echo "The following features are unavailable on your machine: $(UNSUPPORTED_FEATURES)"
610 @false
611endif
612
Stefan Tauner56787082011-08-18 02:27:19 +0000613define FTDI_TEST
614#include <ftdi.h>
615struct ftdi_context *ftdic = NULL;
616int main(int argc, char **argv)
617{
618 (void) argc;
619 (void) argv;
620 return ftdi_init(ftdic);
621}
622endef
623export FTDI_TEST
624
625define UTSNAME_TEST
626#include <sys/utsname.h>
627struct utsname osinfo;
628int main(int argc, char **argv)
629{
630 (void) argc;
631 (void) argv;
632 uname (&osinfo);
633 return 0;
634}
635endef
636export UTSNAME_TEST
637
Carl-Daniel Hailfingerb18ecbc2009-06-19 14:20:34 +0000638features: compiler
639 @echo "FEATURES := yes" > .features.tmp
Stefan Tauner56787082011-08-18 02:27:19 +0000640ifeq ($(CONFIG_FT2232_SPI), yes)
Paul Fox05dfbe62009-06-16 21:08:06 +0000641 @printf "Checking for FTDI support... "
Stefan Tauner56787082011-08-18 02:27:19 +0000642 @echo "$$FTDI_TEST" > .featuretest.c
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000643 @$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) .featuretest.c -o .featuretest$(EXEC_SUFFIX) $(FTDILIBS) $(LIBS) >/dev/null 2>&1 && \
Carl-Daniel Hailfingerb18ecbc2009-06-19 14:20:34 +0000644 ( echo "found."; echo "FTDISUPPORT := yes" >> .features.tmp ) || \
645 ( echo "not found."; echo "FTDISUPPORT := no" >> .features.tmp )
Carl-Daniel Hailfinger8a59ff02009-12-24 03:33:11 +0000646endif
Stefan Tauner56787082011-08-18 02:27:19 +0000647 @printf "Checking for utsname support... "
648 @echo "$$UTSNAME_TEST" > .featuretest.c
649 @$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) .featuretest.c -o .featuretest$(EXEC_SUFFIX) >/dev/null 2>&1 && \
650 ( echo "found."; echo "UTSNAME := yes" >> .features.tmp ) || \
651 ( echo "not found."; echo "UTSNAME := no" >> .features.tmp )
652 @$(DIFF) -q .features.tmp .features >/dev/null 2>&1 && rm .features.tmp || mv .features.tmp .features
653 @rm -f .featuretest.c .featuretest$(EXEC_SUFFIX)
Paul Fox05dfbe62009-06-16 21:08:06 +0000654
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000655install: $(PROGRAM)$(EXEC_SUFFIX)
Uwe Hermannc2a9c9c2009-05-14 14:51:14 +0000656 mkdir -p $(DESTDIR)$(PREFIX)/sbin
Uwe Hermann56b2cb02009-05-21 15:59:58 +0000657 mkdir -p $(DESTDIR)$(MANDIR)/man8
Carl-Daniel Hailfingerddbab712010-06-14 14:44:08 +0000658 $(INSTALL) -m 0755 $(PROGRAM)$(EXEC_SUFFIX) $(DESTDIR)$(PREFIX)/sbin
Uwe Hermann56b2cb02009-05-21 15:59:58 +0000659 $(INSTALL) -m 0644 $(PROGRAM).8 $(DESTDIR)$(MANDIR)/man8
Uwe Hermannc113b572006-12-14 00:59:41 +0000660
Carl-Daniel Hailfingera23041c2009-06-12 14:49:10 +0000661export:
Carl-Daniel Hailfinger48e5e092009-08-31 16:25:08 +0000662 @rm -rf $(EXPORTDIR)/flashrom-$(RELEASENAME)
663 @svn export -r BASE . $(EXPORTDIR)/flashrom-$(RELEASENAME)
664 @sed "s/^SVNVERSION.*/SVNVERSION := $(SVNVERSION)/" Makefile >$(EXPORTDIR)/flashrom-$(RELEASENAME)/Makefile
665 @LC_ALL=C svn log >$(EXPORTDIR)/flashrom-$(RELEASENAME)/ChangeLog
666 @echo Exported $(EXPORTDIR)/flashrom-$(RELEASENAME)/
Carl-Daniel Hailfingera23041c2009-06-12 14:49:10 +0000667
668tarball: export
Carl-Daniel Hailfinger48e5e092009-08-31 16:25:08 +0000669 @tar cjf $(EXPORTDIR)/flashrom-$(RELEASENAME).tar.bz2 -C $(EXPORTDIR)/ $(TAROPTIONS) flashrom-$(RELEASENAME)/
670 @rm -rf $(EXPORTDIR)/flashrom-$(RELEASENAME)
671 @echo Created $(EXPORTDIR)/flashrom-$(RELEASENAME).tar.bz2
Carl-Daniel Hailfingera23041c2009-06-12 14:49:10 +0000672
Carl-Daniel Hailfinger50415d22010-03-21 14:54:57 +0000673djgpp-dos: clean
674 make CC=i586-pc-msdosdjgpp-gcc STRIP=i586-pc-msdosdjgpp-strip WARNERROR=no OS_ARCH=DOS
675
Carl-Daniel Hailfinger5d3fcb92010-06-14 18:40:59 +0000676.PHONY: all clean distclean compiler pciutils features export tarball dos featuresavailable
Ollie Lho184a4042005-11-26 21:55:36 +0000677
Stefan Reinauere2f01582010-06-07 11:08:07 +0000678-include $(OBJS:.o=.d)