2
* Copyright (C) 2006-2007 XenSource Ltd.
3
* Copyright (C) 2008 Citrix Ltd.
4
* Author Vincent Hanquez <vincent.hanquez@eu.citrix.com>
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU Lesser General Public License as published
8
* by the Free Software Foundation; version 2.1 only. with the special
9
* exception on linking described in file LICENSE.
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 Lesser General Public License for more details.
17
let data_concat ls = (String.concat "\000" ls) ^ "\000"
18
let queue_path ty (tid: int) (path: string) con =
19
let data = data_concat [ path; ] in
20
Xb.queue con (Xb.Packet.create tid 0 ty data)
23
let directory tid path con = queue_path Xb.Op.Directory tid path con
24
let read tid path con = queue_path Xb.Op.Read tid path con
26
let getperms tid path con = queue_path Xb.Op.Getperms tid path con
28
let debug commands con =
29
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Debug (data_concat commands))
31
let watch path data con =
32
let data = data_concat [ path; data; ] in
33
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Watch data)
35
let unwatch path data con =
36
let data = data_concat [ path; data; ] in
37
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Unwatch data)
39
let transaction_start con =
40
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Transaction_start (data_concat []))
42
let transaction_end tid commit con =
43
let data = data_concat [ (if commit then "T" else "F"); ] in
44
Xb.queue con (Xb.Packet.create tid 0 Xb.Op.Transaction_end data)
46
let introduce domid mfn port con =
47
let data = data_concat [ Printf.sprintf "%u" domid;
48
Printf.sprintf "%nu" mfn;
49
string_of_int port; ] in
50
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Introduce data)
52
let release domid con =
53
let data = data_concat [ Printf.sprintf "%u" domid; ] in
54
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Release data)
56
let resume domid con =
57
let data = data_concat [ Printf.sprintf "%u" domid; ] in
58
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Resume data)
60
let getdomainpath domid con =
61
let data = data_concat [ Printf.sprintf "%u" domid; ] in
62
Xb.queue con (Xb.Packet.create 0 0 Xb.Op.Getdomainpath data)
64
let write tid path value con =
65
let data = path ^ "\000" ^ value (* no NULL at the end *) in
66
Xb.queue con (Xb.Packet.create tid 0 Xb.Op.Write data)
68
let mkdir tid path con = queue_path Xb.Op.Mkdir tid path con
69
let rm tid path con = queue_path Xb.Op.Rm tid path con
71
let setperms tid path perms con =
72
let data = data_concat [ path; perms ] in
73
Xb.queue con (Xb.Packet.create tid 0 Xb.Op.Setperms data)