ia64/xen-unstable

view tools/xenstore/xs_lib.h @ 19731:01748ccc4da3

Intel VT-d: fix Stoakley boot issue with iommu=1

Signed-off-by: Weidong Han <Weidong.han@intel.com>
Signed-off-by: Allen Kay <allen.m.kay@intel.com>
author Keir Fraser <keir.fraser@citrix.com>
date Fri Jun 05 09:25:50 2009 +0100 (2009-06-05)
parents b47849b774f1
children
line source
1 /*
2 Common routines between Xen store user library and daemon.
3 Copyright (C) 2005 Rusty Russell IBM Corporation
5 This library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 This library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with this library; if not, write to the Free Software
17 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18 */
20 #ifndef _XS_LIB_H
21 #define _XS_LIB_H
23 #include <stdbool.h>
24 #include <limits.h>
25 #include <errno.h>
26 #include <stdint.h>
27 #include <xen/io/xs_wire.h>
29 /* Bitmask of permissions. */
30 enum xs_perm_type {
31 XS_PERM_NONE = 0,
32 XS_PERM_READ = 1,
33 XS_PERM_WRITE = 2,
34 /* Internal use. */
35 XS_PERM_ENOENT_OK = 4,
36 XS_PERM_OWNER = 8,
37 };
39 struct xs_permissions
40 {
41 unsigned int id;
42 enum xs_perm_type perms;
43 };
45 /* Each 10 bits takes ~ 3 digits, plus one, plus one for nul terminator. */
46 #define MAX_STRLEN(x) ((sizeof(x) * CHAR_BIT + CHAR_BIT-1) / 10 * 3 + 2)
48 /* Path for various daemon things: env vars can override. */
49 const char *xs_daemon_rootdir(void);
50 const char *xs_daemon_rundir(void);
51 const char *xs_daemon_socket(void);
52 const char *xs_daemon_socket_ro(void);
53 const char *xs_domain_dev(void);
54 const char *xs_daemon_tdb(void);
56 /* Simple write function: loops for you. */
57 bool xs_write_all(int fd, const void *data, unsigned int len);
59 /* Convert strings to permissions. False if a problem. */
60 bool xs_strings_to_perms(struct xs_permissions *perms, unsigned int num,
61 const char *strings);
63 /* Convert permissions to a string (up to len MAX_STRLEN(unsigned int)+1). */
64 bool xs_perm_to_string(const struct xs_permissions *perm,
65 char *buffer, size_t buf_len);
67 /* Given a string and a length, count how many strings (nul terms). */
68 unsigned int xs_count_strings(const char *strings, unsigned int len);
70 /* Sanitising (quoting) possibly-binary strings. */
71 struct expanding_buffer {
72 char *buf;
73 int avail;
74 };
76 /* Ensure that given expanding buffer has at least min_avail characters. */
77 char *expanding_buffer_ensure(struct expanding_buffer *, int min_avail);
79 /* sanitise_value() may return NULL if malloc fails. */
80 char *sanitise_value(struct expanding_buffer *, const char *val, unsigned len);
82 /* *out_len_r on entry is ignored; out must be at least strlen(in)+1 bytes. */
83 void unsanitise_value(char *out, unsigned *out_len_r, const char *in);
85 #endif /* _XS_LIB_H */