1 #include "xen_backend.h"
3 #include "block_int.h" /* XXX */
5 /* ------------------------------------------------------------- */
9 QTAILQ_ENTRY(xs_dirs) list;
11 static QTAILQ_HEAD(xs_dirs_head, xs_dirs) xs_cleanup = QTAILQ_HEAD_INITIALIZER(xs_cleanup);
13 static void xen_config_cleanup_dir(char *dir)
17 d = g_malloc(sizeof(*d));
19 QTAILQ_INSERT_TAIL(&xs_cleanup, d, list);
22 void xen_config_cleanup(void)
26 QTAILQ_FOREACH(d, &xs_cleanup, list) {
27 xs_rm(xenstore, 0, d->xs_dir);
31 /* ------------------------------------------------------------- */
33 static int xen_config_dev_mkdir(char *dev, int p)
35 struct xs_permissions perms[2] = {{
36 .id = 0, /* set owner: dom0 */
42 if (!xs_mkdir(xenstore, 0, dev)) {
43 xen_be_printf(NULL, 0, "xs_mkdir %s: failed\n", dev);
46 xen_config_cleanup_dir(g_strdup(dev));
48 if (!xs_set_permissions(xenstore, 0, dev, perms, 2)) {
49 xen_be_printf(NULL, 0, "xs_set_permissions %s: failed\n", dev);
55 static int xen_config_dev_dirs(const char *ftype, const char *btype, int vdev,
56 char *fe, char *be, int len)
60 dom = xs_get_domain_path(xenstore, xen_domid);
61 snprintf(fe, len, "%s/device/%s/%d", dom, ftype, vdev);
64 dom = xs_get_domain_path(xenstore, 0);
65 snprintf(be, len, "%s/backend/%s/%d/%d", dom, btype, xen_domid, vdev);
68 xen_config_dev_mkdir(fe, XS_PERM_READ | XS_PERM_WRITE);
69 xen_config_dev_mkdir(be, XS_PERM_READ);
73 static int xen_config_dev_all(char *fe, char *be)
77 xenstore_write_str(fe, "protocol", xen_protocol);
79 xenstore_write_int(fe, "state", XenbusStateInitialising);
80 xenstore_write_int(fe, "backend-id", 0);
81 xenstore_write_str(fe, "backend", be);
84 xenstore_write_str(be, "domain", qemu_name ? qemu_name : "no-name");
85 xenstore_write_int(be, "online", 1);
86 xenstore_write_int(be, "state", XenbusStateInitialising);
87 xenstore_write_int(be, "frontend-id", xen_domid);
88 xenstore_write_str(be, "frontend", fe);
93 /* ------------------------------------------------------------- */
95 int xen_config_dev_blk(DriveInfo *disk)
97 char fe[256], be[256];
98 int vdev = 202 * 256 + 16 * disk->unit;
99 int cdrom = disk->media_cd;
100 const char *devtype = cdrom ? "cdrom" : "disk";
101 const char *mode = cdrom ? "r" : "w";
103 snprintf(disk->bdrv->device_name, sizeof(disk->bdrv->device_name),
104 "xvd%c", 'a' + disk->unit);
105 xen_be_printf(NULL, 1, "config disk %d [%s]: %s\n",
106 disk->unit, disk->bdrv->device_name, disk->bdrv->filename);
107 xen_config_dev_dirs("vbd", "qdisk", vdev, fe, be, sizeof(fe));
110 xenstore_write_int(fe, "virtual-device", vdev);
111 xenstore_write_str(fe, "device-type", devtype);
114 xenstore_write_str(be, "dev", disk->bdrv->device_name);
115 xenstore_write_str(be, "type", "file");
116 xenstore_write_str(be, "params", disk->bdrv->filename);
117 xenstore_write_str(be, "mode", mode);
120 return xen_config_dev_all(fe, be);
123 int xen_config_dev_nic(NICInfo *nic)
125 char fe[256], be[256];
128 snprintf(mac, sizeof(mac), "%02x:%02x:%02x:%02x:%02x:%02x",
129 nic->macaddr.a[0], nic->macaddr.a[1], nic->macaddr.a[2],
130 nic->macaddr.a[3], nic->macaddr.a[4], nic->macaddr.a[5]);
131 xen_be_printf(NULL, 1, "config nic %d: mac=\"%s\"\n", nic->vlan->id, mac);
132 xen_config_dev_dirs("vif", "qnic", nic->vlan->id, fe, be, sizeof(fe));
135 xenstore_write_int(fe, "handle", nic->vlan->id);
136 xenstore_write_str(fe, "mac", mac);
139 xenstore_write_int(be, "handle", nic->vlan->id);
140 xenstore_write_str(be, "mac", mac);
143 return xen_config_dev_all(fe, be);
146 int xen_config_dev_vfb(int vdev, const char *type)
148 char fe[256], be[256];
150 xen_config_dev_dirs("vfb", "vfb", vdev, fe, be, sizeof(fe));
153 xenstore_write_str(be, "type", type);
156 return xen_config_dev_all(fe, be);
159 int xen_config_dev_vkbd(int vdev)
161 char fe[256], be[256];
163 xen_config_dev_dirs("vkbd", "vkbd", vdev, fe, be, sizeof(fe));
164 return xen_config_dev_all(fe, be);
167 int xen_config_dev_console(int vdev)
169 char fe[256], be[256];
171 xen_config_dev_dirs("console", "console", vdev, fe, be, sizeof(fe));
172 return xen_config_dev_all(fe, be);