2
* Copyright (c) 2006-2007, XenSource Inc.
4
* This library is free software; you can redistribute it and/or
5
* modify it under the terms of the GNU Lesser General Public
6
* License as published by the Free Software Foundation; either
7
* version 2.1 of the License, or (at your option) any later version.
9
* This library is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12
* Lesser General Public License for more details.
14
* You should have received a copy of the GNU Lesser General Public
15
* License along with this library; if not, write to the Free Software
16
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19
#ifndef XEN_VDI_TYPE_H
20
#define XEN_VDI_TYPE_H
23
#include <xen/api/xen_common.h>
29
* a disk that may be replaced on upgrade
34
* a disk that is always preserved on upgrade
39
* a disk that may be reformatted on upgrade
41
XEN_VDI_TYPE_EPHEMERAL,
44
* a disk that stores a suspend image
49
* a disk that stores VM crashdump information
51
XEN_VDI_TYPE_CRASHDUMP
55
typedef struct xen_vdi_type_set
58
enum xen_vdi_type contents[];
62
* Allocate a xen_vdi_type_set of the given size.
64
extern xen_vdi_type_set *
65
xen_vdi_type_set_alloc(size_t size);
68
* Free the given xen_vdi_type_set. The given set must have been
69
* allocated by this library.
72
xen_vdi_type_set_free(xen_vdi_type_set *set);
76
* Return the name corresponding to the given code. This string must
77
* not be modified or freed.
80
xen_vdi_type_to_string(enum xen_vdi_type val);
84
* Return the correct code for the given string, or set the session
85
* object to failure and return an undefined value if the given string does
86
* not match a known code.
88
extern enum xen_vdi_type
89
xen_vdi_type_from_string(xen_session *session, const char *str);