2
0

xen_devconfig.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. #include "xen_backend.h"
  2. #include "blockdev.h"
  3. #include "block_int.h" /* XXX */
  4. /* ------------------------------------------------------------- */
  5. struct xs_dirs {
  6. char *xs_dir;
  7. QTAILQ_ENTRY(xs_dirs) list;
  8. };
  9. static QTAILQ_HEAD(xs_dirs_head, xs_dirs) xs_cleanup = QTAILQ_HEAD_INITIALIZER(xs_cleanup);
  10. static void xen_config_cleanup_dir(char *dir)
  11. {
  12. struct xs_dirs *d;
  13. d = qemu_malloc(sizeof(*d));
  14. d->xs_dir = dir;
  15. QTAILQ_INSERT_TAIL(&xs_cleanup, d, list);
  16. }
  17. void xen_config_cleanup(void)
  18. {
  19. struct xs_dirs *d;
  20. QTAILQ_FOREACH(d, &xs_cleanup, list) {
  21. xs_rm(xenstore, 0, d->xs_dir);
  22. }
  23. }
  24. /* ------------------------------------------------------------- */
  25. static int xen_config_dev_mkdir(char *dev, int p)
  26. {
  27. struct xs_permissions perms[2] = {{
  28. .id = 0, /* set owner: dom0 */
  29. },{
  30. .id = xen_domid,
  31. .perms = p,
  32. }};
  33. if (!xs_mkdir(xenstore, 0, dev)) {
  34. xen_be_printf(NULL, 0, "xs_mkdir %s: failed\n", dev);
  35. return -1;
  36. }
  37. xen_config_cleanup_dir(qemu_strdup(dev));
  38. if (!xs_set_permissions(xenstore, 0, dev, perms, 2)) {
  39. xen_be_printf(NULL, 0, "xs_set_permissions %s: failed\n", dev);
  40. return -1;
  41. }
  42. return 0;
  43. }
  44. static int xen_config_dev_dirs(const char *ftype, const char *btype, int vdev,
  45. char *fe, char *be, int len)
  46. {
  47. char *dom;
  48. dom = xs_get_domain_path(xenstore, xen_domid);
  49. snprintf(fe, len, "%s/device/%s/%d", dom, ftype, vdev);
  50. free(dom);
  51. dom = xs_get_domain_path(xenstore, 0);
  52. snprintf(be, len, "%s/backend/%s/%d/%d", dom, btype, xen_domid, vdev);
  53. free(dom);
  54. xen_config_dev_mkdir(fe, XS_PERM_READ | XS_PERM_WRITE);
  55. xen_config_dev_mkdir(be, XS_PERM_READ);
  56. return 0;
  57. }
  58. static int xen_config_dev_all(char *fe, char *be)
  59. {
  60. /* frontend */
  61. if (xen_protocol)
  62. xenstore_write_str(fe, "protocol", xen_protocol);
  63. xenstore_write_int(fe, "state", XenbusStateInitialising);
  64. xenstore_write_int(fe, "backend-id", 0);
  65. xenstore_write_str(fe, "backend", be);
  66. /* backend */
  67. xenstore_write_str(be, "domain", qemu_name ? qemu_name : "no-name");
  68. xenstore_write_int(be, "online", 1);
  69. xenstore_write_int(be, "state", XenbusStateInitialising);
  70. xenstore_write_int(be, "frontend-id", xen_domid);
  71. xenstore_write_str(be, "frontend", fe);
  72. return 0;
  73. }
  74. /* ------------------------------------------------------------- */
  75. int xen_config_dev_blk(DriveInfo *disk)
  76. {
  77. char fe[256], be[256];
  78. int vdev = 202 * 256 + 16 * disk->unit;
  79. int cdrom = disk->media_cd;
  80. const char *devtype = cdrom ? "cdrom" : "disk";
  81. const char *mode = cdrom ? "r" : "w";
  82. snprintf(disk->bdrv->device_name, sizeof(disk->bdrv->device_name),
  83. "xvd%c", 'a' + disk->unit);
  84. xen_be_printf(NULL, 1, "config disk %d [%s]: %s\n",
  85. disk->unit, disk->bdrv->device_name, disk->bdrv->filename);
  86. xen_config_dev_dirs("vbd", "qdisk", vdev, fe, be, sizeof(fe));
  87. /* frontend */
  88. xenstore_write_int(fe, "virtual-device", vdev);
  89. xenstore_write_str(fe, "device-type", devtype);
  90. /* backend */
  91. xenstore_write_str(be, "dev", disk->bdrv->device_name);
  92. xenstore_write_str(be, "type", "file");
  93. xenstore_write_str(be, "params", disk->bdrv->filename);
  94. xenstore_write_str(be, "mode", mode);
  95. /* common stuff */
  96. return xen_config_dev_all(fe, be);
  97. }
  98. int xen_config_dev_nic(NICInfo *nic)
  99. {
  100. char fe[256], be[256];
  101. char mac[20];
  102. snprintf(mac, sizeof(mac), "%02x:%02x:%02x:%02x:%02x:%02x",
  103. nic->macaddr.a[0], nic->macaddr.a[1], nic->macaddr.a[2],
  104. nic->macaddr.a[3], nic->macaddr.a[4], nic->macaddr.a[5]);
  105. xen_be_printf(NULL, 1, "config nic %d: mac=\"%s\"\n", nic->vlan->id, mac);
  106. xen_config_dev_dirs("vif", "qnic", nic->vlan->id, fe, be, sizeof(fe));
  107. /* frontend */
  108. xenstore_write_int(fe, "handle", nic->vlan->id);
  109. xenstore_write_str(fe, "mac", mac);
  110. /* backend */
  111. xenstore_write_int(be, "handle", nic->vlan->id);
  112. xenstore_write_str(be, "mac", mac);
  113. /* common stuff */
  114. return xen_config_dev_all(fe, be);
  115. }
  116. int xen_config_dev_vfb(int vdev, const char *type)
  117. {
  118. char fe[256], be[256];
  119. xen_config_dev_dirs("vfb", "vfb", vdev, fe, be, sizeof(fe));
  120. /* backend */
  121. xenstore_write_str(be, "type", type);
  122. /* common stuff */
  123. return xen_config_dev_all(fe, be);
  124. }
  125. int xen_config_dev_vkbd(int vdev)
  126. {
  127. char fe[256], be[256];
  128. xen_config_dev_dirs("vkbd", "vkbd", vdev, fe, be, sizeof(fe));
  129. return xen_config_dev_all(fe, be);
  130. }
  131. int xen_config_dev_console(int vdev)
  132. {
  133. char fe[256], be[256];
  134. xen_config_dev_dirs("console", "console", vdev, fe, be, sizeof(fe));
  135. return xen_config_dev_all(fe, be);
  136. }