os161-1.99
 All Data Structures
device.h
00001 /*
00002  * Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005, 2008, 2009
00003  *      The President and Fellows of Harvard College.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. Neither the name of the University nor the names of its contributors
00014  *    may be used to endorse or promote products derived from this software
00015  *    without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY AND CONTRIBUTORS ``AS IS'' AND
00018  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00019  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00020  * ARE DISCLAIMED.  IN NO EVENT SHALL THE UNIVERSITY OR CONTRIBUTORS BE LIABLE
00021  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00022  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
00023  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00024  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00025  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
00026  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00027  * SUCH DAMAGE.
00028  */
00029 
00030 #ifndef _DEVICE_H_
00031 #define _DEVICE_H_
00032 
00033 /*
00034  * Devices.
00035  */
00036 
00037 
00038 struct uio;  /* in <uio.h> */
00039 
00040 /*
00041  * Filesystem-namespace-accessible device.
00042  * d_io is for both reads and writes; the uio indicates the direction.
00043  */
00044 struct device {
00045         int (*d_open)(struct device *, int flags_from_open);
00046         int (*d_close)(struct device *);
00047         int (*d_io)(struct device *, struct uio *);
00048         int (*d_ioctl)(struct device *, int op, userptr_t data);
00049 
00050         blkcnt_t d_blocks;
00051         blksize_t d_blocksize;
00052 
00053         dev_t d_devnumber;      /* serial number for this device */
00054 
00055         void *d_data;           /* device-specific data */
00056 };
00057 
00058 /* Create vnode for a vfs-level device. */
00059 struct vnode *dev_create_vnode(struct device *dev);
00060 
00061 
00062 /* Initialization functions for builtin vfs-level devices. */
00063 void devnull_create(void);
00064 
00065 /* Function that kicks off device probe and attach. */
00066 void dev_bootstrap(void);
00067 
00068 
00069 #endif /* _DEVICE_H_ */
 All Data Structures