summaryrefslogtreecommitdiff
path: root/Makefile.in
diff options
context:
space:
mode:
authorThomas Bushnell <thomas@gnu.org>1997-03-24 21:53:03 +0000
committerThomas Bushnell <thomas@gnu.org>1997-03-24 21:53:03 +0000
commit30b32d2ccbf95436b642e6208d6829dcf68981fa (patch)
tree481af37a46b22473db7cadf280a6b5466136d726 /Makefile.in
parent455c9e455d124e3359d8f9e16ffe111178589e6f (diff)
prerelease work
Diffstat (limited to 'Makefile.in')
-rw-r--r--Makefile.in513
1 files changed, 513 insertions, 0 deletions
diff --git a/Makefile.in b/Makefile.in
new file mode 100644
index 0000000..8ecc22c
--- /dev/null
+++ b/Makefile.in
@@ -0,0 +1,513 @@
+# Makefile for Mach 4 kernel directory
+# Copyright 1996 Free Software Foundation, Inc.
+# This file is part of GNU Mach. Redistribution terms are not yet decided.
+
+
+
+# Variables from `configure'.
+srcdir=@srcdir@
+systype=@systype@
+prefix=@prefix@
+
+installed-clib=$(prefix)/lib/libcrt.a
+exec_prefix=$(prefix)
+
+bootdir=$(exec_prefix)/boot
+includedir=$(prefix)/include
+libexecdir=$(exec_prefix)/libexec
+bindir=$(exec_prefix)/bin
+
+sysdep = $(srcdir)/$(systype)
+
+cross_compiling=@cross_compiling@
+
+# Programs found by configure.
+AWK=@AWK@
+INSTALL=@INSTALL@
+CC=@CC@
+BUILD_CC=@BUILD_CC@
+LEX=@LEX@
+YACC=@YACC@
+
+LEXLIB=@LEXLIB@
+
+INSTALL_PROGRAM=$(INSTALL)
+INSTALL_DATA=$(INSTALL) -m 644
+
+CFLAGS=@CFLAGS@
+
+# We build these locally
+MIG=./mig
+MIGCOM=./migcom
+
+all:
+
+# All the possible architectures
+all-archs = i386
+
+all-archs-subdirs = $(patsubst %,$(srcdir)/%/Subdirs,$(all-archs))
+all-archs-files = $(patsubst %,$(srcdir)/%/Files,$(all-archs))
+
+# Files distributed from the top level directory:
+topfiles = ChangeLog ChangeLog.0 ChangeLog.00 Drivers.macros Makefile.in \
+ README INSTALL config.guess config.sub configure configure.in \
+ gensym.awk install-sh version.c
+
+# All the source in each directory.
+
+# Old crud from a previous configure scheme
+bogus-files = bootstrap_symbols.h fast_tas.h hw_footprint.h net_atm.h \
+ power_save.h simple_clock.h stat_time.h xpr_debug.h \
+ $(patsubst %,mach_%.h,assert counters debug fixpri host ipc_compat \
+ ipc_debug ipc_test kdb ldebug lock_mon machine_routines mp_debug \
+ pagemap pcsample ttd vm_debug) \
+ $(patsubst %,norma_%.h,device ether ipc task vm)
+
+# Generic code for various hardware drivers
+chips-files = atm.c audio.c bt431.c bt455.c bt459.c build_font.c busses.c \
+ cfb_hdw.c cfb_misc.c dc503.c dtop_handlers.c dtop_hdw.c dz_hdw.c \
+ fb_hdw.c fb_misc.c fdc_82077_hdw.c frc.c ims332.c isdn_79c30_hdw.c \
+ kernel_font.c lance.c lance_mapped.c lk201.c mc_clock.c mouse.c \
+ nc.c nw_mk.c pm_hdw.c pm_misc.c scc_8530_hdw.c screen.c \
+ screen_switch.c serial_console.c sfb_hdw.c sfb_misc.c spans.c \
+ tca100.c tca100_if.c xcfb_hdw.c xcfb_misc.c \
+ atmreg.h audio_config.h audio_defs.h bt431.h bt455.h bt459.h \
+ bt478.h busses.h dc503.h dtop.h dz_7085.h dz_defs.h eccreg.h \
+ fdc_82077.h ims332.h isdn_79c30.h lance.h lk201.h mc_clock.h \
+ nc.h nw.h nw_mk.h pm_defs.h scc_8530.h screen.h screen_defs.h \
+ screen_switch.h serial_defs.h spans.h tca100.h tca100_if.h \
+ vs42x_rb.h xcfb_monitor.h
+
+# Generic code for various SCSI unit types
+scsi-files = disk_label.c mapped_scsi.c pc_scsi_label.c rz.c rz_audio.c \
+ rz_cpu.c rz_disk.c rz_disk_bbr.c rz_host.c rz_tape.c scsi.c \
+ scsi_alldevs.c scsi_comm.c scsi_cpu.c scsi_disk.c scsi_jukebox.c \
+ scsi_optical.c scsi_printer.c scsi_rom.c scsi_scanner.c \
+ scsi_tape.c scsi_worm.c \
+ compat_30.h mapped_scsi.h rz.h rz_labels.h scsi.h scsi2.h \
+ scsi_defs.h scsi_endian.h
+
+# Icky kernel debugger
+ddb-cfiles = $(addprefix db_,$(ddb-names))
+ddb-names = access.c aout.c break.c command.c cond.c examine.c expr.c \
+ ext_symtab.c input.c lex.c macro.c mp.c output.c print.c run.c \
+ sym.c task_thread.c trap.c variables.c watch.c write_cmd.c
+ddb-files = $(ddb-cfiles) $(patsubst %,db_%.h, \
+ access break command expr lex output print run sym task_thread \
+ variables watch) nlist.h stab.h tr.h
+
+# Device support interfaces
+device-files = blkio.c chario.c cirbuf.c cons.c dev_lookup.c dev_name.c \
+ dev_pager.c device_init.c dk_label.c ds_routines.c net_io.c subrs.c \
+ buf.h cirbuf.h conf.h cons.h dev_hdr.h dev_master.h device_port.h \
+ device_types_kernel.h ds_routines.h errno.h if_ether.h if_hdr.h \
+ io_req.h net_io.h param.h tty.h memory_object_reply.cli \
+ dev_forward.defs device_pager.srv device_reply.cli
+
+# IPC implementation
+ipc-cfiles = $(addprefix ipc_,$(ipc-names)) \
+ mach_msg.c mach_port.c mach_rpc.c mach_debug.c fipc.c
+ipc-names = entry.c hash.c init.c kmsg.c marequest.c mqueue.c \
+ notify.c object.c port.c pset.c right.c space.c splay.c \
+ table.c target.c thread.c
+ipc-files = $(ipc-cfiles) mach_port.srv fipc.h port.h mach_msg.h \
+ $(patsubst %,ipc_%.h, \
+ entry hash init kmsg kmsg_queue machdep marequest mqueue notify \
+ object port pset right space splay table target thread types)
+
+# "kernel" implementation (tasks, threads, trivia, etc.)
+kern-cfiles = act.c ast.c bootstrap.c counters.c debug.c eventcount.c \
+ exception.c host.c ipc_host.c ipc_kobject.c ipc_mig.c ipc_sched.c \
+ ipc_tt.c kalloc.c lock.c lock_mon.c mach_clock.c mach_factor.c \
+ machine.c pc_sample.c printf.c priority.c processor.c profile.c \
+ queue.c sched_prim.c startup.c strings.c syscall_emulation.c \
+ syscall_subr.c syscall_sw.c task.c thread.c thread_swap.c \
+ time_stamp.c timer.c xpr.c zalloc.c elf-load.c
+kern-files = $(kern-cfiles) \
+ act.h assert.h ast.h compat_xxx_defs.h counters.h cpu_number.h \
+ debug.h eventcount.h host.h ipc_host.h ipc_kobject.h ipc_sched.h \
+ ipc_tt.h kalloc.h kern_types.h lock.h mach_param.h macro_help.h \
+ pc_sample.h processor.h queue.h refcount.h sched.h sched_prim.h \
+ shuttle.h strings.h syscall_emulation.h syscall_subr.h syscall_sw.h \
+ task.h thread.h thread_swap.h time_out.h time_stamp.h timer.h xpr.h \
+ zalloc.h \
+ mach.srv mach4.srv mach_debug.srv mach_host.srv
+
+# Still more trivia
+util-cfiles = about_to_die.c cpu.c cpu_init.c die.c putchar.c puts.c
+util-files = $(util-cfiles) config.h cpu.h cpu_subs.h cpus.h debug.h \
+ phys_mem.h ref_count.h
+
+# Virtual memory implementation
+vm-cfiles = $(addprefix vm_,$(vm-names)) memory_object.c
+vm-names = debug.c external.c fault.c init.c kern.c map.c \
+ object.c pageout.c resident.c user.c
+vm-files = $(vm-cfiles) memory_object_default.cli memory_object_user.cli \
+ memory_object.h pmap.h $(patsubst %,vm_%.h, \
+ external fault kern map object page pageout user)
+
+
+
+# Object files that go into the kernel image. (This will be augmented by the
+# machine dependent Makefile fragment.)
+
+# Basic kernel source for Mach
+objfiles := $(subst .c,.o,$(ipc-cfiles) $(kern-cfiles) \
+ $(util-cfiles) $(vm-cfiles))
+vpath %.c $(srcdir)/ipc $(srcdir)/kern $(srcdir)/util $(srcdir)/vm
+
+# These device support files are always needed; the others are needed only
+# if particular drivers want the routines.
+# XXX functions in device/subrs.c should each be moved elsewhere
+objfiles += cons.o dev_lookup.o dev_name.o dev_pager.o device_init.o \
+ ds_routines.o subrs.o net_io.o blkio.o chario.o
+vpath %.c $(srcdir)/device
+
+# DDB support -- eventually to die. Please.
+objfiles += $(subst .c,.o,$(ddb-cfiles))
+vpath %.c $(srcdir)/ddb
+
+# Version number
+objfiles += version.o
+vpath version.c $(srcdir)
+
+
+# Header files installed for user use
+device-headers= $(addprefix device/,audio_status.h bpf.h device.defs \
+ device_reply.defs device_request.defs device_types.defs \
+ device_types.h disk_status.h net_status.h tape_status.h \
+ tty_status.h)
+mach-headers= $(addprefix mach/, bootstrap.defs default_pager.defs \
+ default_pager_helper.defs default_pager_types.defs \
+ exc.defs mach.defs mach4.defs mach_host.defs mach_norma.defs \
+ mach_port.defs mach_types.defs memory_object.defs \
+ memory_object_default.defs norma_task.defs notify.defs \
+ std_types.defs \
+ alert.h boolean.h boot.h default_pager_types.h exception.h \
+ host_info.h kern_return.h mach_param.h mach_types.h \
+ machine.h macro_help.h memory_object.h message.h mig_errors.h \
+ msg_type.h multiboot.h norma_special_ports.h notify.h \
+ pc_sample.h policy.h port.h proc_ops.h processor_info.h \
+ profil.h profilparam.h rpc.h std_types.h syscall_sw.h \
+ task_info.h task_special_ports.h thread_info.h \
+ thread_special_ports.h thread_status.h thread_switch.h \
+ time_value.h version.h vm_attributes.h vm_inherit.h \
+ vm_param.h vm_prot.h vm_statistics.h)
+
+mach-debug-headers:= $(addprefix mach_debug/, hash_info.h ipc_info.h \
+ mach_debug.defs mach_debug_types.defs mach_debug_types.h \
+ pc_info.h vm_info.h zone_info.h)
+
+installed-headers:= $(device-headers) $(mach-headers)
+
+
+
+# We steal routines from the C library and put them here.
+# If we link against the C library directly, then we have to hope that we have
+# correctly found all the dependencies that might bring in C library code.
+# This method is much safer because it's easy to check this one object file
+# for sanity.
+objfiles += clib-routines.o
+
+clib-routines = memcpy memset bcopy bzero htonl ntohl ntohs
+
+clib-routines.o: $(installed-clib)
+ $(LD) -o clib-routines.o -r $(addprefix -u ,$(clib-routines)) $(installed-clib)
+
+# This rule checks clib-routines and makes sure it doesn't have any
+# extra symbols.
+kernel: check-clib-routines
+check-clib-routines: clib-routines.o
+ (set -e; test `echo $(clib-routines) | wc -w` -eq `nm $< | wc -l`; \
+ touch check-clib-routines)
+
+
+# Empty dependency file
+clib-routines.d:; touch $@
+
+
+
+# Automatically generated source
+
+# User stubs
+objfiles += memory_object_user_user.o memory_object_default_user.o \
+ device_reply_user.o memory_object_reply_user.o
+
+# Server stubs
+objfiles += device_server.o device_pager_server.o mach_port_server.o \
+ mach_server.o mach4_server.o mach_debug_server.o mach_host_server.o
+
+# Where to find the relevant Mig source files
+vpath %.cli $(srcdir)/vm $(srcdir)/device
+vpath %.srv $(srcdir)/device $(srcdir)/ipc $(srcdir)/kern
+
+
+
+
+#
+# Compilation flags
+#
+
+DEFINES += -DMACH -DCMU -DMACH_KERNEL -DKERNEL
+INCLUDES += -I. -I$(srcdir) -I$(srcdir)/include -I$(srcdir)/include/mach/sa \
+ -I$(srcdir)/bogus -I$(srcdir)/util -I$(srcdir)/kern -I$(srcdir)/device
+
+
+include $(sysdep)/Makefrag
+
+CPPFLAGS += -nostdinc $(DEFINES) $(INCLUDES)
+
+MIGFLAGS += $(CPPFLAGS)
+
+
+all: kernel cross-migcom
+
+
+#
+# Kernel Image
+#
+# (The newline in this command makes it much easier to read in make output.)
+kernel: $(objfiles)
+ $(LD) -o $@ $(LDFLAGS) \
+ $(objfiles)
+
+
+
+#
+# Installation
+#
+installed-headers-names = $(addprefix $(includedir)/,$(installed-headers))
+installed-sysdep-headers-names = $(addprefix $(includedir)/,$($(systype)-installed-headers))
+install: mkinstalldirs kernel $(installed-headers-names) $(installed-sysdep-headers-names) cross-mig cross-migcom
+ $(INSTALL_PROGRAM) kernel $(bootdir)/gnumach
+ $(INSTALL_PROGRAM) cross-mig $(bindir)/mig
+ $(INSTALL_PROGRAM) cross-migcom $(libexecdir)/mig
+ -ln -s $(systype) $(includedir)/mach/machine
+
+$(installed-headers-names): $(includedir)/%: $(srcdir)/include/%
+ $(INSTALL_DATA) $< $@
+
+$(installed-sysdep-headers-names): $(includedir)/%: $(sysdep)/include/%
+ $(INSTALL_DATA) $< $@
+
+mkinstalldirs:
+ mkdir -p $(bootdir) $(includedir) $(includedir)/device \
+ $(includedir)/mach $(includedir)/mach/$(systype)
+
+
+#
+# Building the distribution
+#
+
+dist:
+ rm -rf gnumach-$(version)
+ mkdir gnumach-$(version)
+ # Directories
+ mkdir gnumach-$(version)/{bogus,chips,ddb,device,ipc,kern,mig,scsi,util,vm,include}
+ mkdir gnumach-$(version)/include/{mach,device,mach_debug}
+ for dir in `cat $(all-archs-subdirs)`; do \
+ mkdir -p gnumach-$(version)/$$dir; \
+ done
+ # Files
+ ln $(addprefix $(srcdir)/,$(topfiles)) gnumach-$(version)
+ ln $(addprefix $(srcdir)/bogus/,$(bogus-files)) gnumach-$(version)/bogus
+ ln $(addprefix $(srcdir)/chips/,$(chips-files)) gnumach-$(version)/chips
+ ln $(addprefix $(srcdir)/ddb/,$(ddb-files)) gnumach-$(version)/ddb
+ ln $(addprefix $(srcdir)/device/,$(device-files)) gnumach-$(version)/device
+ ln $(addprefix $(srcdir)/ipc/,$(ipc-files)) gnumach-$(version)/ipc
+ ln $(addprefix $(srcdir)/kern/,$(kern-files)) gnumach-$(version)/kern
+ ln $(addprefix $(srcdir)/mig/,$(mig-files)) gnumach-$(version)/mig
+ ln $(addprefix $(srcdir)/scsi/,$(scsi-files)) gnumach-$(version)/scsi
+ ln $(addprefix $(srcdir)/util/,$(util-files)) gnumach-$(version)/util
+ ln $(addprefix $(srcdir)/vm/,$(vm-files)) gnumach-$(version)/vm
+ ln $(addprefix $(srcdir)/include/,$(mach-headers)) gnumach-$(version)/include/mach
+ ln $(addprefix $(srcdir)/include/,$(device-headers)) gnumach-$(version)/include/device
+ ln $(addprefix $(srcdir)/include/,$(mach-debug-headers)) gnumach-$(version)/include/mach_debug
+ # Files in arch dirs
+ for file in `cat $(all-archs-files)`; do \
+ ln $(srcdir)/$$file gnumach-$(version)/`dirname $$file`; \
+ done
+ for arch in $(all-archs); do \
+ ln -s $$arch gnumach-$(version)/arch/include/mach/machine; \
+ done
+
+
+
+#
+# Autoconf support
+#
+$(srcdir)/configure: configure.in
+ cd $(srcdir) && autoconf
+
+Makefile: Makefile.in config.status
+ ./config.status
+
+config.status: configure
+ ./config.status --recheck
+
+vpath %.in $(srcdir)
+vpath configure $(srcdir)
+
+
+
+#
+# How to do some things
+#
+
+# Building foo.h from foo.sym:
+%.symc: %.sym
+ $(AWK) -f $(srcdir)/gensym.awk $< >$*.symc
+%.symc.o: %.symc
+ $(CC) -S $(CPPFLAGS) $(CFLAGS) $(CPPFLAGS-$@) -x c -o $@ $<
+%.h: %.symc.o
+ sed <$< -e 's/^[^*].*$$//' | \
+ sed -e 's/^[*]/#define/' -e 's/mAgIc[^-0-9]*//' >$@
+
+# Building from foo.cli
+%.h %_user.c: %.cli $(MIG) $(MIGCOM)
+ $(MIG) $(MIGFLAGS) -header $*.h -user $*_user.c -server /dev/null $<
+
+# Building from foo.srv
+%_interface.h %_server.c: %.srv $(MIG) $(MIGCOM)
+ $(MIG) $(MIGFLAGS) -header $*_interface.h -server $*_server.c -user /dev/null $<
+
+#
+# Dependency generation
+#
+
+# Include dependency files
+ifneq ($(no_deps),t)
+
+# For each file generated by MiG we need a .d file.
+servers = $(filter %_server.o,$(objfiles))
+include $(subst _server.o,.migs_d,$(servers)) /dev/null
+include $(subst _server.o,.migsh_d,$(servers)) /dev/null
+
+# vm_user.o fits the pattern, but is not actually a MiG-related file.
+users = $(filter-out vm_user.o,$(filter %_user.o,$(objfiles)))
+include $(subst _user.o,.migu_d,$(users)) /dev/null
+include $(subst _user.o,.miguh_d,$(users)) /dev/null
+
+# For each .o file we need a .d file.
+include $(subst .o,.d,$(filter %.o,$(objfiles))) /dev/null
+
+endif
+
+# Here is how to make those dependency files
+
+%.migs_d: %.srv
+ (set -e; $(CPP) $(MIGFLAGS) -M -MG -x c $< | \
+ sed -e 's/\.srv\.o:/_server.c $@:/' > $@)
+
+%.migu_d: %.cli
+ (set -e; $(CPP) $(MIGFLAGS) -M -MG -x c $< | \
+ sed -e 's/\.cli\.o:/_user.c $@:/' > $@)
+
+%.migsh_d: %.migs_d
+ sed -e 's/_server\.c /_interface.h /' -e 's/migs_d/migsh_d/' < $< > $@
+
+%.miguh_d: %.migu_d
+ sed -e 's/_user\.c /.h /' -e 's/migu_d/miguh_d/' < $< > $@
+
+# Generic rule for $(CC) based compilation for making dependencies
+define make-deps
+set -e; $(CC) $(CFLAGS) $(CPPFLAGS) -M -MG $< | \
+ sed > $@.new -e 's/$*\.o:/$*.o $@:/'
+mv -f $@.new $@
+endef
+
+%.d: %.c; $(make-deps)
+%.d: %.S; $(make-deps)
+
+# .s files don't go through the preprocessor, so we do this
+# This rule must come *after* the genuine ones above, so that
+# make doesn't build a .s file and then make an empty dependency
+# list.
+%.d: %.s
+ echo '$*.o: $<' > $@
+
+
+# How to build MiG:
+
+mig-objfiles = error.o global.o header.o lexxer.o migcom.o parser.o routine.o \
+ server.o statement.o string.o type.o user.o utils.o
+mig-csrcfiles = $(subst .o,.c,$(mig-objfiles))
+mig-othersrc = alloc.h boolean.h error.h global.h lexxer.h message.h \
+ mig_string.h routine.h statement.h type.h utils.h write.h \
+ lexxer.l parser.y mig.sh parser.h cpu.sym
+
+mig-files = $(mig-csrcfiles) $(mig-othersrc) ChangeLog
+
+vpath cpu.sym $(srcdir)/mig
+
+# Don't use $(CPPFLAGS) here; MiG needs none of the Mach headers except
+# what happens automagically to build cpu.h.
+
+# Here's how to build MiG for the target.
+cross-mig-objfiles = $(addprefix cross-,$(mig-objfiles))
+
+$(cross-mig-objfiles): cross-%.o: $(srcdir)/mig/%.c
+ $(CC) -c $(CFLAGS) -I. -I$(srcdir)/mig -o $@ $<
+
+./cross-migcom: $(cross-mig-objfiles)
+ $(CC) $(CFLAGS) $(cross-mig-objfiles) $(LEXLIB) -o $@
+
+# Dependencies for these .o files
+ifneq ($(no_deps),t)
+include $(subst .o,.d,$(cross-mig-objfiles)) /dev/null
+endif
+
+$(subst .o,.d,$(cross-mig-objfiles)): cross-%.d: $(srcdir)/mig/%.c
+ set -e; $(CC) $(CFLAGS) -M -MG $< | \
+ sed > $@.new -e 's/$*\.o:/$*.o $@:/'
+ mv -f $@.new $@
+
+
+ifeq ($(cross_compiling),yes)
+# When cross compiling, we build two migcoms; one for our use and one to
+# install. Otherwise, we just build the one.
+
+$(mig-objfiles): %.o: $(srcdir)/mig/%.c
+ $(BUILD_CC) -c $(BUILD_CFLAGS) -I. -I$(srcdir)/mig -o $@ $<
+
+./migcom: $(mig-objfiles)
+ $(BUILD_CC) $(BUILD_CFLAGS) $(mig-objfiles) $(LEXLIB) -o $@
+
+ifneq ($(no_deps),t)
+include $(subst .o,.d,$(mig-objfiles))
+endif
+
+$(subst .o,.d,$(mig-objfiles)): %.d: $(srcdir)/mig/%.c
+ set -e; $(BUILD_CC) $(BUILD_CFLAGS) -M -MG $< | \
+ sed > $@.new -e 's/$*\.o:/$*.o $@:/'
+ mv -f $@.new $@
+
+else
+./migcom: ./cross-migcom
+ rm -f $@
+ $(LN) $< $@
+endif
+
+$(srcdir)/mig/lexxer.c: $(srcdir)/mig/lexxer.l
+ $(LEX) $(LFLAGS) $<
+ mv lex.yy.c $*.c
+
+$(srcdir)/mig/parser.c $(srcdir)/mig/parser.h: $(srcdir)/mig/parser.y
+ $(YACC) $(YFLAGS) -d $<
+ mv y.tab.c $(srcdir)/mig/parser.c
+ mv y.tab.h $(srcdir)/mig/parser.h
+
+# Version of mig script that looks for the right local tools
+ifeq ($(cross_compiling),yes)
+./mig: $(srcdir)/mig/mig.sh Makefile
+ sed -e 's,@MIGDIR@,.,g' \
+ -e 's,@CPP@,${BUILD_CC} -x c-header -E,g' \
+ $< >$@.tmp && chmod +x $@.tmp && mv -f $@.tmp $@
+else
+./mig: $(srcdir)/mig/mig.sh Makefile
+ sed -e 's,@MIGDIR@,.,g' \
+ -e 's,@CPP@,${CC} -x c-header -E,g' \
+ $< >$@.tmp && chmod +x $@.tmp && mv -f $@.tmp $@
+endif
+
+