a8b86fb8b1d5a53e4dee2a879b30d9a1cc82d1b6
[people/sha0/winvblock.git] / src / include / ramdisk.h
1 /**
2  * Copyright (C) 2009-2010, Shao Miller <shao.miller@yrdsb.edu.on.ca>.
3  *
4  * This file is part of WinVBlock, derived from WinAoE.
5  *
6  * WinVBlock is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * WinVBlock is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with WinVBlock.  If not, see <http://www.gnu.org/licenses/>.
18  */
19 #ifndef WV_M_RAMDISK_H_
20 #  define WV_M_RAMDISK_H_
21
22 /**
23  * @file
24  *
25  * RAM disk specifics.
26  */
27
28 winvblock__def_struct ( ramdisk__type )
29 {
30   WV_SP_DISK_T disk;
31   winvblock__uint32 DiskBuf;
32   winvblock__uint32 DiskSize;
33   WV_FP_DEV_FREE prev_free;
34   LIST_ENTRY tracking;
35 };
36
37 extern NTSTATUS ramdisk__module_init(void);
38
39 /**
40  * Create a new RAM disk
41  *
42  * @ret ramdisk_ptr     The address of a new RAM disk, or NULL for failure
43  *
44  * This function should not be confused with a PDO creation routine, which is
45  * actually implemented for each device type.  This routine will allocate a
46  * ramdisk__type, track it in a global list, as well as populate the disk
47  * with default values.
48  */
49 extern ramdisk__type_ptr ramdisk__create (
50   void
51  );
52
53 #endif  /* WV_M_RAMDISK_H_ */