4 Copyright (C) Andrew Tridgell 2006
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 "lib/util/dlinklist.h"
23 #include "system/network.h"
24 #include "system/filesys.h"
25 #include "../include/ctdb_private.h"
30 called when a complete packet has come in
32 void ctdb_tcp_read_cb(uint8_t *data
, size_t cnt
, void *args
)
34 struct ctdb_incoming
*in
= talloc_get_type(args
, struct ctdb_incoming
);
35 struct ctdb_req_header
*hdr
= (struct ctdb_req_header
*)data
;
38 /* incoming socket has died */
42 if (cnt
< sizeof(*hdr
)) {
43 DEBUG(DEBUG_ALERT
,(__location__
" Bad packet length %u\n", (unsigned)cnt
));
47 if (cnt
& (CTDB_TCP_ALIGNMENT
-1)) {
48 DEBUG(DEBUG_ALERT
,(__location__
" Length 0x%x not multiple of alignment\n",
54 if (cnt
!= hdr
->length
) {
55 DEBUG(DEBUG_ALERT
,(__location__
" Bad header length %u expected %u\n",
56 (unsigned)hdr
->length
, (unsigned)cnt
));
60 if (hdr
->ctdb_magic
!= CTDB_MAGIC
) {
61 DEBUG(DEBUG_ALERT
,(__location__
" Non CTDB packet 0x%x rejected\n",
66 if (hdr
->ctdb_version
!= CTDB_PROTOCOL
) {
67 DEBUG(DEBUG_ALERT
, (__location__
" Bad CTDB version 0x%x rejected\n",
72 /* tell the ctdb layer above that we have a packet */
73 in
->ctdb
->upcalls
->recv_pkt(in
->ctdb
, data
, cnt
);
81 queue a packet for sending
83 int ctdb_tcp_queue_pkt(struct ctdb_node
*node
, uint8_t *data
, uint32_t length
)
85 struct ctdb_tcp_node
*tnode
= talloc_get_type(node
->private_data
,
86 struct ctdb_tcp_node
);
87 return ctdb_queue_send(tnode
->out_queue
, data
, length
);