Use tables of callbacks for the functions.
[virt-df.git] / lib / diskimage_linux_swsuspend.ml
1 (* 'df' command for virtual domains.
2
3    (C) Copyright 2007 Richard W.M. Jones, Red Hat Inc.
4    http://libvirt.org/
5
6    This program 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 2 of the License, or
9    (at your option) any later version.
10
11    This program 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 this program; if not, write to the Free Software
18    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19
20    Support for Linux software suspend partitions.
21 *)
22
23 open Diskimage_utils
24
25 open Int63.Operators
26
27 let plugin_id = "linux_swsuspend"
28 let blocksize = ~^4096                  (* XXX *)
29
30 let probe dev =
31   (* Load the "superblock" (ie. first 0x1000 bytes). *)
32   let bits = dev#read_bitstring ~^0 ~^0x1000 in
33
34   bitmatch bits with
35   | {
36       (* Actually this isn't just padding. *)
37       padding : 8*0x1000 - 10*8 : bitstring;
38       ("S1SUSPEND"|"S2SUSPEND") : 80 : string
39     } ->
40
41       let fs_dev = new blocksize_overlay blocksize dev in
42       {
43         fs_plugin_id = plugin_id;
44         fs_dev = fs_dev;
45
46         fs_blocksize = blocksize;
47         fs_blocks_total = fs_dev#size /^ blocksize;
48
49         (* The remaining fields are ignored when fs_is_swap is true. *)
50         fs_is_swap = true;
51         fs_blocks_reserved = ~^0;
52         fs_blocks_avail = ~^0;
53         fs_blocks_used = ~^0;
54         fs_inodes_total = ~^0;
55         fs_inodes_reserved = ~^0;
56         fs_inodes_avail = ~^0;
57         fs_inodes_used = ~^0;
58       }
59
60   | { _ } ->
61       raise Not_found                   (* Not Linux software suspend. *)
62
63 (* Linux software suspend image is never free.
64  * Compare diskimage_linux_swap.ml
65  *)
66 let offset_is_free _ _ = false
67
68 let callbacks = {
69   fs_cb_probe = probe;
70   fs_cb_offset_is_free = offset_is_free;
71 }