450 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			450 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| #
 | |
| # Machine-independent kernel config definitions.
 | |
| #
 | |
| # The idea is that the files, options, and facilities in the system
 | |
| # are declared by conf.kern and the various files it includes. Then a
 | |
| # kernel config (such as ASST1, or GENERIC, or TEST, or whatever) is
 | |
| # used to select options and facilities for a particular kernel build.
 | |
| #
 | |
| # To add new files to the system, you need to edit this file (or
 | |
| # others like it) and rerun the config script.
 | |
| #
 | |
| # Note: when running the config script, be sure to be in the
 | |
| # right directory (the same one this file is in) and run it as
 | |
| # "./config", not just "config" - in the latter case you will
 | |
| # probably get the host system's kernel config utility, which
 | |
| # will likely make a mess and produce mysterious error messages.
 | |
| #
 | |
| # The documentation for the syntax of these files follows.
 | |
| #
 | |
| 
 | |
| ############################################################
 | |
| #
 | |
| # Kernel config file syntax:
 | |
| #
 | |
| # The syntax for including the system definition is:
 | |
| #
 | |
| #    include conf.kern
 | |
| #
 | |
| #       This should come first. This is because the system must be
 | |
| #       defined before you can do much else useful.
 | |
| #
 | |
| #       You can also include other files using the same syntax.
 | |
| #
 | |
| #
 | |
| # The syntax for turning on a kernel compile option is:
 | |
| #
 | |
| #    options optname
 | |
| #
 | |
| #       A previous "defoption" must have been seen first. See below
 | |
| #       for more information.
 | |
| #
 | |
| #       The act of compiling with debug info is (has to be) handled
 | |
| #       specially, and is just "debug" without the "options".
 | |
| #
 | |
| #
 | |
| # The syntax for turning on a device driver is:
 | |
| #
 | |
| #    device foo%
 | |
| #    device foo% at bar%
 | |
| #
 | |
| #       where the % is either a number or a star, which is treated as
 | |
| #       a wildcard. The first line enables a device foo that is not
 | |
| #       supposed to be "attached" to anything. The second line enables
 | |
| #       a device foo that is attached to a device bar. For more
 | |
| #       information about what this means, see below.
 | |
| #
 | |
| #
 | |
| ############################################################
 | |
| #
 | |
| # Kernel definition file syntax:
 | |
| #
 | |
| # Note: All source file names are relative to the top directory of the
 | |
| # kernel source, that is, src/kern.
 | |
| #
 | |
| # The syntax for adding a regular source file is:
 | |
| #
 | |
| #    [machine M | platform P] file sourcefile.c
 | |
| #
 | |
| #       Such a file is always included automatically in every kernel
 | |
| #       built for machine M, or platform P, or all kernels.
 | |
| #
 | |
| #
 | |
| # The syntax for defining optional source files is:
 | |
| #
 | |
| #    defoption optname
 | |
| #    [machine M | platform P] optfile optname sourcefile.c
 | |
| #    [machine M | platform P] optofffile optname sourcefile.c
 | |
| #
 | |
| #       "defoption" declares the name of a kernel option. These are
 | |
| #       then turned on by including "options optname" in a
 | |
| #       kernel config.
 | |
| #
 | |
| #       Source files added with optfile are compiled in if the option
 | |
| #       specified is enabled. Source files added with optofffile are
 | |
| #       compiled in if the option specified is not enabled.
 | |
| #
 | |
| #       Additionally, a file "opt-optname.h" is created in the compile
 | |
| #       directory, which defines a C preprocessor symbol OPT_OPTNAME.
 | |
| #       This symbol is #defined to either 0 or 1 in the logical way.
 | |
| #       Thus, you can have small bits of code that are enabled or
 | |
| #       disabled by particular options by writing constructs like
 | |
| #
 | |
| #            #include "opt-foo.h"
 | |
| #            #if OPT_FOO
 | |
| #               code();
 | |
| #            #else
 | |
| #               other_code();
 | |
| #            #endif
 | |
| #
 | |
| #       *** Be sure to use #if and not #ifdef - you want the value
 | |
| #           of the symbol.
 | |
| #       *** Be sure to remember to include the header file for the
 | |
| #           option - if you don't, cpp will silently assume it is 0,
 | |
| #           which can be quite frustrating.
 | |
| #
 | |
| #       The defoption must be seen before any optional file
 | |
