jlink: Replace crazy home cooked assertion with a real one
[openocd.git] / src / Makefile.am
blob3413ba953f5e39638df1bf235e261c94b429ea79
1 include $(top_srcdir)/common.mk
3 SUBDIRS = \
4         jtag \
5         helper \
6         target \
7         transport \
8         flash \
9         svf \
10         xsvf \
11         pld \
12         server \
13         rtos
15 noinst_LTLIBRARIES = libopenocd.la
16 bin_PROGRAMS = openocd
18 MAINFILE = main.c
20 openocd_SOURCES = $(MAINFILE)
21 openocd_LDADD = libopenocd.la
23 if INTERNAL_JIMTCL
24 openocd_LDADD += $(top_builddir)/jimtcl/libjim.a
25 else
26 openocd_LDADD += -ljim
27 endif
29 if ULINK
30 openocd_LDADD += -lm
31 endif
33 libopenocd_la_SOURCES = \
34         hello.c \
35         openocd.c \
36         startup_tcl.c
38 noinst_HEADERS = \
39         hello.h \
40         openocd.h
42 libopenocd_la_CPPFLAGS = -DPKGBLDDATE=\"`date +%F-%R`\"
44 # banner output includes RELSTR appended to $VERSION from the configure script
45 # guess-rev.sh returns either a repository version ID or "-snapshot"
46 if RELEASE
47 libopenocd_la_CPPFLAGS += -DRELSTR=\"\"
48 libopenocd_la_CPPFLAGS += -DGITVERSION=\"\"
49 else
50 libopenocd_la_CPPFLAGS += -DRELSTR=\"`$(top_srcdir)/guess-rev.sh $(top_srcdir)`\"
51 libopenocd_la_CPPFLAGS += -DGITVERSION=\"`cd $(top_srcdir) && git describe`\"
52 endif
54 # add default CPPFLAGS
55 libopenocd_la_CPPFLAGS += $(AM_CPPFLAGS) $(CPPFLAGS)
57 # the library search path.
58 libopenocd_la_LDFLAGS = $(all_libraries)
60 if IS_MINGW
61 MINGWLDADD = -lws2_32
62 else
63 MINGWLDADD =
64 endif
66 if FT2232_LIBFTDI
67 FTDI2232LIB = -lftdi -lusb
68 else
69 if PRESTO_LIBFTDI
70 FTDI2232LIB = -lftdi -lusb
71 else
72 FTDI2232LIB =
73 endif
74 endif
76 LIBUSB =
77 if USE_LIBUSB1
78 LIBUSB += $(LIBUSB1_LIBS)
79 endif
81 if USE_LIBUSB0
82 LIBUSB += $(LIBUSB0_LIBS)
83 endif
85 libopenocd_la_LIBADD = \
86         $(top_builddir)/src/xsvf/libxsvf.la \
87         $(top_builddir)/src/svf/libsvf.la \
88         $(top_builddir)/src/pld/libpld.la \
89         $(top_builddir)/src/jtag/libjtag.la \
90         $(top_builddir)/src/transport/libtransport.la \
91         $(top_builddir)/src/flash/libflash.la \
92         $(top_builddir)/src/target/libtarget.la \
93         $(top_builddir)/src/server/libserver.la \
94         $(top_builddir)/src/rtos/librtos.la \
95         $(top_builddir)/src/helper/libhelper.la \
96         $(FTDI2232LIB) $(MINGWLDADD) $(LIBUSB)
98 STARTUP_TCL_SRCS = \
99         $(srcdir)/helper/startup.tcl \
100         $(srcdir)/jtag/startup.tcl \
101         $(srcdir)/target/startup.tcl \
102         $(srcdir)/flash/startup.tcl \
103         $(srcdir)/server/startup.tcl
105 EXTRA_DIST = $(STARTUP_TCL_SRCS)
107 BUILT_SOURCES = startup.tcl
109 startup.tcl: $(STARTUP_TCL_SRCS)
110         cat $^ > $@
112 BIN2C = $(top_builddir)/src/helper/bin2char$(EXEEXT_FOR_BUILD)
114 # Convert .tcl to cfile
115 startup_tcl.c: startup.tcl $(BIN2C)
116         $(BIN2C) openocd_startup_tcl < $< > $@ || rm -f $@
118 # add startup_tcl.c to make clean list
119 CLEANFILES = startup.tcl startup_tcl.c
121 # we do not want generated file in the dist
122 dist-hook:
123         rm -f $(distdir)/startup_tcl.c
124         
125 MAINTAINERCLEANFILES = $(srcdir)/Makefile.in
127 # The "quick" target builds executables & reinstalls the executables
128 # Primary use: developer types to quicken the edit/compile/debug
129 # cycle.  by not requiring a "full build and full install". Note the
130 # assumption is: You are only rebuilding the EXE.... and everything
131 # else is/was previously installed.
133 # use at your own risk
134 quick: all install-binPROGRAMS