| 
									
										
										
										
											2020-04-06 18:30:47 +02:00
										 |  |  | # | 
					
						
							|  |  |  | # 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 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-25 18:00:42 +02:00
										 |  |  | # NEW PDS WORK (lab1) | 
					
						
							| 
									
										
										
										
											2020-04-06 18:30:47 +02:00
										 |  |  | defoption hello | 
					
						
							| 
									
										
										
										
											2020-05-25 18:00:42 +02:00
										 |  |  | optfile hello   main/hello.c | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-28 15:27:02 +02:00
										 |  |  | defoption semlock | 
					
						
							|  |  |  | defoption wchanlock | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-25 18:00:42 +02:00
										 |  |  | # LAB2 | 
					
						
							|  |  |  | file    syscall/file_syscalls.c | 
					
						
							|  |  |  | file    syscall/proc_syscalls.c |