Remove diskzip.ml source file temporarily -- needs a preprocessor.
[virt-df.git] / lib / diskimage_linux_swap.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 swap partitions.
21 *)
22
23 open Diskimage_impl
24
25 open Int63.Operators
26
27 let id = "linux_swap"
28 let blocksize = ~^4096                  (* XXX *)
29
30 let rec 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       _ : 8*0x1000 - 10*8 : bitstring;
37       ("SWAP-SPACE"|"SWAPSPACE2") : 80 : string
38     } ->
39
40       let fs_dev = new blocksize_overlay blocksize dev in
41       {
42         fs_cb = callbacks ();
43         fs_dev = fs_dev;
44
45         fs_blocksize = blocksize;
46         fs_blocks_total = fs_dev#size /^ blocksize;
47
48         (* The remaining fields are ignored when fs_is_swap is true. *)
49         fs_is_swap = true;
50         fs_blocks_reserved = ~^0;
51         fs_blocks_avail = ~^0;
52         fs_blocks_used = ~^0;
53         fs_inodes_total = ~^0;
54         fs_inodes_reserved = ~^0;
55         fs_inodes_avail = ~^0;
56         fs_inodes_used = ~^0;
57       }
58
59   | { _ } ->
60       raise Not_found                   (* Not Linux swapspace. *)
61
62 (* Linux swap space is always 'free', apart from the superblock.
63  * Compare diskimage_linux_swsuspend.ml
64  *)
65 and offset_is_free _ offset = offset >= blocksize
66
67 and callbacks =
68   let i = ref 0 in
69   fun () -> {
70     fs_cb_uq = (incr i; !i);
71     fs_cb_name = id;
72     fs_cb_printable_name = "Linux swap";
73     fs_cb_offset_is_free = offset_is_free;
74   }
75
76 (* Register the plugin. *)
77 let () = register_plugin ~filesystem:probe id