2 CTDB protocol marshalling
4 Copyright (C) Amitay Isaacs 2015
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, see <http://www.gnu.org/licenses/>.
21 #include "system/network.h"
27 #include "protocol_api.h"
28 #include "protocol_private.h"
30 struct ctdb_req_control_wire {
31 struct ctdb_req_header hdr;
41 struct ctdb_reply_control_wire {
42 struct ctdb_req_header hdr;
49 static size_t ctdb_req_control_data_len(struct ctdb_req_control_data *cd)
59 case CTDB_CONTROL_PROCESS_EXISTS:
60 len = ctdb_pid_len(cd->data.pid);
63 case CTDB_CONTROL_STATISTICS:
66 case CTDB_CONTROL_PING:
69 case CTDB_CONTROL_GETDBPATH:
70 len = ctdb_uint32_len(cd->data.db_id);
73 case CTDB_CONTROL_GETVNNMAP:
76 case CTDB_CONTROL_SETVNNMAP:
77 len = ctdb_vnn_map_len(cd->data.vnnmap);
80 case CTDB_CONTROL_GET_DEBUG:
83 case CTDB_CONTROL_SET_DEBUG:
84 len = ctdb_uint32_len(cd->data.loglevel);
87 case CTDB_CONTROL_GET_DBMAP:
90 case CTDB_CONTROL_PULL_DB:
91 len = ctdb_pulldb_len(cd->data.pulldb);
94 case CTDB_CONTROL_PUSH_DB:
95 len = ctdb_rec_buffer_len(cd->data.recbuf);
98 case CTDB_CONTROL_GET_RECMODE:
101 case CTDB_CONTROL_SET_RECMODE:
102 len = ctdb_uint32_len(cd->data.recmode);
105 case CTDB_CONTROL_STATISTICS_RESET:
108 case CTDB_CONTROL_DB_ATTACH:
109 len = ctdb_string_len(cd->data.db_name);
112 case CTDB_CONTROL_SET_CALL:
115 case CTDB_CONTROL_TRAVERSE_START:
116 len = ctdb_traverse_start_len(cd->data.traverse_start);
119 case CTDB_CONTROL_TRAVERSE_ALL:
120 len = ctdb_traverse_all_len(cd->data.traverse_all);
123 case CTDB_CONTROL_TRAVERSE_DATA:
124 len = ctdb_rec_data_len(cd->data.rec_data);
127 case CTDB_CONTROL_REGISTER_SRVID:
130 case CTDB_CONTROL_DEREGISTER_SRVID:
133 case CTDB_CONTROL_GET_DBNAME:
134 len = ctdb_uint32_len(cd->data.db_id);
137 case CTDB_CONTROL_ENABLE_SEQNUM:
138 len = ctdb_uint32_len(cd->data.db_id);
141 case CTDB_CONTROL_UPDATE_SEQNUM:
142 len = ctdb_uint32_len(cd->data.db_id);
145 case CTDB_CONTROL_DUMP_MEMORY:
148 case CTDB_CONTROL_GET_PID:
151 case CTDB_CONTROL_GET_RECMASTER:
154 case CTDB_CONTROL_SET_RECMASTER:
155 len = ctdb_uint32_len(cd->data.recmaster);
158 case CTDB_CONTROL_FREEZE:
161 case CTDB_CONTROL_THAW:
164 case CTDB_CONTROL_GET_PNN:
167 case CTDB_CONTROL_SHUTDOWN:
170 case CTDB_CONTROL_GET_MONMODE:
173 case CTDB_CONTROL_TCP_CLIENT:
174 len = ctdb_connection_len(cd->data.conn);
177 case CTDB_CONTROL_TCP_ADD:
178 len = ctdb_connection_len(cd->data.conn);
181 case CTDB_CONTROL_TCP_REMOVE:
182 len = ctdb_connection_len(cd->data.conn);
185 case CTDB_CONTROL_STARTUP:
188 case CTDB_CONTROL_SET_TUNABLE:
189 len = ctdb_tunable_len(cd->data.tunable);
192 case CTDB_CONTROL_GET_TUNABLE:
193 len = ctdb_stringn_len(cd->data.tun_var);
196 case CTDB_CONTROL_LIST_TUNABLES:
199 case CTDB_CONTROL_MODIFY_FLAGS:
200 len = ctdb_node_flag_change_len(cd->data.flag_change);
203 case CTDB_CONTROL_GET_ALL_TUNABLES:
206 case CTDB_CONTROL_GET_TCP_TICKLE_LIST:
207 len = ctdb_sock_addr_len(cd->data.addr);
210 case CTDB_CONTROL_SET_TCP_TICKLE_LIST:
211 len = ctdb_tickle_list_len(cd->data.tickles);
214 case CTDB_CONTROL_REGISTER_SERVER_ID:
215 len = ctdb_client_id_len(cd->data.cid);
218 case CTDB_CONTROL_UNREGISTER_SERVER_ID:
219 len = ctdb_client_id_len(cd->data.cid);
222 case CTDB_CONTROL_CHECK_SERVER_ID:
223 len = ctdb_client_id_len(cd->data.cid);
226 case CTDB_CONTROL_GET_SERVER_ID_LIST:
229 case CTDB_CONTROL_DB_ATTACH_PERSISTENT:
230 len = ctdb_string_len(cd->data.db_name);
233 case CTDB_CONTROL_UPDATE_RECORD:
234 len = ctdb_rec_buffer_len(cd->data.recbuf);
237 case CTDB_CONTROL_SEND_GRATUITOUS_ARP:
238 len = ctdb_addr_info_len(cd->data.addr_info);
241 case CTDB_CONTROL_TRANSACTION_START:
242 len = ctdb_uint32_len(cd->data.tid);
245 case CTDB_CONTROL_TRANSACTION_COMMIT:
246 len = ctdb_uint32_len(cd->data.tid);
249 case CTDB_CONTROL_WIPE_DATABASE:
250 len = ctdb_transdb_len(cd->data.transdb);
253 case CTDB_CONTROL_UPTIME:
256 case CTDB_CONTROL_START_RECOVERY:
259 case CTDB_CONTROL_END_RECOVERY:
262 case CTDB_CONTROL_RELOAD_NODES_FILE:
265 case CTDB_CONTROL_TRY_DELETE_RECORDS:
266 len = ctdb_rec_buffer_len(cd->data.recbuf);
269 case CTDB_CONTROL_ENABLE_MONITOR:
272 case CTDB_CONTROL_DISABLE_MONITOR:
275 case CTDB_CONTROL_ADD_PUBLIC_IP:
276 len = ctdb_addr_info_len(cd->data.addr_info);
279 case CTDB_CONTROL_DEL_PUBLIC_IP:
280 len = ctdb_addr_info_len(cd->data.addr_info);
283 case CTDB_CONTROL_RUN_EVENTSCRIPTS:
284 len = ctdb_string_len(cd->data.event_str);
287 case CTDB_CONTROL_GET_CAPABILITIES:
290 case CTDB_CONTROL_RECD_PING:
293 case CTDB_CONTROL_RELEASE_IP:
294 len = ctdb_public_ip_len(cd->data.pubip);
297 case CTDB_CONTROL_TAKEOVER_IP:
298 len = ctdb_public_ip_len(cd->data.pubip);
301 case CTDB_CONTROL_GET_PUBLIC_IPS:
304 case CTDB_CONTROL_GET_NODEMAP:
307 case CTDB_CONTROL_GET_EVENT_SCRIPT_STATUS:
308 len = ctdb_uint32_len(cd->data.event);
311 case CTDB_CONTROL_TRAVERSE_KILL:
312 len = ctdb_traverse_start_len(cd->data.traverse_start);
315 case CTDB_CONTROL_RECD_RECLOCK_LATENCY:
316 len = ctdb_double_len(cd->data.reclock_latency);
319 case CTDB_CONTROL_GET_RECLOCK_FILE:
322 case CTDB_CONTROL_SET_RECLOCK_FILE:
323 len = ctdb_string_len(cd->data.reclock_file);
326 case CTDB_CONTROL_STOP_NODE:
329 case CTDB_CONTROL_CONTINUE_NODE:
332 case CTDB_CONTROL_SET_LMASTERROLE:
333 len = ctdb_uint32_len(cd->data.role);
336 case CTDB_CONTROL_SET_RECMASTERROLE:
337 len = ctdb_uint32_len(cd->data.role);
340 case CTDB_CONTROL_ENABLE_SCRIPT:
341 len = ctdb_string_len(cd->data.script);
344 case CTDB_CONTROL_DISABLE_SCRIPT:
345 len = ctdb_string_len(cd->data.script);
348 case CTDB_CONTROL_SET_BAN_STATE:
349 len = ctdb_ban_state_len(cd->data.ban_state);
352 case CTDB_CONTROL_GET_BAN_STATE:
355 case CTDB_CONTROL_SET_DB_PRIORITY:
356 len = ctdb_db_priority_len(cd->data.db_prio);
359 case CTDB_CONTROL_GET_DB_PRIORITY:
360 len = ctdb_uint32_len(cd->data.db_id);
363 case CTDB_CONTROL_TRANSACTION_CANCEL:
366 case CTDB_CONTROL_REGISTER_NOTIFY:
367 len = ctdb_notify_data_len(cd->data.notify);
370 case CTDB_CONTROL_DEREGISTER_NOTIFY:
371 len = ctdb_uint64_len(cd->data.srvid);
374 case CTDB_CONTROL_TRANS3_COMMIT:
375 len = ctdb_rec_buffer_len(cd->data.recbuf);
378 case CTDB_CONTROL_GET_DB_SEQNUM:
379 u64 = cd->data.db_id;
380 len = ctdb_uint64_len(u64);
383 case CTDB_CONTROL_DB_SET_HEALTHY:
384 len = ctdb_uint32_len(cd->data.db_id);
387 case CTDB_CONTROL_DB_GET_HEALTH:
388 len = ctdb_uint32_len(cd->data.db_id);
391 case CTDB_CONTROL_GET_PUBLIC_IP_INFO:
392 len = ctdb_sock_addr_len(cd->data.addr);
395 case CTDB_CONTROL_GET_IFACES:
398 case CTDB_CONTROL_SET_IFACE_LINK_STATE:
399 len = ctdb_iface_len(cd->data.iface);
402 case CTDB_CONTROL_TCP_ADD_DELAYED_UPDATE:
403 len = ctdb_connection_len(cd->data.conn);
406 case CTDB_CONTROL_GET_STAT_HISTORY:
409 case CTDB_CONTROL_SCHEDULE_FOR_DELETION:
410 len = ctdb_key_data_len(cd->data.key);
413 case CTDB_CONTROL_SET_DB_READONLY:
414 len = ctdb_uint32_len(cd->data.db_id);
417 case CTDB_CONTROL_CHECK_SRVIDS:
418 len = ctdb_uint64_array_len(cd->data.u64_array);
421 case CTDB_CONTROL_TRAVERSE_START_EXT:
422 len = ctdb_traverse_start_ext_len(cd->data.traverse_start_ext);
425 case CTDB_CONTROL_GET_DB_STATISTICS:
426 len = ctdb_uint32_len(cd->data.db_id);
429 case CTDB_CONTROL_SET_DB_STICKY:
430 len = ctdb_uint32_len(cd->data.db_id);
433 case CTDB_CONTROL_RELOAD_PUBLIC_IPS:
436 case CTDB_CONTROL_TRAVERSE_ALL_EXT:
437 len = ctdb_traverse_all_ext_len(cd->data.traverse_all_ext);
440 case CTDB_CONTROL_RECEIVE_RECORDS:
441 len = ctdb_rec_buffer_len(cd->data.recbuf);
444 case CTDB_CONTROL_IPREALLOCATED:
447 case CTDB_CONTROL_GET_RUNSTATE:
450 case CTDB_CONTROL_DB_DETACH:
451 len = ctdb_uint32_len(cd->data.db_id);
454 case CTDB_CONTROL_GET_NODES_FILE:
457 case CTDB_CONTROL_DB_FREEZE:
458 len = ctdb_uint32_len(cd->data.db_id);
461 case CTDB_CONTROL_DB_THAW:
462 len = ctdb_uint32_len(cd->data.db_id);
465 case CTDB_CONTROL_DB_TRANSACTION_START:
466 len = ctdb_transdb_len(cd->data.transdb);
469 case CTDB_CONTROL_DB_TRANSACTION_COMMIT:
470 len = ctdb_transdb_len(cd->data.transdb);
473 case CTDB_CONTROL_DB_TRANSACTION_CANCEL:
474 len = ctdb_uint32_len(cd->data.db_id);
477 case CTDB_CONTROL_DB_PULL:
478 len = ctdb_pulldb_ext_len(cd->data.pulldb_ext);
481 case CTDB_CONTROL_DB_PUSH_START:
482 len = ctdb_pulldb_ext_len(cd->data.pulldb_ext);
485 case CTDB_CONTROL_DB_PUSH_CONFIRM:
486 len = ctdb_uint32_len(cd->data.db_id);
493 static void ctdb_req_control_data_push(struct ctdb_req_control_data *cd,
498 switch (cd->opcode) {
499 case CTDB_CONTROL_PROCESS_EXISTS:
500 ctdb_pid_push(cd->data.pid, buf);
503 case CTDB_CONTROL_GETDBPATH:
504 ctdb_uint32_push(cd->data.db_id, buf);
507 case CTDB_CONTROL_SETVNNMAP:
508 ctdb_vnn_map_push(cd->data.vnnmap, buf);
511 case CTDB_CONTROL_SET_DEBUG:
512 ctdb_uint32_push(cd->data.loglevel, buf);
515 case CTDB_CONTROL_PULL_DB:
516 ctdb_pulldb_push(cd->data.pulldb, buf);
519 case CTDB_CONTROL_PUSH_DB:
520 ctdb_rec_buffer_push(cd->data.recbuf, buf);
523 case CTDB_CONTROL_SET_RECMODE:
524 ctdb_uint32_push(cd->data.recmode, buf);
527 case CTDB_CONTROL_DB_ATTACH:
528 ctdb_string_push(cd->data.db_name, buf);
531 case CTDB_CONTROL_SET_CALL:
534 case CTDB_CONTROL_TRAVERSE_START:
535 ctdb_traverse_start_push(cd->data.traverse_start, buf);
538 case CTDB_CONTROL_TRAVERSE_ALL:
539 ctdb_traverse_all_push(cd->data.traverse_all, buf);
542 case CTDB_CONTROL_TRAVERSE_DATA:
543 ctdb_rec_data_push(cd->data.rec_data, buf);
546 case CTDB_CONTROL_GET_DBNAME:
547 ctdb_uint32_push(cd->data.db_id, buf);
550 case CTDB_CONTROL_ENABLE_SEQNUM:
551 ctdb_uint32_push(cd->data.db_id, buf);
554 case CTDB_CONTROL_UPDATE_SEQNUM:
555 ctdb_uint32_push(cd->data.db_id, buf);
558 case CTDB_CONTROL_SET_RECMASTER:
559 ctdb_uint32_push(cd->data.recmaster, buf);
562 case CTDB_CONTROL_TCP_CLIENT:
563 ctdb_connection_push(cd->data.conn, buf);
566 case CTDB_CONTROL_TCP_ADD:
567 ctdb_connection_push(cd->data.conn, buf);
570 case CTDB_CONTROL_TCP_REMOVE:
571 ctdb_connection_push(cd->data.conn, buf);
574 case CTDB_CONTROL_SET_TUNABLE:
575 ctdb_tunable_push(cd->data.tunable, buf);
578 case CTDB_CONTROL_GET_TUNABLE:
579 ctdb_stringn_push(cd->data.tun_var, buf);
582 case CTDB_CONTROL_MODIFY_FLAGS:
583 ctdb_node_flag_change_push(cd->data.flag_change, buf);
586 case CTDB_CONTROL_GET_TCP_TICKLE_LIST:
587 ctdb_sock_addr_push(cd->data.addr, buf);
590 case CTDB_CONTROL_SET_TCP_TICKLE_LIST:
591 ctdb_tickle_list_push(cd->data.tickles, buf);
594 case CTDB_CONTROL_REGISTER_SERVER_ID:
595 ctdb_client_id_push(cd->data.cid, buf);
598 case CTDB_CONTROL_UNREGISTER_SERVER_ID:
599 ctdb_client_id_push(cd->data.cid, buf);
602 case CTDB_CONTROL_CHECK_SERVER_ID:
603 ctdb_client_id_push(cd->data.cid, buf);
606 case CTDB_CONTROL_DB_ATTACH_PERSISTENT:
607 ctdb_string_push(cd->data.db_name, buf);
610 case CTDB_CONTROL_UPDATE_RECORD:
611 ctdb_rec_buffer_push(cd->data.recbuf, buf);
614 case CTDB_CONTROL_SEND_GRATUITOUS_ARP:
615 ctdb_addr_info_push(cd->data.addr_info, buf);
618 case CTDB_CONTROL_TRANSACTION_START:
619 ctdb_uint32_push(cd->data.tid, buf);
622 case CTDB_CONTROL_TRANSACTION_COMMIT:
623 ctdb_uint32_push(cd->data.tid, buf);
626 case CTDB_CONTROL_WIPE_DATABASE:
627 ctdb_transdb_push(cd->data.transdb, buf);
630 case CTDB_CONTROL_TRY_DELETE_RECORDS:
631 ctdb_rec_buffer_push(cd->data.recbuf, buf);
634 case CTDB_CONTROL_ADD_PUBLIC_IP:
635 ctdb_addr_info_push(cd->data.addr_info, buf);
638 case CTDB_CONTROL_DEL_PUBLIC_IP:
639 ctdb_addr_info_push(cd->data.addr_info, buf);
642 case CTDB_CONTROL_RUN_EVENTSCRIPTS:
643 ctdb_string_push(cd->data.event_str, buf);
646 case CTDB_CONTROL_RELEASE_IP:
647 ctdb_public_ip_push(cd->data.pubip, buf);
650 case CTDB_CONTROL_TAKEOVER_IP:
651 ctdb_public_ip_push(cd->data.pubip, buf);
654 case CTDB_CONTROL_GET_EVENT_SCRIPT_STATUS:
655 ctdb_uint32_push(cd->data.event, buf);
658 case CTDB_CONTROL_TRAVERSE_KILL:
659 ctdb_traverse_start_push(cd->data.traverse_start, buf);
662 case CTDB_CONTROL_RECD_RECLOCK_LATENCY:
663 ctdb_double_push(cd->data.reclock_latency, buf);
666 case CTDB_CONTROL_SET_RECLOCK_FILE:
667 ctdb_string_push(cd->data.reclock_file, buf);
670 case CTDB_CONTROL_SET_LMASTERROLE:
671 ctdb_uint32_push(cd->data.role, buf);
674 case CTDB_CONTROL_SET_RECMASTERROLE:
675 ctdb_uint32_push(cd->data.role, buf);
678 case CTDB_CONTROL_ENABLE_SCRIPT:
679 ctdb_string_push(cd->data.script, buf);
682 case CTDB_CONTROL_DISABLE_SCRIPT:
683 ctdb_string_push(cd->data.script, buf);
686 case CTDB_CONTROL_SET_BAN_STATE:
687 ctdb_ban_state_push(cd->data.ban_state, buf);
690 case CTDB_CONTROL_SET_DB_PRIORITY:
691 ctdb_db_priority_push(cd->data.db_prio, buf);
694 case CTDB_CONTROL_GET_DB_PRIORITY:
695 ctdb_uint32_push(cd->data.db_id, buf);
698 case CTDB_CONTROL_REGISTER_NOTIFY:
699 ctdb_notify_data_push(cd->data.notify, buf);
702 case CTDB_CONTROL_DEREGISTER_NOTIFY:
703 ctdb_uint64_push(cd->data.srvid, buf);
706 case CTDB_CONTROL_TRANS3_COMMIT:
707 ctdb_rec_buffer_push(cd->data.recbuf, buf);
710 case CTDB_CONTROL_GET_DB_SEQNUM:
711 u64 = cd->data.db_id;
712 ctdb_uint64_push(u64, buf);
715 case CTDB_CONTROL_DB_SET_HEALTHY:
716 ctdb_uint32_push(cd->data.db_id, buf);
719 case CTDB_CONTROL_DB_GET_HEALTH:
720 ctdb_uint32_push(cd->data.db_id, buf);
723 case CTDB_CONTROL_GET_PUBLIC_IP_INFO:
724 ctdb_sock_addr_push(cd->data.addr, buf);
727 case CTDB_CONTROL_SET_IFACE_LINK_STATE:
728 ctdb_iface_push(cd->data.iface, buf);
731 case CTDB_CONTROL_TCP_ADD_DELAYED_UPDATE:
732 ctdb_connection_push(cd->data.conn, buf);
735 case CTDB_CONTROL_SCHEDULE_FOR_DELETION:
736 ctdb_key_data_push(cd->data.key, buf);
739 case CTDB_CONTROL_SET_DB_READONLY:
740 ctdb_uint32_push(cd->data.db_id, buf);
743 case CTDB_CONTROL_CHECK_SRVIDS:
744 ctdb_uint64_array_push(cd->data.u64_array, buf);
747 case CTDB_CONTROL_TRAVERSE_START_EXT:
748 ctdb_traverse_start_ext_push(cd->data.traverse_start_ext, buf);
751 case CTDB_CONTROL_GET_DB_STATISTICS:
752 ctdb_uint32_push(cd->data.db_id, buf);
755 case CTDB_CONTROL_SET_DB_STICKY:
756 ctdb_uint32_push(cd->data.db_id, buf);
759 case CTDB_CONTROL_TRAVERSE_ALL_EXT:
760 ctdb_traverse_all_ext_push(cd->data.traverse_all_ext, buf);
763 case CTDB_CONTROL_RECEIVE_RECORDS:
764 ctdb_rec_buffer_push(cd->data.recbuf, buf);
767 case CTDB_CONTROL_DB_DETACH:
768 ctdb_uint32_push(cd->data.db_id, buf);
771 case CTDB_CONTROL_DB_FREEZE:
772 ctdb_uint32_push(cd->data.db_id, buf);
775 case CTDB_CONTROL_DB_THAW:
776 ctdb_uint32_push(cd->data.db_id, buf);
779 case CTDB_CONTROL_DB_TRANSACTION_START:
780 ctdb_transdb_push(cd->data.transdb, buf);
783 case CTDB_CONTROL_DB_TRANSACTION_COMMIT:
784 ctdb_transdb_push(cd->data.transdb, buf);
787 case CTDB_CONTROL_DB_TRANSACTION_CANCEL:
788 ctdb_uint32_push(cd->data.db_id, buf);
791 case CTDB_CONTROL_DB_PULL:
792 ctdb_pulldb_ext_push(cd->data.pulldb_ext, buf);
795 case CTDB_CONTROL_DB_PUSH_START:
796 ctdb_pulldb_ext_push(cd->data.pulldb_ext, buf);
799 case CTDB_CONTROL_DB_PUSH_CONFIRM:
800 ctdb_uint32_push(cd->data.db_id, buf);
805 static int ctdb_req_control_data_pull(uint8_t *buf, size_t buflen,
808 struct ctdb_req_control_data *cd)
816 case CTDB_CONTROL_PROCESS_EXISTS:
817 ret = ctdb_pid_pull(buf, buflen, mem_ctx,
821 case CTDB_CONTROL_GETDBPATH:
822 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
826 case CTDB_CONTROL_SETVNNMAP:
827 ret = ctdb_vnn_map_pull(buf, buflen, mem_ctx,
831 case CTDB_CONTROL_SET_DEBUG:
832 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
836 case CTDB_CONTROL_PULL_DB:
837 ret = ctdb_pulldb_pull(buf, buflen, mem_ctx,
841 case CTDB_CONTROL_PUSH_DB:
842 ret = ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
846 case CTDB_CONTROL_SET_RECMODE:
847 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
851 case CTDB_CONTROL_DB_ATTACH:
852 ret = ctdb_string_pull(buf, buflen, mem_ctx,
856 case CTDB_CONTROL_SET_CALL:
859 case CTDB_CONTROL_TRAVERSE_START:
860 ret = ctdb_traverse_start_pull(buf, buflen, mem_ctx,
861 &cd->data.traverse_start);
864 case CTDB_CONTROL_TRAVERSE_ALL:
865 ret = ctdb_traverse_all_pull(buf, buflen, mem_ctx,
866 &cd->data.traverse_all);
869 case CTDB_CONTROL_TRAVERSE_DATA:
870 ret = ctdb_rec_data_pull(buf, buflen, mem_ctx,
874 case CTDB_CONTROL_GET_DBNAME:
875 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
879 case CTDB_CONTROL_ENABLE_SEQNUM:
880 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
884 case CTDB_CONTROL_UPDATE_SEQNUM:
885 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
889 case CTDB_CONTROL_SET_RECMASTER:
890 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
891 &cd->data.recmaster);
894 case CTDB_CONTROL_TCP_CLIENT:
895 ret = ctdb_connection_pull(buf, buflen, mem_ctx,
899 case CTDB_CONTROL_TCP_ADD:
900 ret = ctdb_connection_pull(buf, buflen, mem_ctx,
904 case CTDB_CONTROL_TCP_REMOVE:
905 ret = ctdb_connection_pull(buf, buflen, mem_ctx,
909 case CTDB_CONTROL_SET_TUNABLE:
910 ret = ctdb_tunable_pull(buf, buflen, mem_ctx,
914 case CTDB_CONTROL_GET_TUNABLE:
915 ret = ctdb_stringn_pull(buf, buflen, mem_ctx,
919 case CTDB_CONTROL_MODIFY_FLAGS:
920 ret = ctdb_node_flag_change_pull(buf, buflen, mem_ctx,
921 &cd->data.flag_change);
924 case CTDB_CONTROL_GET_TCP_TICKLE_LIST:
925 ret = ctdb_sock_addr_pull(buf, buflen, mem_ctx,
929 case CTDB_CONTROL_SET_TCP_TICKLE_LIST:
930 ret = ctdb_tickle_list_pull(buf, buflen, mem_ctx,
934 case CTDB_CONTROL_REGISTER_SERVER_ID:
935 ret = ctdb_client_id_pull(buf, buflen, mem_ctx,
939 case CTDB_CONTROL_UNREGISTER_SERVER_ID:
940 ret = ctdb_client_id_pull(buf, buflen, mem_ctx,
944 case CTDB_CONTROL_CHECK_SERVER_ID:
945 ret = ctdb_client_id_pull(buf, buflen, mem_ctx,
949 case CTDB_CONTROL_DB_ATTACH_PERSISTENT:
950 ret = ctdb_string_pull(buf, buflen, mem_ctx,
954 case CTDB_CONTROL_UPDATE_RECORD:
955 ret = ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
959 case CTDB_CONTROL_SEND_GRATUITOUS_ARP:
960 ret = ctdb_addr_info_pull(buf, buflen, mem_ctx,
961 &cd->data.addr_info);
964 case CTDB_CONTROL_TRANSACTION_START:
965 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
969 case CTDB_CONTROL_TRANSACTION_COMMIT:
970 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
974 case CTDB_CONTROL_WIPE_DATABASE:
975 ret = ctdb_transdb_pull(buf, buflen, mem_ctx,
979 case CTDB_CONTROL_TRY_DELETE_RECORDS:
980 ret = ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
984 case CTDB_CONTROL_ADD_PUBLIC_IP:
985 ret = ctdb_addr_info_pull(buf, buflen, mem_ctx,
986 &cd->data.addr_info);
989 case CTDB_CONTROL_DEL_PUBLIC_IP:
990 ret = ctdb_addr_info_pull(buf, buflen, mem_ctx,
991 &cd->data.addr_info);
994 case CTDB_CONTROL_RUN_EVENTSCRIPTS:
995 ret = ctdb_string_pull(buf, buflen, mem_ctx,
996 &cd->data.event_str);
999 case CTDB_CONTROL_RELEASE_IP:
1000 ret = ctdb_public_ip_pull(buf, buflen, mem_ctx,
1004 case CTDB_CONTROL_TAKEOVER_IP:
1005 ret = ctdb_public_ip_pull(buf, buflen, mem_ctx,
1009 case CTDB_CONTROL_GET_EVENT_SCRIPT_STATUS:
1010 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1014 case CTDB_CONTROL_TRAVERSE_KILL:
1015 ret = ctdb_traverse_start_pull(buf, buflen, mem_ctx,
1016 &cd->data.traverse_start);
1019 case CTDB_CONTROL_RECD_RECLOCK_LATENCY:
1020 ret = ctdb_double_pull(buf, buflen, mem_ctx,
1021 &cd->data.reclock_latency);
1024 case CTDB_CONTROL_SET_RECLOCK_FILE:
1025 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1026 &cd->data.reclock_file);
1029 case CTDB_CONTROL_SET_LMASTERROLE:
1030 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1034 case CTDB_CONTROL_SET_RECMASTERROLE:
1035 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1039 case CTDB_CONTROL_ENABLE_SCRIPT:
1040 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1044 case CTDB_CONTROL_DISABLE_SCRIPT:
1045 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1049 case CTDB_CONTROL_SET_BAN_STATE:
1050 ret = ctdb_ban_state_pull(buf, buflen, mem_ctx,
1051 &cd->data.ban_state);
1054 case CTDB_CONTROL_SET_DB_PRIORITY:
1055 ret = ctdb_db_priority_pull(buf, buflen, mem_ctx,
1059 case CTDB_CONTROL_GET_DB_PRIORITY:
1060 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1064 case CTDB_CONTROL_REGISTER_NOTIFY:
1065 ret = ctdb_notify_data_pull(buf, buflen, mem_ctx,
1069 case CTDB_CONTROL_DEREGISTER_NOTIFY:
1070 ctdb_uint64_pull(buf, buflen, mem_ctx,
1074 case CTDB_CONTROL_TRANS3_COMMIT:
1075 ret = ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
1079 case CTDB_CONTROL_GET_DB_SEQNUM:
1080 ret = ctdb_uint64_pull(buf, buflen, mem_ctx, &u64);
1081 cd->data.db_id = (uint32_t)u64;
1084 case CTDB_CONTROL_DB_SET_HEALTHY:
1085 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1089 case CTDB_CONTROL_DB_GET_HEALTH:
1090 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1094 case CTDB_CONTROL_GET_PUBLIC_IP_INFO:
1095 ret = ctdb_sock_addr_pull(buf, buflen, mem_ctx,
1099 case CTDB_CONTROL_SET_IFACE_LINK_STATE:
1100 ret = ctdb_iface_pull(buf, buflen, mem_ctx,
1104 case CTDB_CONTROL_TCP_ADD_DELAYED_UPDATE:
1105 ret = ctdb_connection_pull(buf, buflen, mem_ctx,
1109 case CTDB_CONTROL_SCHEDULE_FOR_DELETION:
1110 ret = ctdb_key_data_pull(buf, buflen, mem_ctx,
1114 case CTDB_CONTROL_SET_DB_READONLY:
1115 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1119 case CTDB_CONTROL_CHECK_SRVIDS:
1120 ret = ctdb_uint64_array_pull(buf, buflen, mem_ctx,
1121 &cd->data.u64_array);
1124 case CTDB_CONTROL_TRAVERSE_START_EXT:
1125 ret = ctdb_traverse_start_ext_pull(buf, buflen, mem_ctx,
1126 &cd->data.traverse_start_ext);
1129 case CTDB_CONTROL_GET_DB_STATISTICS:
1130 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1134 case CTDB_CONTROL_SET_DB_STICKY:
1135 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1139 case CTDB_CONTROL_TRAVERSE_ALL_EXT:
1140 ret = ctdb_traverse_all_ext_pull(buf, buflen, mem_ctx,
1141 &cd->data.traverse_all_ext);
1144 case CTDB_CONTROL_RECEIVE_RECORDS:
1145 ret = ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
1149 case CTDB_CONTROL_DB_DETACH:
1150 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1154 case CTDB_CONTROL_DB_FREEZE:
1155 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1159 case CTDB_CONTROL_DB_THAW:
1160 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1164 case CTDB_CONTROL_DB_TRANSACTION_START:
1165 ret = ctdb_transdb_pull(buf, buflen, mem_ctx,
1169 case CTDB_CONTROL_DB_TRANSACTION_COMMIT:
1170 ret = ctdb_transdb_pull(buf, buflen, mem_ctx,
1174 case CTDB_CONTROL_DB_TRANSACTION_CANCEL:
1175 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1179 case CTDB_CONTROL_DB_PULL:
1180 ret = ctdb_pulldb_ext_pull(buf, buflen, mem_ctx,
1181 &cd->data.pulldb_ext);
1184 case CTDB_CONTROL_DB_PUSH_START:
1185 ret = ctdb_pulldb_ext_pull(buf, buflen, mem_ctx,
1186 &cd->data.pulldb_ext);
1189 case CTDB_CONTROL_DB_PUSH_CONFIRM:
1190 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1198 static size_t ctdb_reply_control_data_len(struct ctdb_reply_control_data *cd)
1206 switch (cd->opcode) {
1207 case CTDB_CONTROL_PROCESS_EXISTS:
1210 case CTDB_CONTROL_STATISTICS:
1211 len = ctdb_statistics_len(cd->data.stats);
1214 case CTDB_CONTROL_PING:
1217 case CTDB_CONTROL_GETDBPATH:
1218 len = ctdb_string_len(cd->data.db_path);
1221 case CTDB_CONTROL_GETVNNMAP:
1222 len = ctdb_vnn_map_len(cd->data.vnnmap);
1225 case CTDB_CONTROL_SETVNNMAP:
1228 case CTDB_CONTROL_GET_DEBUG:
1229 len = ctdb_uint32_len(cd->data.loglevel);
1232 case CTDB_CONTROL_SET_DEBUG:
1235 case CTDB_CONTROL_GET_DBMAP:
1236 len = ctdb_dbid_map_len(cd->data.dbmap);
1239 case CTDB_CONTROL_PULL_DB:
1240 len = ctdb_rec_buffer_len(cd->data.recbuf);
1243 case CTDB_CONTROL_PUSH_DB:
1246 case CTDB_CONTROL_GET_RECMODE:
1249 case CTDB_CONTROL_SET_RECMODE:
1252 case CTDB_CONTROL_STATISTICS_RESET:
1255 case CTDB_CONTROL_DB_ATTACH:
1256 len = ctdb_uint32_len(cd->data.db_id);
1259 case CTDB_CONTROL_SET_CALL:
1262 case CTDB_CONTROL_TRAVERSE_START:
1265 case CTDB_CONTROL_TRAVERSE_ALL:
1268 case CTDB_CONTROL_TRAVERSE_DATA:
1271 case CTDB_CONTROL_REGISTER_SRVID:
1274 case CTDB_CONTROL_DEREGISTER_SRVID:
1277 case CTDB_CONTROL_GET_DBNAME:
1278 len = ctdb_string_len(cd->data.db_name);
1281 case CTDB_CONTROL_ENABLE_SEQNUM:
1284 case CTDB_CONTROL_UPDATE_SEQNUM:
1287 case CTDB_CONTROL_DUMP_MEMORY:
1288 len = ctdb_string_len(cd->data.mem_str);
1291 case CTDB_CONTROL_GET_PID:
1294 case CTDB_CONTROL_GET_RECMASTER:
1297 case CTDB_CONTROL_SET_RECMASTER:
1300 case CTDB_CONTROL_FREEZE:
1303 case CTDB_CONTROL_THAW:
1306 case CTDB_CONTROL_GET_PNN:
1309 case CTDB_CONTROL_SHUTDOWN:
1312 case CTDB_CONTROL_GET_MONMODE:
1315 case CTDB_CONTROL_TCP_CLIENT:
1318 case CTDB_CONTROL_TCP_ADD:
1321 case CTDB_CONTROL_TCP_REMOVE:
1324 case CTDB_CONTROL_STARTUP:
1327 case CTDB_CONTROL_SET_TUNABLE:
1330 case CTDB_CONTROL_GET_TUNABLE:
1331 len = ctdb_uint32_len(cd->data.tun_value);
1334 case CTDB_CONTROL_LIST_TUNABLES:
1335 len = ctdb_var_list_len(cd->data.tun_var_list);
1338 case CTDB_CONTROL_MODIFY_FLAGS:
1341 case CTDB_CONTROL_GET_ALL_TUNABLES:
1342 len = ctdb_tunable_list_len(cd->data.tun_list);
1345 case CTDB_CONTROL_GET_TCP_TICKLE_LIST:
1346 len = ctdb_tickle_list_len(cd->data.tickles);
1349 case CTDB_CONTROL_SET_TCP_TICKLE_LIST:
1352 case CTDB_CONTROL_REGISTER_SERVER_ID:
1355 case CTDB_CONTROL_UNREGISTER_SERVER_ID:
1358 case CTDB_CONTROL_CHECK_SERVER_ID:
1361 case CTDB_CONTROL_GET_SERVER_ID_LIST:
1362 len = ctdb_client_id_map_len(cd->data.cid_map);
1365 case CTDB_CONTROL_DB_ATTACH_PERSISTENT:
1366 len = ctdb_uint32_len(cd->data.db_id);
1369 case CTDB_CONTROL_UPDATE_RECORD:
1372 case CTDB_CONTROL_SEND_GRATUITOUS_ARP:
1375 case CTDB_CONTROL_TRANSACTION_START:
1378 case CTDB_CONTROL_TRANSACTION_COMMIT:
1381 case CTDB_CONTROL_WIPE_DATABASE:
1384 case CTDB_CONTROL_UPTIME:
1385 len = ctdb_uptime_len(cd->data.uptime);
1388 case CTDB_CONTROL_START_RECOVERY:
1391 case CTDB_CONTROL_END_RECOVERY:
1394 case CTDB_CONTROL_RELOAD_NODES_FILE:
1397 case CTDB_CONTROL_TRY_DELETE_RECORDS:
1398 len = ctdb_rec_buffer_len(cd->data.recbuf);
1401 case CTDB_CONTROL_ENABLE_MONITOR:
1404 case CTDB_CONTROL_DISABLE_MONITOR:
1407 case CTDB_CONTROL_ADD_PUBLIC_IP:
1410 case CTDB_CONTROL_DEL_PUBLIC_IP:
1413 case CTDB_CONTROL_RUN_EVENTSCRIPTS:
1416 case CTDB_CONTROL_GET_CAPABILITIES:
1417 len = ctdb_uint32_len(cd->data.caps);
1420 case CTDB_CONTROL_RECD_PING:
1423 case CTDB_CONTROL_RELEASE_IP:
1426 case CTDB_CONTROL_TAKEOVER_IP:
1429 case CTDB_CONTROL_GET_PUBLIC_IPS:
1430 len = ctdb_public_ip_list_len(cd->data.pubip_list);
1433 case CTDB_CONTROL_GET_NODEMAP:
1434 len = ctdb_node_map_len(cd->data.nodemap);
1437 case CTDB_CONTROL_GET_EVENT_SCRIPT_STATUS:
1438 len = ctdb_script_list_len(cd->data.script_list);
1441 case CTDB_CONTROL_TRAVERSE_KILL:
1444 case CTDB_CONTROL_RECD_RECLOCK_LATENCY:
1447 case CTDB_CONTROL_GET_RECLOCK_FILE:
1448 len = ctdb_string_len(cd->data.reclock_file);
1451 case CTDB_CONTROL_SET_RECLOCK_FILE:
1454 case CTDB_CONTROL_STOP_NODE:
1457 case CTDB_CONTROL_CONTINUE_NODE:
1460 case CTDB_CONTROL_SET_LMASTERROLE:
1463 case CTDB_CONTROL_SET_RECMASTERROLE:
1466 case CTDB_CONTROL_ENABLE_SCRIPT:
1469 case CTDB_CONTROL_DISABLE_SCRIPT:
1472 case CTDB_CONTROL_SET_BAN_STATE:
1475 case CTDB_CONTROL_GET_BAN_STATE:
1476 len = ctdb_ban_state_len(cd->data.ban_state);
1479 case CTDB_CONTROL_SET_DB_PRIORITY:
1482 case CTDB_CONTROL_GET_DB_PRIORITY:
1485 case CTDB_CONTROL_TRANSACTION_CANCEL:
1488 case CTDB_CONTROL_REGISTER_NOTIFY:
1491 case CTDB_CONTROL_DEREGISTER_NOTIFY:
1494 case CTDB_CONTROL_TRANS3_COMMIT:
1497 case CTDB_CONTROL_GET_DB_SEQNUM:
1498 len = ctdb_uint64_len(cd->data.seqnum);
1501 case CTDB_CONTROL_DB_SET_HEALTHY:
1504 case CTDB_CONTROL_DB_GET_HEALTH:
1505 len = ctdb_string_len(cd->data.reason);
1508 case CTDB_CONTROL_GET_PUBLIC_IP_INFO:
1509 len = ctdb_public_ip_info_len(cd->data.ipinfo);
1512 case CTDB_CONTROL_GET_IFACES:
1513 len = ctdb_iface_list_len(cd->data.iface_list);
1516 case CTDB_CONTROL_SET_IFACE_LINK_STATE:
1519 case CTDB_CONTROL_TCP_ADD_DELAYED_UPDATE:
1522 case CTDB_CONTROL_GET_STAT_HISTORY:
1523 len = ctdb_statistics_list_len(cd->data.stats_list);
1526 case CTDB_CONTROL_SCHEDULE_FOR_DELETION:
1529 case CTDB_CONTROL_SET_DB_READONLY:
1532 case CTDB_CONTROL_CHECK_SRVIDS:
1533 len = ctdb_uint8_array_len(cd->data.u8_array);
1536 case CTDB_CONTROL_TRAVERSE_START_EXT:
1539 case CTDB_CONTROL_GET_DB_STATISTICS:
1540 len = ctdb_db_statistics_len(cd->data.dbstats);
1543 case CTDB_CONTROL_SET_DB_STICKY:
1546 case CTDB_CONTROL_RELOAD_PUBLIC_IPS:
1549 case CTDB_CONTROL_TRAVERSE_ALL_EXT:
1552 case CTDB_CONTROL_RECEIVE_RECORDS:
1553 len = ctdb_rec_buffer_len(cd->data.recbuf);
1556 case CTDB_CONTROL_IPREALLOCATED:
1559 case CTDB_CONTROL_GET_RUNSTATE:
1560 len = ctdb_uint32_len(cd->data.runstate);
1563 case CTDB_CONTROL_DB_DETACH:
1566 case CTDB_CONTROL_GET_NODES_FILE:
1567 len = ctdb_node_map_len(cd->data.nodemap);
1570 case CTDB_CONTROL_DB_FREEZE:
1573 case CTDB_CONTROL_DB_THAW:
1576 case CTDB_CONTROL_DB_TRANSACTION_START:
1579 case CTDB_CONTROL_DB_TRANSACTION_COMMIT:
1582 case CTDB_CONTROL_DB_TRANSACTION_CANCEL:
1585 case CTDB_CONTROL_DB_PULL:
1586 len = ctdb_uint32_len(cd->data.num_records);
1589 case CTDB_CONTROL_DB_PUSH_START:
1592 case CTDB_CONTROL_DB_PUSH_CONFIRM:
1593 len = ctdb_uint32_len(cd->data.num_records);
1600 static void ctdb_reply_control_data_push(struct ctdb_reply_control_data *cd,
1603 switch (cd->opcode) {
1604 case CTDB_CONTROL_STATISTICS:
1605 ctdb_statistics_push(cd->data.stats, buf);
1608 case CTDB_CONTROL_GETDBPATH:
1609 ctdb_string_push(cd->data.db_path, buf);
1612 case CTDB_CONTROL_GETVNNMAP:
1613 ctdb_vnn_map_push(cd->data.vnnmap, buf);
1616 case CTDB_CONTROL_GET_DEBUG:
1617 ctdb_uint32_push(cd->data.loglevel, buf);
1620 case CTDB_CONTROL_GET_DBMAP:
1621 ctdb_dbid_map_push(cd->data.dbmap, buf);
1624 case CTDB_CONTROL_PULL_DB:
1625 ctdb_rec_buffer_push(cd->data.recbuf, buf);
1628 case CTDB_CONTROL_PUSH_DB:
1631 case CTDB_CONTROL_DB_ATTACH:
1632 ctdb_uint32_push(cd->data.db_id, buf);
1635 case CTDB_CONTROL_GET_DBNAME:
1636 ctdb_string_push(cd->data.db_name, buf);
1639 case CTDB_CONTROL_DUMP_MEMORY:
1640 ctdb_string_push(cd->data.mem_str, buf);
1643 case CTDB_CONTROL_GET_PID:
1646 case CTDB_CONTROL_GET_RECMASTER:
1649 case CTDB_CONTROL_GET_TUNABLE:
1650 ctdb_uint32_push(cd->data.tun_value, buf);
1653 case CTDB_CONTROL_LIST_TUNABLES:
1654 ctdb_var_list_push(cd->data.tun_var_list, buf);
1657 case CTDB_CONTROL_GET_ALL_TUNABLES:
1658 ctdb_tunable_list_push(cd->data.tun_list, buf);
1661 case CTDB_CONTROL_GET_TCP_TICKLE_LIST:
1662 ctdb_tickle_list_push(cd->data.tickles, buf);
1665 case CTDB_CONTROL_GET_SERVER_ID_LIST:
1666 ctdb_client_id_map_push(cd->data.cid_map, buf);
1669 case CTDB_CONTROL_DB_ATTACH_PERSISTENT:
1670 ctdb_uint32_push(cd->data.db_id, buf);
1673 case CTDB_CONTROL_UPTIME:
1674 ctdb_uptime_push(cd->data.uptime, buf);
1677 case CTDB_CONTROL_TRY_DELETE_RECORDS:
1678 ctdb_rec_buffer_push(cd->data.recbuf, buf);
1681 case CTDB_CONTROL_GET_CAPABILITIES:
1682 ctdb_uint32_push(cd->data.caps, buf);
1685 case CTDB_CONTROL_GET_PUBLIC_IPS:
1686 ctdb_public_ip_list_push(cd->data.pubip_list, buf);
1689 case CTDB_CONTROL_GET_NODEMAP:
1690 ctdb_node_map_push(cd->data.nodemap, buf);
1693 case CTDB_CONTROL_GET_EVENT_SCRIPT_STATUS:
1694 ctdb_script_list_push(cd->data.script_list, buf);
1697 case CTDB_CONTROL_GET_RECLOCK_FILE:
1698 ctdb_string_push(cd->data.reclock_file, buf);
1701 case CTDB_CONTROL_GET_BAN_STATE:
1702 ctdb_ban_state_push(cd->data.ban_state, buf);
1705 case CTDB_CONTROL_GET_DB_PRIORITY:
1708 case CTDB_CONTROL_GET_DB_SEQNUM:
1709 ctdb_uint64_push(cd->data.seqnum, buf);
1712 case CTDB_CONTROL_DB_GET_HEALTH:
1713 ctdb_string_push(cd->data.reason, buf);
1716 case CTDB_CONTROL_GET_PUBLIC_IP_INFO:
1717 ctdb_public_ip_info_push(cd->data.ipinfo, buf);
1720 case CTDB_CONTROL_GET_IFACES:
1721 ctdb_iface_list_push(cd->data.iface_list, buf);
1724 case CTDB_CONTROL_GET_STAT_HISTORY:
1725 ctdb_statistics_list_push(cd->data.stats_list, buf);
1728 case CTDB_CONTROL_CHECK_SRVIDS:
1729 ctdb_uint8_array_push(cd->data.u8_array, buf);
1732 case CTDB_CONTROL_GET_DB_STATISTICS:
1733 ctdb_db_statistics_push(cd->data.dbstats, buf);
1736 case CTDB_CONTROL_RECEIVE_RECORDS:
1737 ctdb_rec_buffer_push(cd->data.recbuf, buf);
1740 case CTDB_CONTROL_GET_RUNSTATE:
1741 ctdb_uint32_push(cd->data.runstate, buf);
1744 case CTDB_CONTROL_GET_NODES_FILE:
1745 ctdb_node_map_push(cd->data.nodemap, buf);
1748 case CTDB_CONTROL_DB_PULL:
1749 ctdb_uint32_push(cd->data.num_records, buf);
1752 case CTDB_CONTROL_DB_PUSH_CONFIRM:
1753 ctdb_uint32_push(cd->data.num_records, buf);
1758 static int ctdb_reply_control_data_pull(uint8_t *buf, size_t buflen,
1759 uint32_t opcode, TALLOC_CTX *mem_ctx,
1760 struct ctdb_reply_control_data *cd)
1763 cd->opcode = opcode;
1766 case CTDB_CONTROL_STATISTICS:
1767 ret = ctdb_statistics_pull(buf, buflen, mem_ctx,
1771 case CTDB_CONTROL_GETDBPATH:
1772 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1776 case CTDB_CONTROL_GETVNNMAP:
1777 ret = ctdb_vnn_map_pull(buf, buflen, mem_ctx,
1781 case CTDB_CONTROL_GET_DEBUG:
1782 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1783 &cd->data.loglevel);
1786 case CTDB_CONTROL_GET_DBMAP:
1787 ret = ctdb_dbid_map_pull(buf, buflen, mem_ctx,
1791 case CTDB_CONTROL_PULL_DB:
1792 ret = ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
1796 case CTDB_CONTROL_PUSH_DB:
1799 case CTDB_CONTROL_DB_ATTACH:
1800 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1804 case CTDB_CONTROL_GET_DBNAME:
1805 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1809 case CTDB_CONTROL_DUMP_MEMORY:
1810 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1814 case CTDB_CONTROL_GET_PID:
1817 case CTDB_CONTROL_GET_RECMASTER:
1820 case CTDB_CONTROL_GET_TUNABLE:
1821 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1822 &cd->data.tun_value);
1825 case CTDB_CONTROL_LIST_TUNABLES:
1826 ret = ctdb_var_list_pull(buf, buflen, mem_ctx,
1827 &cd->data.tun_var_list);
1830 case CTDB_CONTROL_GET_ALL_TUNABLES:
1831 ret = ctdb_tunable_list_pull(buf, buflen, mem_ctx,
1832 &cd->data.tun_list);
1835 case CTDB_CONTROL_GET_TCP_TICKLE_LIST:
1836 ret = ctdb_tickle_list_pull(buf, buflen, mem_ctx,
1840 case CTDB_CONTROL_GET_SERVER_ID_LIST:
1841 ret = ctdb_client_id_map_pull(buf, buflen, mem_ctx,
1845 case CTDB_CONTROL_DB_ATTACH_PERSISTENT:
1846 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1850 case CTDB_CONTROL_UPTIME:
1851 ret = ctdb_uptime_pull(buf, buflen, mem_ctx,
1855 case CTDB_CONTROL_TRY_DELETE_RECORDS:
1856 ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
1860 case CTDB_CONTROL_GET_CAPABILITIES:
1861 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1865 case CTDB_CONTROL_GET_PUBLIC_IPS:
1866 ret = ctdb_public_ip_list_pull(buf, buflen, mem_ctx,
1867 &cd->data.pubip_list);
1870 case CTDB_CONTROL_GET_NODEMAP:
1871 ret = ctdb_node_map_pull(buf, buflen, mem_ctx,
1875 case CTDB_CONTROL_GET_EVENT_SCRIPT_STATUS:
1876 ret = ctdb_script_list_pull(buf, buflen, mem_ctx,
1877 &cd->data.script_list);
1880 case CTDB_CONTROL_GET_RECLOCK_FILE:
1881 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1882 &cd->data.reclock_file);
1885 case CTDB_CONTROL_GET_BAN_STATE:
1886 ret = ctdb_ban_state_pull(buf, buflen, mem_ctx,
1887 &cd->data.ban_state);
1890 case CTDB_CONTROL_GET_DB_PRIORITY:
1893 case CTDB_CONTROL_GET_DB_SEQNUM:
1894 ret = ctdb_uint64_pull(buf, buflen, mem_ctx,
1898 case CTDB_CONTROL_DB_GET_HEALTH:
1899 ret = ctdb_string_pull(buf, buflen, mem_ctx,
1903 case CTDB_CONTROL_GET_PUBLIC_IP_INFO:
1904 ret = ctdb_public_ip_info_pull(buf, buflen, mem_ctx,
1908 case CTDB_CONTROL_GET_IFACES:
1909 ret = ctdb_iface_list_pull(buf, buflen, mem_ctx,
1910 &cd->data.iface_list);
1913 case CTDB_CONTROL_GET_STAT_HISTORY:
1914 ret = ctdb_statistics_list_pull(buf, buflen, mem_ctx,
1915 &cd->data.stats_list);
1918 case CTDB_CONTROL_CHECK_SRVIDS:
1919 ret = ctdb_uint8_array_pull(buf, buflen, mem_ctx,
1920 &cd->data.u8_array);
1923 case CTDB_CONTROL_GET_DB_STATISTICS:
1924 ret = ctdb_db_statistics_pull(buf, buflen, mem_ctx,
1928 case CTDB_CONTROL_RECEIVE_RECORDS:
1929 ret = ctdb_rec_buffer_pull(buf, buflen, mem_ctx,
1933 case CTDB_CONTROL_GET_RUNSTATE:
1934 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1935 &cd->data.runstate);
1938 case CTDB_CONTROL_GET_NODES_FILE:
1939 ret = ctdb_node_map_pull(buf, buflen, mem_ctx,
1943 case CTDB_CONTROL_DB_PULL:
1944 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1945 &cd->data.num_records);
1948 case CTDB_CONTROL_DB_PUSH_CONFIRM:
1949 ret = ctdb_uint32_pull(buf, buflen, mem_ctx,
1950 &cd->data.num_records);
1957 int ctdb_req_control_push(struct ctdb_req_header *h,
1958 struct ctdb_req_control *request,
1959 TALLOC_CTX *mem_ctx,
1960 uint8_t **pkt, size_t *pkt_len)
1962 struct ctdb_req_control_wire *wire;
1964 size_t length, buflen, datalen;
1967 datalen = ctdb_req_control_data_len(&request->rdata);
1968 length = offsetof(struct ctdb_req_control_wire, data) + datalen;
1970 ret = allocate_pkt(mem_ctx, length, &buf, &buflen);
1975 wire = (struct ctdb_req_control_wire *)buf;
1978 memcpy(&wire->hdr, h, sizeof(struct ctdb_req_header));
1980 wire->opcode = request->opcode;
1981 wire->pad = request->pad;
1982 wire->srvid = request->srvid;
1983 wire->client_id = request->client_id;
1984 wire->flags = request->flags;
1986 wire->datalen = datalen;
1987 ctdb_req_control_data_push(&request->rdata, wire->data);
1994 int ctdb_req_control_pull(uint8_t *pkt, size_t pkt_len,
1995 struct ctdb_req_header *h,
1996 TALLOC_CTX *mem_ctx,
1997 struct ctdb_req_control *request)
1999 struct ctdb_req_control_wire *wire =
2000 (struct ctdb_req_control_wire *)pkt;
2004 length = offsetof(struct ctdb_req_control_wire, data);
2005 if (pkt_len < length) {
2008 if (pkt_len < length + wire->datalen) {
2013 memcpy(h, &wire->hdr, sizeof(struct ctdb_req_header));
2016 request->opcode = wire->opcode;
2017 request->pad = wire->pad;
2018 request->srvid = wire->srvid;
2019 request->client_id = wire->client_id;
2020 request->flags = wire->flags;
2022 ret = ctdb_req_control_data_pull(wire->data, wire->datalen,
2023 request->opcode, mem_ctx,
2032 int ctdb_reply_control_push(struct ctdb_req_header *h,
2033 struct ctdb_reply_control *reply,
2034 TALLOC_CTX *mem_ctx,
2035 uint8_t **pkt, size_t *pkt_len)
2037 struct ctdb_reply_control_wire *wire;
2039 size_t length, buflen, datalen, errlen;
2042 if (reply->status == 0) {
2043 datalen = ctdb_reply_control_data_len(&reply->rdata);
2048 if (reply->errmsg == NULL) {
2051 errlen = strlen(reply->errmsg) + 1;
2054 length = offsetof(struct ctdb_reply_control_wire, data) +
2057 ret = allocate_pkt(mem_ctx, length, &buf, &buflen);
2062 wire = (struct ctdb_reply_control_wire *)buf;
2065 memcpy(&wire->hdr, h, sizeof(struct ctdb_req_header));
2067 wire->status = reply->status;
2069 wire->datalen = datalen;
2070 if (reply->status == 0) {
2071 ctdb_reply_control_data_push(&reply->rdata, wire->data);
2074 wire->errorlen = errlen;
2076 memcpy(wire->data + datalen, reply->errmsg, wire->errorlen);
2084 int ctdb_reply_control_pull(uint8_t *pkt, size_t pkt_len, uint32_t opcode,
2085 struct ctdb_req_header *h,
2086 TALLOC_CTX *mem_ctx,
2087 struct ctdb_reply_control *reply)
2089 struct ctdb_reply_control_wire *wire =
2090 (struct ctdb_reply_control_wire *)pkt;
2094 length = offsetof(struct ctdb_reply_control_wire, data);
2096 if (pkt_len < length) {
2099 if (pkt_len < length + wire->datalen + wire->errorlen) {
2104 memcpy(h, &wire->hdr, sizeof(struct ctdb_req_header));
2107 reply->status = wire->status;
2109 if (reply->status != -1) {
2110 ret = ctdb_reply_control_data_pull(wire->data, wire->datalen,
2118 if (wire->errorlen > 0) {
2119 reply->errmsg = talloc_memdup(mem_ctx,
2120 wire->data + wire->datalen,
2123 reply->errmsg = NULL;