| #       declarations that use it.
 | |
| #
 | |
| #
 | |
| # The syntax for defining device drivers is:
 | |
| #
 | |
| #    defdevice devname                  sourcefile.c
 | |
| #    defattach devname% otherdevname%   sourcefile.c
 | |
| #    pseudoattach devname%
 | |
| #
 | |
| #       Declare a device driver and its "attachment(s)". (The device
 | |
| #       driver can then be selectively included or not included in any
 | |
| #       particular kernel by using the "device" statement in the
 | |
| #       kernel config file.)
 | |
| #
 | |
| #       The specified source files are only compiled if the device
 | |
| #       is enabled.
 | |
| #
 | |
| #       The % is either a specific number N, meaning "only the Nth
 | |
| #       such device can be attached this way", or a star (*), meaning
 | |
| #       "any such device can be attached this way".
 | |
| #
 | |
| #       In OS/161, device drivers are conceptually organized into
 | |
| #       trees. This mimics the organization of real hardware, where
 | |
| #       several expansion cards are plugged into one bus and there
 | |
| #       might be several devices on each expansion card and so forth.
 | |
| #
 | |
| #       There can be any number of these trees. However, devices at
 | |
| #       the root of each tree must be able to probe and "find"
 | |
| #       themselves completely on their own. This generally means that
 | |
| #       they are either all software with no hardware, or they are the
 | |
| #       system main bus which is located in a machine-dependent way.
 | |
| #
 | |
| #       Software-only devices are known as "pseudo-devices". These
 | |
| #       are "attached" with the pseudoattach directive; functions
 | |
| #       of the form
 | |
| #
 | |
| #           pseudoattach_devname
 | |
| #
 | |
| #       are called from autoconf.c to create instances as requested.
 | |
| #       These calls are made from the function pseudoconfig(), which
 | |
| #       should be called from dev/init.c after hardware device
 | |
| #       initialization completes. The pseudoattach functions should
 | |
| #       perform all setup and initialization necessary. (No
 | |
| #       config_devname function will be called.)
 | |
| #
 | |
| #       Devices with attachments are automatically probed and
 | |
| #       configured from code in autoconf.c. This file is generated
 | |
| #       by the config script. It contains functions called
 | |
| #       "autoconf_devname", for each device. These functions call
 | |
| #       other functions, which are supplied by device drivers,
 | |
| #       which have the following hardwired names:
 | |
| #
 | |
| #           attach_devname1_to_devname2
 | |
| #
 | |
| #                 A "devname2" device has been found and configured;
 | |
| #                 this function attempts to probe the devname2 for
 | |
| #                 a "devname1" device. Returns NULL if nothing was
 | |
| #                 found.
 | |
| #
 | |
| #           config_devname
 | |
| #
 | |
| #                 A "devname" device has been found. This function
 | |
| #                 can then perform initialization that's shared
 | |
| #                 among all the possible things it can be attached
 | |
| #                 to.
 | |
| #
 | |
| #       The idea is that there can be multiple attachments for
 | |
| #       the same device to different underlying devices. In the
 | |
| #       real world this can be used to great effect when you have,
 | |
| #       for instance, the same ethernet chipset used on both PCI
 | |
| #       and ISA cards - the chipset behaves the same way in both
 | |
| #       cases, but the probe and attach logic is very different.
 | |
| #
 | |
| #       The attach_foo_to_bar functions are put in the files
 | |
| #       specified with defattach; the config_foo function (and
 | |
| #       generally the rest of the driver for the foo device) is
 | |
| #       put in the file specified with defdevice.
 | |
| #
 | |
| #       One selects particular attachments when including the device
 | |
| #       in the kernel. A top-level device with no attachments should
 | |
| #       be included with this syntax:
 | |
| #
 | |
| #              device bar
 | |
| #
 | |
| #       A pseudo-device should be included with this syntax:
 | |
| #
 | |
| #              device bar0
 | |
| #
 | |
| #       To make use of device foo, which can be found attached to
 | |
| #       device bar, one of the following syntaxes is used:
 | |
| #
 | |
| #              device foo* at bar*
 | |
| #              device foo* at bar0
 | |
| #              device foo0 at bar*
 | |
| #              device foo0 at bar0
 | |
| #
 | |
| #       depending on to what extent you want to configure only a
 | |
| #       specific device number.
 | |
| #
 | |
