1 /* $NetBSD: conf.c,v 1.18 2002/03/15 13:31:08 simonb Exp $ */ 2 3 /* 4 * Copyright (c) 1992, 1993 5 * The Regents of the University of California. All rights reserved. 6 * 7 * This code is derived from software contributed to Berkeley by 8 * Ralph Campbell. 9 * 10 * Redistribution and use in source and binary forms, with or without 11 * modification, are permitted provided that the following conditions 12 * are met: 13 * 1. Redistributions of source code must retain the above copyright 14 * notice, this list of conditions and the following disclaimer. 15 * 2. Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in the 17 * documentation and/or other materials provided with the distribution. 18 * 3. All advertising materials mentioning features or use of this software 19 * must display the following acknowledgement: 20 * This product includes software developed by the University of 21 * California, Berkeley and its contributors. 22 * 4. Neither the name of the University nor the names of its contributors 23 * may be used to endorse or promote products derived from this software 24 * without specific prior written permission. 25 * 26 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 27 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 28 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 29 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 30 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 31 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 32 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 33 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 34 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 35 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 36 * SUCH DAMAGE. 37 * 38 * @(#)conf.c 8.1 (Berkeley) 6/10/93 39 */ 40 41 #include <sys/types.h> 42 #include <netinet/in.h> 43 #include <lib/libsa/stand.h> 44 #include <lib/libsa/dev_net.h> 45 #include <lib/libsa/ufs.h> 46 #include <lib/libsa/lfs.h> 47 #include <lib/libsa/nfs.h> 48 #include <lib/libsa/cd9660.h> 49 #include <lib/libsa/ustarfs.h> 50 #include <machine/dec_prom.h> 51 #include "../common/rz.h" 52 53 #ifdef NET_DEBUG 54 /* only used for network debugging for now */ 55 #ifdef DEBUG_VAL 56 int debug = DEBUG_VAL; 57 #else 58 int debug = 0; 59 #endif 60 #endif /* NET_DEBUG */ 61 62 #ifndef LIBSA_SINGLE_DEVICE 63 64 #ifdef LIBSA_NO_DEV_CLOSE 65 #define rzclose /*(()(struct open_file*))*/0 66 #endif 67 68 #ifdef LIBSA_NO_DEV_IOCTL 69 #define rzioctl /*(()(struct open_file*, u_long, void*))*/0 70 #else 71 #define rzioctl noioctl 72 #endif 73 74 struct devsw devsw[] = { 75 { "rz", rzstrategy, rzopen, rzclose, rzioctl }, /* 0 */ 76 #ifdef BOOTNET 77 { "tftp", net_strategy, net_open, net_close, net_ioctl }, /* 1 */ 78 #endif 79 }; 80 81 int ndevs = (sizeof(devsw)/sizeof(devsw[0])); 82 #endif 83 84 85 #ifndef LIBSA_SINGLE_FILESYSTEM 86 #ifdef LIBSA_NO_FS_CLOSE 87 #define ufs_close 0 88 #define lfs_close 0 89 #define cd9660_close 0 90 #define ustarfs_close 0 91 #define nfs_close 0 92 #endif 93 #ifdef LIBSA_NO_FS_WRITE 94 #define ufs_write 0 95 #define lfs_write 0 96 #define cd9660_write 0 97 #define ustarfs_write 0 98 #define nfs_write 0 99 #endif 100 101 struct fs_ops file_system[] = { 102 { ufs_open, ufs_close, ufs_read, ufs_write, ufs_seek, ufs_stat }, 103 { lfs_open, lfs_close, lfs_read, lfs_write, lfs_seek, lfs_stat }, 104 { cd9660_open, cd9660_close, cd9660_read, cd9660_write, cd9660_seek, 105 cd9660_stat }, 106 { ustarfs_open, ustarfs_close, ustarfs_read, ustarfs_write, 107 ustarfs_seek, ustarfs_stat }, 108 #ifdef BOOTNET 109 { nfs_open, nfs_close, nfs_read, nfs_write, nfs_seek, nfs_stat }, 110 #endif 111 }; 112 113 int nfsys = sizeof(file_system)/sizeof(struct fs_ops); 114 #endif 115 116 #ifdef BOOTNET 117 extern struct netif_driver prom_netif_driver; 118 119 struct netif_driver *netif_drivers[] = { 120 &prom_netif_driver, 121 }; 122 int n_netif_drivers = (sizeof(netif_drivers) / sizeof(netif_drivers[0])); 123 #endif 124