conf.c revision 1.18
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 56int debug = DEBUG_VAL; 57#else 58int 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 74struct 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 81int 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 101struct 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 113int nfsys = sizeof(file_system)/sizeof(struct fs_ops); 114#endif 115 116#ifdef BOOTNET 117extern struct netif_driver prom_netif_driver; 118 119struct netif_driver *netif_drivers[] = { 120 &prom_netif_driver, 121}; 122int n_netif_drivers = (sizeof(netif_drivers) / sizeof(netif_drivers[0])); 123#endif 124