| #       It sometimes matters what order things are handled in; probes
 | |
| #       occur more or less in the order things appear in the config,
 | |
| #       as constrained by the tree structure of the available devices.
 | |
| #
 | |
| #       Note that OS/161 does not make extensive use of this
 | |
| #       functionality, and the device driver architecture outlined
 | |
| #       here is overkill for such a limited environment as System/161.
 | |
| #       However, it's similar to the way real systems are organized.
 | |
| #
 | |
| #
 | |
| # The syntax for including other config/definition files is:
 | |
| #
 | |
| #    include filename
 | |
| #
 | |
| #       The filename is relative to the top of the kernel source tree.
 | |
| #
 | |
| #       Thus,
 | |
| #          include conf/conf.foo     includes src/kern/conf/conf.foo
 | |
| #
 | |
| #
 | |
| ############################################################
 | |
| 
 | |
| 
 | |
| ########################################
 | |
| #                                      #
 | |
| # Generic machine-independent devices. #
 | |
| #                                      #
 | |
| ########################################
 | |
| 
 | |
| #
 | |
| # These are abstract system services we expect the system hardware to
 | |
| # provide: beeping, system console I/O, and time of day clock.
 | |
| #
 | |
| # These come before the archinclude so that the hardware device
 | |
| # definitions, which are included from there, can define attachments
 | |
| # for them.
 | |
| #
 | |
| 
 | |
| defdevice       beep			dev/generic/beep.c
 | |
| defdevice	con			dev/generic/console.c
 | |
| defdevice       rtclock                 dev/generic/rtclock.c
 | |
| defdevice       random                  dev/generic/random.c
 | |
| 
 | |
| ########################################
 | |
| #                                      #
 | |
| #        Machine-dependent stuff       #
 | |
| #                                      #
 | |
| ########################################
 | |
| 
 | |
| #
 | |
| # Get the definitions for each machine and platform supported. The
 | |
| # ones used will be selected by make at compile time based on the
 | |
| # contents of the top-level defs.mk file.
 | |
| #
 | |
| # This will declare a bunch of machine-dependent source files and also
 | |
| # declare all the hardware devices (since what sorts of hardware we
 | |
| # expect to find is machine-dependent.)
 | |
| #
 | |
| 
 | |
| include   arch/mips/conf/conf.arch
 | |
| include   arch/sys161/conf/conf.arch
 | |
| 
 | |
| ########################################
 | |
| #                                      #
 | |
| #            Support code              #
 | |
| #                                      #
 | |
| ########################################
 | |
| 
 | |
| #
 | |
| # Kernel utility code
 | |
| #
 | |
| 
 | |
| file      lib/array.c
 | |
| file      lib/bitmap.c
 | |
| file      lib/bswap.c
 | |
| file      lib/kgets.c
 | |
| file      lib/kprintf.c
 | |
| file      lib/misc.c
 | |
| file      lib/time.c
 | |
| file      lib/uio.c
 | |
| 
 | |
| defoption noasserts
 | |
| 
 | |
| 
 | |
| #
 | |
| # Standard C functions
 | |
| #
 | |
| # For most of these, we take the source files from our libc.  Note
 | |
| # that those files have to have been hacked a bit to support this.
 | |
| #
 | |
| 
 | |
| file      ../common/libc/printf/__printf.c
 | |
| file      ../common/libc/printf/snprintf.c
 | |
| file      ../common/libc/stdlib/atoi.c
 | |
| file      ../common/libc/string/bzero.c
 | |
| file      ../common/libc/string/memcpy.c
 | |
| file      ../common/libc/string/memmove.c
 | |
| file      ../common/libc/string/memset.c
 | |
| file      ../common/libc/string/strcat.c
 | |
| file      ../common/libc/string/strchr.c
 | |
| file      ../common/libc/string/strcmp.c
 | |
| file      ../common/libc/string/strcpy.c
 | |
| file      ../common/libc/string/strlen.c
 | |
| file      ../common/libc/string/strrchr.c
 | |
| file      ../common/libc/string/strtok_r.c
 | |
| 
 | |
| ########################################
 | |
| #                                      #
 | |
| #       Core kernel source files       #
 | |
| #                                      #
 | |
| ########################################
 | |
| 
 | |
| #
 | |
| # Thread system
 | |
| #
 | |
| 
 | |
| file      thread/clock.c
 | |
| file      thread/spl.c
 | |
