Bochs/bochs/debug/Makefile.in
Bryce Denney e61d00351f - merged BRANCH-smp-bochs into main branch. For details see comments
in BRANCH-smp-bochs revisions.
- The general task was to make multiple CPU's which communicate
  through their APICs.  So instead of BX_CPU and BX_MEM, we now have
  BX_CPU(x) and BX_MEM(y).  For an SMP simulation you have several
  processors in a shared memory space, so there might be processors
  BX_CPU(0..3) but only one memory space BX_MEM(0).  For cosimulation,
  you could have BX_CPU(0) with BX_MEM(0), then BX_CPU(1) with
  BX_MEM(1).  WARNING: Cosimulation is almost certainly broken by the
  SMP changes.
- to simulate multiple CPUs, you have to give each CPU time to execute
  in turn.  This is currently implemented using debugger guards.  The
  cpu loop steps one CPU for a few instructions, then steps the
  next CPU for a few instructions, etc.
- there is some limited support in the debugger for two CPUs, for
  example printing information from each CPU when single stepping.
2001-05-23 08:16:07 +00:00

105 lines
2.2 KiB
Makefile

# Copyright (C) 2001 MandrakeSoft S.A.
#
# MandrakeSoft S.A.
# 43, rue d'Aboukir
# 75002 Paris - France
# http://www.linux-mandrake.com/
# http://www.mandrakesoft.com/
#
# 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
@SUFFIX_LINE@
SHELL = /bin/sh
@SET_MAKE@
CC = @CC@
CFLAGS = @CFLAGS@
CXX = @CXX@
CXXFLAGS = @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 \
linux.o \
crc.o @BX_LOADER_OBJS@
BX_PARSER_OBJS = \
parser.o \
lexer.o
BX_INCLUDES = debug.h
BX_INCDIRS = -I.. -I../@INSTRUMENT_DIR@
.@CPP_SUFFIX@.o:
$(CXX) @DASH@c $(CXXFLAGS) $(BX_INCDIRS) @CXXFP@$< @OFP@$@
.c.o:
$(CC) @DASH@c $(CFLAGS) $(BX_INCDIRS) @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.c
@RMCOMMAND@ -f parser.h
dbg_main.o: debug.h
sim2.o: debug.h
parser.c: parser.y
@/bin/rm -f y.tab.c parser.c
@/bin/rm -f y.tab.h parser.h
$(YACC) -p bx -d parser.y
@/bin/mv -f y.tab.c parser.c
@/bin/mv -f y.tab.h parser.h
lexer.c: lexer.l
$(LEX) -Pbx -t lexer.l > lexer.c