153 lines
5.2 KiB
Makefile
153 lines
5.2 KiB
Makefile
#########################################################################
|
|
# Copyright (C) 2001-2021 The Bochs Project
|
|
#
|
|
# This library is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
# License as published by the Free Software Foundation; either
|
|
# version 2 of the License, or (at your option) any later version.
|
|
#
|
|
# This library 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
|
|
# Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with this library; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
#########################################################################
|
|
|
|
@SUFFIX_LINE@
|
|
|
|
srcdir = @srcdir@
|
|
VPATH = @srcdir@
|
|
top_builddir = ..
|
|
top_srcdir = @top_srcdir@
|
|
|
|
SHELL = @SHELL@
|
|
|
|
@SET_MAKE@
|
|
|
|
CC = @CC@
|
|
CFLAGS = @CFLAGS@ @GUI_CFLAGS@
|
|
CXX = @CXX@
|
|
CXXFLAGS = @CXXFLAGS@ @GUI_CXXFLAGS@
|
|
|
|
LDFLAGS = @LDFLAGS@
|
|
LIBS = @LIBS@
|
|
RANLIB = @RANLIB@
|
|
|
|
# Definitely use flex. Use flex version >= 2.5.4
|
|
# Flex version 2.5.2 was reported not to work
|
|
LEX = flex
|
|
YACC = yacc
|
|
|
|
|
|
# ===========================================================
|
|
# end of configurable options
|
|
# ===========================================================
|
|
|
|
|
|
BX_OBJS = \
|
|
dbg_main.o \
|
|
dbg_breakpoints.o \
|
|
symbols.o \
|
|
linux.o \
|
|
|
|
BX_PARSER_OBJS = \
|
|
parser.o \
|
|
lexer.o
|
|
|
|
BX_INCLUDES = debug.h
|
|
|
|
BX_INCDIRS = -I.. -I$(srcdir)/.. -I../@INSTRUMENT_DIR@ -I$(srcdir)/../@INSTRUMENT_DIR@ -I. -I$(srcdir)/.
|
|
|
|
all: libdebug.a
|
|
|
|
.@CPP_SUFFIX@.o:
|
|
$(CXX) @DASH@c $(BX_INCDIRS) $(CXXFLAGS) @CXXFP@$< @OFP@$@
|
|
|
|
|
|
.c.o:
|
|
$(CC) @DASH@c $(BX_INCDIRS) $(CFLAGS) @CFP@$< @OFP@$@
|
|
|
|
|
|
|
|
libdebug.a: $(BX_OBJS) $(BX_PARSER_OBJS)
|
|
@RMCOMMAND@ libdebug.a
|
|
@MAKELIB@ $(BX_OBJS) $(BX_PARSER_OBJS)
|
|
$(RANLIB) libdebug.a
|
|
|
|
$(BX_OBJS): $(BX_INCLUDES)
|
|
|
|
|
|
clean:
|
|
@RMCOMMAND@ *.o
|
|
@RMCOMMAND@ libdebug.a
|
|
|
|
dist-clean: clean
|
|
@RMCOMMAND@ Makefile
|
|
|
|
parse-clean:
|
|
@RMCOMMAND@ -f lexer.c
|
|
@RMCOMMAND@ -f parser.cc
|
|
@RMCOMMAND@ -f parser.h
|
|
|
|
dbg_main.o: debug.h
|
|
|
|
@NO_FLEX_YACC@parser.cc: parser.y
|
|
@NO_FLEX_YACC@ @/bin/rm -f y.tab.c parser.cc
|
|
@NO_FLEX_YACC@ @/bin/rm -f y.tab.h parser.h
|
|
@NO_FLEX_YACC@ $(YACC) -p bx -d $<
|
|
@NO_FLEX_YACC@ @/bin/mv -f y.tab.c parser.cc
|
|
@NO_FLEX_YACC@ @/bin/mv -f y.tab.h parser.h
|
|
@NO_FLEX_YACC@ @sed -i s/extern\ YYSTYPE/extern\ \"C\"\ YYSTYPE/ parser.cc
|
|
@NO_FLEX_YACC@ @echo '#endif /* if BX_DEBUGGER */' >> parser.cc
|
|
@NO_FLEX_YACC@ @echo '/* The #endif is appended by the makefile after running yacc. */' >> parser.cc
|
|
|
|
@NO_FLEX_YACC@lexer.c: lexer.l
|
|
@NO_FLEX_YACC@ $(LEX) -Pbx -t $< > lexer.c
|
|
|
|
###########################################
|
|
# dependencies generated by
|
|
# gcc -MM -I. -I.. -I../instrument/stubs *.c *.cc | sed 's/\.cc/.@CPP_SUFFIX@/g'
|
|
###########################################
|
|
lexer.o: lexer.c debug.h ../config.h ../osdep.h ../cpu/decoder/decoder.h \
|
|
parser.h
|
|
parser.o: parser.cc debug.h ../config.h ../osdep.h \
|
|
../cpu/decoder/decoder.h
|
|
dbg_breakpoints.o: dbg_breakpoints.@CPP_SUFFIX@ ../bochs.h ../config.h ../osdep.h \
|
|
../bx_debug/debug.h ../config.h ../osdep.h ../cpu/decoder/decoder.h \
|
|
../gui/paramtree.h ../logio.h \
|
|
../instrument/stubs/instrument.h
|
|
dbg_main.o: dbg_main.@CPP_SUFFIX@ ../bochs.h ../config.h ../osdep.h \
|
|
../bx_debug/debug.h ../config.h ../osdep.h ../cpu/decoder/decoder.h \
|
|
../gui/paramtree.h ../logio.h \
|
|
../instrument/stubs/instrument.h ../param_names.h ../cpu/cpu.h \
|
|
../cpu/decoder/decoder.h ../cpu/i387.h ../cpu/fpu/softfloat.h \
|
|
../cpu/fpu/tag_w.h ../cpu/fpu/status_w.h ../cpu/fpu/control_w.h \
|
|
../cpu/crregs.h ../cpu/descriptor.h ../cpu/decoder/instr.h \
|
|
../cpu/lazy_flags.h ../cpu/tlb.h ../cpu/icache.h ../cpu/apic.h \
|
|
../cpu/xmm.h ../cpu/vmx.h ../cpu/svm.h ../cpu/cpuid.h ../cpu/access.h \
|
|
../cpu/decoder/ia_opcodes.h ../cpu/decoder/ia_opcodes.def \
|
|
../iodev/iodev.h ../plugin.h ../extplugin.h ../pc_system.h \
|
|
../memory/memory-bochs.h ../gui/siminterface.h ../gui/paramtree.h \
|
|
../gui/gui.h
|
|
linux.o: linux.@CPP_SUFFIX@ ../bochs.h ../config.h ../osdep.h ../bx_debug/debug.h \
|
|
../config.h ../osdep.h ../cpu/decoder/decoder.h ../gui/paramtree.h \
|
|
../logio.h ../instrument/stubs/instrument.h ../cpu/cpu.h \
|
|
../cpu/decoder/decoder.h ../cpu/i387.h ../cpu/fpu/softfloat.h \
|
|
../cpu/fpu/tag_w.h ../cpu/fpu/status_w.h ../cpu/fpu/control_w.h \
|
|
../cpu/crregs.h ../cpu/descriptor.h ../cpu/decoder/instr.h \
|
|
../cpu/lazy_flags.h ../cpu/tlb.h ../cpu/icache.h ../cpu/apic.h \
|
|
../cpu/xmm.h ../cpu/vmx.h ../cpu/svm.h ../cpu/cpuid.h ../cpu/access.h \
|
|
syscalls-linux.h
|
|
symbols.o: symbols.@CPP_SUFFIX@ ../bochs.h ../config.h ../osdep.h \
|
|
../bx_debug/debug.h ../config.h ../osdep.h ../cpu/decoder/decoder.h \
|
|
../gui/paramtree.h ../logio.h \
|
|
../instrument/stubs/instrument.h ../cpu/cpu.h ../cpu/decoder/decoder.h \
|
|
../cpu/i387.h ../cpu/fpu/softfloat.h ../cpu/fpu/tag_w.h \
|
|
../cpu/fpu/status_w.h ../cpu/fpu/control_w.h ../cpu/crregs.h \
|
|
../cpu/descriptor.h ../cpu/decoder/instr.h ../cpu/lazy_flags.h \
|
|
../cpu/tlb.h ../cpu/icache.h ../cpu/apic.h ../cpu/xmm.h ../cpu/vmx.h \
|
|
../cpu/svm.h ../cpu/cpuid.h ../cpu/access.h
|