mspdebug/Makefile

227 lines
5.8 KiB
Makefile
Raw Normal View History

# MSPDebug - debugging tool for the eZ430
# Copyright (C) 2009-2015 Daniel Beer
# Copyright (C) 2010 Andrew Armenia
#
# 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.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
CC ?= gcc
2010-03-18 01:02:05 +00:00
INSTALL = /usr/bin/install
PREFIX ?= /usr/local
LDFLAGS ?= -s
BINDIR = ${PREFIX}/bin/
MANDIR = ${PREFIX}/share/man/man1
LIBDIR = ${PREFIX}/lib/
UNAME_S := $(shell sh -c 'uname -s')
UNAME_O := $(shell sh -c 'uname -o 2> /dev/null')
2010-03-23 02:49:33 +00:00
ifdef WITHOUT_READLINE
2010-07-12 04:36:01 +00:00
READLINE_CFLAGS =
READLINE_LIBS =
CONSOLE_INPUT_OBJ = ui/input_console.o
2010-03-23 02:49:33 +00:00
else
2010-07-12 04:36:01 +00:00
READLINE_CFLAGS = -DUSE_READLINE
READLINE_LIBS = -lreadline
CONSOLE_INPUT_OBJ = ui/input_readline.o
2010-03-23 02:49:33 +00:00
endif
2016-11-26 10:03:41 +00:00
BSLHID_OBJ ?= transport/bslhid.o
RF25000_OBJ ?= transport/rf2500.o
2016-11-26 10:03:41 +00:00
ifeq ($(OS),Windows_NT)
2016-05-13 23:47:28 +00:00
MSPDEBUG_CC = $(CC)
BINARY = mspdebug.exe
ifneq ($(UNAME_O),Cygwin)
OS_LIBS = -lws2_32 -lregex
OS_CFLAGS = -D__Windows__ -DNO_SHELLCMD
RM = del
endif
else
MSPDEBUG_CC = $(CC)
BINARY = mspdebug
ifneq ($(filter $(UNAME_S),OpenBSD NetBSD),)
2012-10-09 03:49:42 +00:00
OS_LIBS =
else ifneq ($(filter $(UNAME_S),FreeBSD DragonFly),)
2012-10-24 09:49:16 +00:00
OS_CFLAGS = -pthread
OS_LIBS = -lpthread
else ifneq ($(filter $(UNAME_S),SunOS),)
OS_LIBS = -lpthread -ldl -lresolv -lsocket -lnsl
else
OS_LIBS = -lpthread -ldl
endif
ifeq ($(UNAME_S),Darwin) # Mac OS X/MacPorts stuff
ifeq ($(shell fink -V > /dev/null 2>&1 && echo ok),ok)
PORTS_CFLAGS := $(shell pkg-config --cflags hidapi libusb)
PORTS_LDFLAGS := $(shell pkg-config --libs hidapi libusb) -ltermcap -pthread
else ifeq ($(shell brew --version > /dev/null 2>&1 && echo ok),ok)
PORTS_CFLAGS := $(shell pkg-config --cflags hidapi libusb)
PORTS_LDFLAGS := $(shell pkg-config --libs hidapi libusb) -framework IOKit -framework CoreFoundation
else
PORTS_CFLAGS := -I/opt/local/include
PORTS_LDFLAGS := -L/opt/local/lib -lhidapi -framework IOKit -framework CoreFoundation
endif
2016-11-26 10:03:41 +00:00
BSLHID_OBJ = transport/bslosx.o
RF25000_OBJ = transport/rf2500hidapi.o
LDFLAGS =
else ifneq ($(filter $(UNAME_S),OpenBSD NetBSD DragonFly),)
PORTS_CFLAGS := $(shell pkg-config --cflags libusb)
PORTS_LDFLAGS := $(shell pkg-config --libs libusb) -ltermcap -pthread
else
PORTS_CFLAGS :=
PORTS_LDFLAGS :=
endif
endif
INCLUDES = -I. -Isimio -Iformats -Itransport -Idrivers -Iutil -Iui
GCC_CFLAGS = -O1 -Wall -Wno-char-subscripts -ggdb
CONFIG_CFLAGS = -DLIB_DIR=\"$(LIBDIR)\"
MSPDEBUG_LDFLAGS = $(LDFLAGS) $(PORTS_LDFLAGS)
2016-11-26 10:03:41 +00:00
MSPDEBUG_LIBS = -L. -lusb $(READLINE_LIBS) $(OS_LIBS)
MSPDEBUG_CFLAGS = $(CFLAGS) $(READLINE_CFLAGS) $(PORTS_CFLAGS)\
$(GCC_CFLAGS) $(INCLUDES) $(CONFIG_CFLAGS) $(OS_CFLAGS)
2010-05-13 04:45:38 +00:00
all: $(BINARY)
ifeq ($(OS),Windows_NT)
clean:
ifeq ($(UNAME_O),Cygwin)
$(RM) */*.o
$(RM) $(BINARY)
else
$(RM) drivers\*.o
$(RM) formats\*.o
$(RM) simio\*.o
$(RM) transport\*.o
$(RM) ui\*.o
$(RM) util\*.o
$(RM) $(BINARY)
endif
else
clean:
$(RM) */*.o
$(RM) $(BINARY)
endif
install: $(BINARY) mspdebug.man
mkdir -p $(DESTDIR)$(BINDIR)
$(INSTALL) -m 0755 $(BINARY) $(DESTDIR)$(BINDIR)
mkdir -p $(DESTDIR)$(MANDIR)
$(INSTALL) -m 0644 mspdebug.man $(DESTDIR)$(MANDIR)/mspdebug.1
mkdir -p $(DESTDIR)$(LIBDIR)/mspdebug
$(INSTALL) -m 0644 ti_3410.fw.ihex \
$(DESTDIR)$(LIBDIR)/mspdebug/ti_3410.fw.ihex
2010-03-18 01:02:05 +00:00
.SUFFIXES: .c .o
OBJ=\
util/btree.o \
util/expr.o \
util/list.o \
util/sockets.o \
util/sport.o \
util/usbutil.o \
util/util.o \
util/vector.o \
util/output.o \
util/output_util.o \
util/opdb.o \
util/prog.o \
util/stab.o \
util/dis.o \
util/gdb_proto.o \
util/dynload.o \
util/demangle.o \
util/powerbuf.o \
util/ctrlc.o \
util/chipinfo.o \
2014-12-14 20:06:30 +00:00
util/gpio.o \
transport/cp210x.o \
transport/cdc_acm.o \
transport/ftdi.o \
transport/ti3410.o \
transport/comport.o \
2016-11-26 10:03:41 +00:00
$(BSLHID_OBJ) \
$(RF25000_OBJ) \
drivers/device.o \
drivers/bsl.o \
drivers/fet.o \
drivers/fet_core.o \
drivers/fet_proto.o \
drivers/fet_error.o \
drivers/fet_db.o \
drivers/flash_bsl.o \
drivers/gdbc.o \
drivers/sim.o \
drivers/tilib.o \
2012-07-18 00:26:55 +00:00
drivers/goodfet.o \
drivers/obl.o \
drivers/devicelist.o \
drivers/fet_olimex_db.o \
drivers/jtdev.o \
drivers/jtdev_bus_pirate.o \
drivers/jtdev_gpio.o \
drivers/jtaglib.o \
drivers/pif.o \
drivers/loadbsl.o \
drivers/loadbsl_fw.o \
drivers/hal_proto.o \
drivers/v3hil.o \
drivers/fet3.o \
drivers/bsllib.o \
2014-04-17 03:58:16 +00:00
drivers/rom_bsl.o \
drivers/tilib_api.o \
formats/binfile.o \
formats/coff.o \
formats/elf32.o \
formats/ihex.o \
formats/symmap.o \
formats/srec.o \
formats/titext.o \
simio/simio.o \
simio/simio_tracer.o \
simio/simio_timer.o \
simio/simio_wdt.o \
simio/simio_hwmult.o \
simio/simio_gpio.o \
simio/simio_console.o \
ui/gdb.o \
ui/rtools.o \
ui/sym.o \
ui/devcmd.o \
ui/flatfile.o \
ui/reader.o \
ui/cmddb.o \
ui/stdcmd.o \
ui/aliasdb.o \
ui/power.o \
ui/input.o \
2012-10-09 02:42:54 +00:00
ui/input_async.o \
$(CONSOLE_INPUT_OBJ) \
ui/main.o
$(BINARY): $(OBJ)
2011-09-18 16:04:08 +00:00
$(MSPDEBUG_CC) $(MSPDEBUG_LDFLAGS) -o $@ $^ $(MSPDEBUG_LIBS)
util/chipinfo.o: chipinfo.db
.c.o:
2011-09-18 16:04:08 +00:00
$(MSPDEBUG_CC) $(MSPDEBUG_CFLAGS) -o $@ -c $*.c