conf.c

来自「基于组件方式开发操作系统的OSKIT源代码」· C语言 代码 · 共 382 行

C
382
字号
/*	$NetBSD: conf.c,v 1.75 1996/05/03 19:40:20 christos Exp $	*//* * Copyright (c) 1994, 1995 Charles M. Hannum.  All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. All advertising materials mentioning features or use of this software *    must display the following acknowledgement: *	This product includes software developed by Charles Hannum. * 4. The name of the author may not be used to endorse or promote products *    derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */#include <sys/param.h>#include <sys/systm.h>#include <sys/buf.h>#include <sys/ioctl.h>#include <sys/tty.h>#include <sys/conf.h>#include <sys/vnode.h>#ifndef LKM#define	lkmenodev	enodev#elseint	lkmenodev __P((void));#endif#ifndef OSKIT#include "wdc.h"bdev_decl(wd);bdev_decl(sw);#include "fdc.h"bdev_decl(fd);#include "wt.h"bdev_decl(wt);#include "sd.h"bdev_decl(sd);#include "st.h"bdev_decl(st);#include "cd.h"bdev_decl(cd);#include "mcd.h"bdev_decl(mcd);#include "vnd.h"bdev_decl(vnd);#include "scd.h"bdev_decl(scd);#include "ccd.h"bdev_decl(ccd);#include "rd.h"bdev_decl(rd);/* no cdev for rd */#elsebdev_decl(wd);#endif /* OSKIT */struct bdevsw	bdevsw[] ={#ifdef OSKIT	/*	 * This is all we need because our major() macro just returns 0.	 */	bdev_disk_init(NWDC,wd),	/* 0: ST506/ESDI/IDE disk */#else	bdev_lkm_dummy(),	bdev_lkm_dummy(),	bdev_lkm_dummy(),	bdev_disk_init(NSD,sd)		/* 4: SCSI disk */	bdev_swap_init(1,sw),		/* 1: swap pseudo-device */	bdev_disk_init(NFDC,fd),	/* 2: floppy diskette */	bdev_tape_init(NWT,wt),		/* 3: QIC-02/QIC-36 tape */	bdev_disk_init(NSD,sd),		/* 4: SCSI disk */	bdev_tape_init(NST,st),		/* 5: SCSI tape */	bdev_disk_init(NCD,cd),		/* 6: SCSI CD-ROM */	bdev_disk_init(NMCD,mcd),	/* 7: Mitsumi CD-ROM */	bdev_lkm_dummy(),		/* 8 */	bdev_lkm_dummy(),		/* 9 */	bdev_lkm_dummy(),		/* 10 */	bdev_lkm_dummy(),		/* 11 */	bdev_lkm_dummy(),		/* 12 */	bdev_lkm_dummy(),		/* 13 */	bdev_disk_init(NVND,vnd),	/* 14: vnode disk driver */	bdev_disk_init(NSCD,scd),	/* 15: Sony CD-ROM */	bdev_disk_init(NCCD,ccd),	/* 16: concatenated disk driver */	bdev_disk_init(NRD,rd),		/* 17: ram disk driver */#endif /* OSKIT */};int	nblkdev = sizeof(bdevsw) / sizeof(bdevsw[0]);#ifndef OSKIT/* open, close, read, write, ioctl, tty, mmap */#define cdev_pc_init(c,n) { \	dev_init(c,n,open), dev_init(c,n,close), dev_init(c,n,read), \	dev_init(c,n,write), dev_init(c,n,ioctl), dev_init(c,n,stop), \	dev_init(c,n,tty), ttselect, dev_init(c,n,mmap), D_TTY }/* open, close, write, ioctl */#define	cdev_lpt_init(c,n) { \	dev_init(c,n,open), dev_init(c,n,close), (dev_type_read((*))) enodev, \	dev_init(c,n,write), dev_init(c,n,ioctl), (dev_type_stop((*))) enodev, \	0, seltrue, (dev_type_mmap((*))) enodev }/* open, close, write, ioctl */#define	cdev_spkr_init(c,n) { \	dev_init(c,n,open), dev_init(c,n,close), (dev_type_read((*))) enodev, \	dev_init(c,n,write), dev_init(c,n,ioctl), (dev_type_stop((*))) enodev, \	0, seltrue, (dev_type_mmap((*))) enodev }/* open, close, read, ioctl */#define cdev_ss_init(c,n) { \	dev_init(c,n,open), dev_init(c,n,close), dev_init(c,n,read), \	(dev_type_write((*))) enodev, dev_init(c,n,ioctl), \	(dev_type_stop((*))) enodev, 0, seltrue, \	(dev_type_mmap((*))) enodev }#define cdev_joy_init cdev_ss_initcdev_decl(cn);cdev_decl(ctty);#define	mmread	mmrw#define	mmwrite	mmrwcdev_decl(mm);cdev_decl(wd);cdev_decl(sw);#include "pty.h"#define	ptstty		ptytty#define	ptsioctl	ptyioctlcdev_decl(pts);#define	ptctty		ptytty#define	ptcioctl	ptyioctlcdev_decl(ptc);cdev_decl(log);#include "com.h"cdev_decl(com);cdev_decl(fd);cdev_decl(wt);cdev_decl(scd);#include "pc.h"#include "vt.h"cdev_decl(pc);cdev_decl(sd);cdev_decl(st);#include "ss.h"cdev_decl(ss);cdev_decl(cd);#include "lpt.h"cdev_decl(lpt);#include "ch.h"cdev_decl(ch);dev_decl(filedesc,open);#include "bpfilter.h"cdev_decl(bpf);#include "spkr.h"cdev_decl(spkr);#ifdef LKM#define	NLKM	1#else#define	NLKM	0#endifcdev_decl(lkm);#include "mms.h"cdev_decl(mms);#include "lms.h"cdev_decl(lms);#include "pms.h"cdev_decl(pms);#include "cy.h"cdev_decl(cy);cdev_decl(mcd);#include "tun.h"cdev_decl(tun);cdev_decl(vnd);#include "audio.h"cdev_decl(audio);cdev_decl(svr4_net);cdev_decl(ccd);#include "joy.h"cdev_decl(joy);#endif /* OSKIT */struct cdevsw	cdevsw[] ={#ifndef OSKIT	cdev_cn_init(1,cn),		/* 0: virtual console */	cdev_ctty_init(1,ctty),		/* 1: controlling terminal */	cdev_mm_init(1,mm),		/* 2: /dev/{null,mem,kmem,...} */	cdev_disk_init(NWDC,wd),	/* 3: ST506/ESDI/IDE disk */	cdev_swap_init(1,sw),		/* 4: /dev/drum (swap pseudo-device) */	cdev_tty_init(NPTY,pts),	/* 5: pseudo-tty slave */	cdev_ptc_init(NPTY,ptc),	/* 6: pseudo-tty master */	cdev_log_init(1,log),		/* 7: /dev/klog */	cdev_tty_init(NCOM,com),	/* 8: serial port */	cdev_disk_init(NFDC,fd),	/* 9: floppy disk */	cdev_tape_init(NWT,wt),		/* 10: QIC-02/QIC-36 tape */	cdev_disk_init(NSCD,scd),	/* 11: Sony CD-ROM */	cdev_pc_init(NPC + NVT,pc),	/* 12: PC console */	cdev_disk_init(NSD,sd),		/* 13: SCSI disk */	cdev_tape_init(NST,st),		/* 14: SCSI tape */	cdev_disk_init(NCD,cd),		/* 15: SCSI CD-ROM */	cdev_lpt_init(NLPT,lpt),	/* 16: parallel printer */	cdev_ch_init(NCH,ch),		/* 17: SCSI autochanger */	cdev_disk_init(NCCD,ccd),	/* 18: concatenated disk driver */	cdev_ss_init(NSS,ss),		/* 19: SCSI scanner */	cdev_notdef(),			/* 20 */	cdev_notdef(),			/* 21 */	cdev_fd_init(1,filedesc),	/* 22: file descriptor pseudo-device */	cdev_bpftun_init(NBPFILTER,bpf),/* 23: Berkeley packet filter */	cdev_notdef(),			/* 24 */	cdev_notdef(),			/* 25 */	cdev_joy_init(NJOY,joy),        /* 26: joystick */	cdev_spkr_init(NSPKR,spkr),	/* 27: PC speaker */	cdev_lkm_init(NLKM,lkm),	/* 28: loadable module driver */	cdev_lkm_dummy(),		/* 29 */	cdev_lkm_dummy(),		/* 30 */	cdev_lkm_dummy(),		/* 31 */	cdev_lkm_dummy(),		/* 32 */	cdev_lkm_dummy(),		/* 33 */	cdev_lkm_dummy(),		/* 34 */	cdev_mouse_init(NMMS,mms),	/* 35: Microsoft mouse */	cdev_mouse_init(NLMS,lms),	/* 36: Logitech mouse */	cdev_mouse_init(NPMS,pms),	/* 37: PS/2 mouse */	cdev_tty_init(NCY,cy),		/* 38: Cyclom serial port */	cdev_disk_init(NMCD,mcd),	/* 39: Mitsumi CD-ROM */	cdev_bpftun_init(NTUN,tun),	/* 40: network tunnel */	cdev_disk_init(NVND,vnd),	/* 41: vnode disk driver */	cdev_audio_init(NAUDIO,audio),	/* 42: generic audio I/O */#ifdef COMPAT_SVR4	cdev_svr4_net_init(1,svr4_net),	/* 43: svr4 net pseudo-device */#else	cdev_notdef(),			/* 43 */#endif#endif /* OSKIT */};int	nchrdev = sizeof(cdevsw) / sizeof(cdevsw[0]);int	mem_no = 2; 	/* major device number of memory special file *//* * Swapdev is a fake device implemented * in sw.c used only internally to get to swstrategy. * It cannot be provided to the users, because the * swstrategy routine munches the b_dev and b_blkno entries * before calling the appropriate driver.  This would horribly * confuse, e.g. the hashing routines. Instead, /dev/drum is * provided as a character (raw) device. */dev_t	swapdev = makedev(1, 0);/* * Returns true if dev is /dev/mem or /dev/kmem. */intiskmemdev(dev)	dev_t dev;{	return (major(dev) == mem_no && (minor(dev) < 2 || minor(dev) == 14));}/* * Returns true if dev is /dev/zero. */intiszerodev(dev)	dev_t dev;{	return (major(dev) == mem_no && minor(dev) == 12);}static int chrtoblktbl[] = {	/* XXXX This needs to be dynamic for LKMs. */	/*VCHR*/	/*VBLK*/	/*  0 */	NODEV,	/*  1 */	NODEV,	/*  2 */	NODEV,	/*  3 */	0,	/*  4 */	NODEV,	/*  5 */	NODEV,	/*  6 */	NODEV,	/*  7 */	NODEV,	/*  8 */	NODEV,	/*  9 */	2,	/* 10 */	3,	/* 11 */	15,	/* 12 */	NODEV,	/* 13 */	4,	/* 14 */	5,	/* 15 */	6,	/* 16 */	NODEV,	/* 17 */	NODEV,	/* 18 */	16,	/* 19 */	NODEV,	/* 20 */	NODEV,	/* 21 */	NODEV,	/* 22 */	NODEV,	/* 23 */	NODEV,	/* 24 */	NODEV,	/* 25 */	NODEV,	/* 26 */	NODEV,	/* 27 */	NODEV,	/* 28 */	NODEV,	/* 29 */	NODEV,	/* 30 */	NODEV,	/* 31 */	NODEV,	/* 32 */	NODEV,	/* 33 */	NODEV,	/* 34 */	NODEV,	/* 35 */	NODEV,	/* 36 */	NODEV,	/* 37 */	NODEV,	/* 38 */	NODEV,	/* 39 */	7,	/* 40 */	NODEV,	/* 41 */	14,	/* 42 */	NODEV,	/* 43 */	NODEV,	/* 44 */	NODEV,	/* 45 */	NODEV,	/* 46 */	NODEV,	/* 47 */	NODEV,	/* 48 */	NODEV,	/* 49 */	NODEV,};/* * Convert a character device number to a block device number. */dev_tchrtoblk(dev)	dev_t dev;{	int blkmaj;	if (major(dev) >= nchrdev)		return (NODEV);	blkmaj = chrtoblktbl[major(dev)];	if (blkmaj == NODEV)		return (NODEV);	return (makedev(blkmaj, minor(dev)));}/* * This entire table could be autoconfig()ed but that would mean that * the kernel's idea of the console would be out of sync with that of * the standalone boot.  I think it best that they both use the same * known algorithm unless we see a pressing need otherwise. */#ifndef OSKIT#include <dev/cons.h>cons_decl(pc);cons_decl(com)struct	consdev constab[] = {#if NPC + NVT > 0	cons_init(pc),#endif#if NCOM > 0	cons_init(com),#endif	{ 0 },};#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?