| file      thread/spinlock.c
 | |
| file      thread/synch.c
 | |
| file      thread/thread.c
 | |
| file      thread/threadlist.c
 | |
| 
 | |
| #
 | |
| # Process system
 | |
| #
 | |
| 
 | |
| file      proc/proc.c
 | |
| 
 | |
| #
 | |
| # Virtual memory system
 | |
| # (you will probably want to add stuff here while doing the VM assignment)
 | |
| #
 | |
| 
 | |
| file      vm/kmalloc.c
 | |
| 
 | |
| optofffile dumbvm   vm/addrspace.c
 | |
| 
 | |
| #
 | |
| # Network
 | |
| # (nothing here yet)
 | |
| #
 | |
| 
 | |
| defoption  net
 | |
| #optfile   net    net/net.c
 | |
| 
 | |
| #
 | |
| # VFS layer
 | |
| #
 | |
| 
 | |
| file      vfs/device.c
 | |
| file      vfs/vfscwd.c
 | |
| file      vfs/vfsfail.c
 | |
| file      vfs/vfslist.c
 | |
| file      vfs/vfslookup.c
 | |
| file      vfs/vfspath.c
 | |
| file      vfs/vnode.c
 | |
| 
 | |
| #
 | |
| # VFS devices
 | |
| #
 | |
| 
 | |
| file      vfs/devnull.c
 | |
| 
 | |
| #
 | |
| # System call layer
 | |
| # (You will probably want to add stuff here while doing the basic system
 | |
| # calls assignment.)
 | |
| #
 | |
| 
 | |
| file      syscall/loadelf.c
 | |
| file      syscall/runprogram.c
 | |
| file      syscall/time_syscalls.c
 | |
| 
 | |
| #
 | |
| # Startup and initialization
 | |
| #
 | |
| 
 | |
| file      main/main.c
 | |
| file      main/menu.c
 | |
| 
 | |
| ########################################
 | |
| #                                      #
 | |
| #             Filesystems              #
 | |
| #                                      #
 | |
| ########################################
 | |
| 
 | |
| #
 | |
| # semfs (fake filesystem providing userlevel semaphores)
 | |
| #
 | |
| defoption semfs
 | |
| optfile   semfs  fs/semfs/semfs_fsops.c
 | |
| optfile   semfs  fs/semfs/semfs_obj.c
 | |
| optfile   semfs  fs/semfs/semfs_vnops.c
 | |
| 
 | |
| #
 | |
| # sfs (the small/simple filesystem)
 | |
| #
 | |
| 
 | |
| defoption sfs
 | |
| optfile   sfs    fs/sfs/sfs_balloc.c
 | |
| optfile   sfs    fs/sfs/sfs_bmap.c
 | |
| optfile   sfs    fs/sfs/sfs_dir.c
 | |
| optfile   sfs    fs/sfs/sfs_fsops.c
 | |
| optfile   sfs    fs/sfs/sfs_inode.c
 | |
| optfile   sfs    fs/sfs/sfs_io.c
 | |
| optfile   sfs    fs/sfs/sfs_vnops.c
 | |
| 
 | |
| #
 | |
| # netfs (the networked filesystem - you might write this as one assignment)
 | |
| #
 | |
| defoption netfs
 | |
| #optfile  netfs     fs/netfs/netfs_fs.c   # or whatever
 | |
| 
 | |
| #
 | |
| # Note that "emufs" is completely contained in the "emu" device.
 | |
| #
 | |
| 
 | |
| 
 | |
| ########################################
 | |
| #                                      #
 | |
| #              Test code               #
 | |
| #                                      #
 | |
| ########################################
 | |
| 
 | |
| file		test/arraytest.c
 | |
| file		test/bitmaptest.c
 | |
| file		test/threadlisttest.c
 | |
| file		test/threadtest.c
 | |
| file		test/tt3.c
 | |
| file		test/synchtest.c
 | |
| file		test/semunit.c
 | |
| file		test/kmalloctest.c
 | |
| file		test/fstest.c
 | |
| optfile net	test/nettest.c
 | |
| 
 | |
| 
 | |
| # NEW PDS WORK (lab1)
 | |
| defoption hello
 | |
| optfile hello   main/hello.c
 | |
| 
 | |
| # LAB2
 | |
| file    syscall/file_syscalls.c
 | |
| file    syscall/proc_syscalls.c
 |