4
0

vq_object.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. /*
  2. This is a Votequorum object in the parent process. it's really just a conduit for the forked
  3. votequorum entity
  4. */
  5. #include <qb/qblog.h>
  6. #include <qb/qbloop.h>
  7. #include <qb/qbipcc.h>
  8. #include <netinet/in.h>
  9. #include "../exec/votequorum.h"
  10. #include "vqsim.h"
  11. struct vq_instance
  12. {
  13. int nodeid;
  14. int vq_socket;
  15. pid_t pid;
  16. };
  17. vq_object_t vq_create_instance(qb_loop_t *poll_loop, int nodeid)
  18. {
  19. struct vq_instance *instance = malloc(sizeof(struct vq_instance));
  20. if (!instance) {
  21. return NULL;
  22. }
  23. instance->nodeid = nodeid;
  24. if (fork_new_instance(nodeid, &instance->vq_socket, &instance->pid)) {
  25. free(instance);
  26. return NULL;
  27. }
  28. return instance;
  29. }
  30. pid_t vq_get_pid(vq_object_t instance)
  31. {
  32. struct vq_instance *vqi = instance;
  33. return vqi->pid;
  34. }
  35. void vq_quit(vq_object_t instance)
  36. {
  37. struct vq_instance *vqi = instance;
  38. struct vqsim_msg_header msg;
  39. int res;
  40. msg.type = VQMSG_QUIT;
  41. msg.from_nodeid = 0;
  42. msg.param = 0;
  43. res = write(vqi->vq_socket, &msg, sizeof(msg));
  44. if (res <= 0) {
  45. perror("Quit write failed");
  46. }
  47. }
  48. int vq_quit_if_inquorate(vq_object_t instance)
  49. {
  50. struct vq_instance *vqi = instance;
  51. struct vqsim_msg_header msg;
  52. int res;
  53. msg.type = VQMSG_QUORUMQUIT;
  54. msg.from_nodeid = 0;
  55. msg.param = 0;
  56. res = write(vqi->vq_socket, &msg, sizeof(msg));
  57. if (res <= 0) {
  58. perror("Quit write failed");
  59. }
  60. return 0;
  61. }
  62. int vq_set_nodelist(vq_object_t instance, struct memb_ring_id *ring_id, int *nodeids, int nodeids_entries)
  63. {
  64. struct vq_instance *vqi = instance;
  65. char msgbuf[sizeof(int)*nodeids_entries + sizeof(struct vqsim_sync_msg)];
  66. struct vqsim_sync_msg *msg = (void*)msgbuf;
  67. int res;
  68. msg->header.type = VQMSG_SYNC;
  69. msg->header.from_nodeid = 0;
  70. msg->header.param = 0;
  71. msg->view_list_entries = nodeids_entries;
  72. memcpy(&msg->view_list, nodeids, nodeids_entries*sizeof(int));
  73. memcpy(&msg->ring_id, ring_id, sizeof(struct memb_ring_id));
  74. res = write(vqi->vq_socket, msgbuf, sizeof(msgbuf));
  75. if (res <= 0) {
  76. perror("Sync write failed");
  77. return -1;
  78. }
  79. return 0;
  80. }
  81. int vq_set_qdevice(vq_object_t instance, struct memb_ring_id *ring_id, int onoff)
  82. {
  83. struct vq_instance *vqi = instance;
  84. struct vqsim_msg_header msg;
  85. int res;
  86. msg.type = VQMSG_QDEVICE;
  87. msg.from_nodeid = 0;
  88. msg.param = onoff;
  89. res = write(vqi->vq_socket, &msg, sizeof(msg));
  90. if (res <= 0) {
  91. perror("qdevice register write failed");
  92. return -1;
  93. }
  94. return 0;
  95. }
  96. int vq_get_parent_fd(vq_object_t instance)
  97. {
  98. struct vq_instance *vqi = instance;
  99. return vqi->vq_socket;
  100. }