mirror of
https://github.com/samba-team/samba.git
synced 2025-01-10 01:18:15 +03:00
ctdb-protocol: Add a generic packet header
This will avoid duplication when new daemons (and new client-server protocols) are created out of the main ctdb daemon. Signed-off-by: Amitay Isaacs <amitay@gmail.com> Reviewed-by: Martin Schwenke <martin@meltin.net>
This commit is contained in:
parent
15c91774d9
commit
1787a4b632
@ -1007,6 +1007,15 @@ struct ctdb_g_lock_list {
|
|||||||
struct ctdb_g_lock *lock;
|
struct ctdb_g_lock *lock;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Generic packet header
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct sock_packet_header {
|
||||||
|
uint32_t length;
|
||||||
|
uint32_t reqid;
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Eventd protocol
|
* Eventd protocol
|
||||||
*/
|
*/
|
||||||
|
@ -677,6 +677,19 @@ int ctdb_event_reply_pull(uint8_t *buf, size_t buflen,
|
|||||||
int ctdb_allocate_pkt(TALLOC_CTX *mem_ctx, size_t datalen,
|
int ctdb_allocate_pkt(TALLOC_CTX *mem_ctx, size_t datalen,
|
||||||
uint8_t **buf, size_t *buflen);
|
uint8_t **buf, size_t *buflen);
|
||||||
|
|
||||||
|
/* From protocol/protocol_sock.c */
|
||||||
|
|
||||||
|
size_t sock_packet_header_len(struct sock_packet_header *in);
|
||||||
|
void sock_packet_header_push(struct sock_packet_header *in, uint8_t *buf,
|
||||||
|
size_t *npush);
|
||||||
|
int sock_packet_header_pull(uint8_t *buf, size_t buflen,
|
||||||
|
struct sock_packet_header *out, size_t *npull);
|
||||||
|
|
||||||
|
void sock_packet_header_set_reqid(struct sock_packet_header *h,
|
||||||
|
uint32_t reqid);
|
||||||
|
void sock_packet_header_set_length(struct sock_packet_header *h,
|
||||||
|
uint32_t length);
|
||||||
|
|
||||||
/* From protocol/protocol_util.c */
|
/* From protocol/protocol_util.c */
|
||||||
|
|
||||||
const char *ctdb_runstate_to_string(enum ctdb_runstate runstate);
|
const char *ctdb_runstate_to_string(enum ctdb_runstate runstate);
|
||||||
|
81
ctdb/protocol/protocol_sock.c
Normal file
81
ctdb/protocol/protocol_sock.c
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
/*
|
||||||
|
CTDB generic sock packet marshalling
|
||||||
|
|
||||||
|
Copyright (C) Amitay Isaacs 2017
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "replace.h"
|
||||||
|
#include "system/network.h"
|
||||||
|
|
||||||
|
#include <talloc.h>
|
||||||
|
|
||||||
|
#include "protocol.h"
|
||||||
|
#include "protocol_private.h"
|
||||||
|
#include "protocol_api.h"
|
||||||
|
|
||||||
|
size_t sock_packet_header_len(struct sock_packet_header *in)
|
||||||
|
{
|
||||||
|
return ctdb_uint32_len(&in->length) +
|
||||||
|
ctdb_uint32_len(&in->reqid);
|
||||||
|
}
|
||||||
|
|
||||||
|
void sock_packet_header_push(struct sock_packet_header *in, uint8_t *buf,
|
||||||
|
size_t *npush)
|
||||||
|
{
|
||||||
|
size_t offset = 0, np;
|
||||||
|
|
||||||
|
ctdb_uint32_push(&in->length, buf+offset, &np);
|
||||||
|
offset += np;
|
||||||
|
|
||||||
|
ctdb_uint32_push(&in->reqid, buf+offset, &np);
|
||||||
|
offset += np;
|
||||||
|
|
||||||
|
*npush = offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
int sock_packet_header_pull(uint8_t *buf, size_t buflen,
|
||||||
|
struct sock_packet_header *out, size_t *npull)
|
||||||
|
{
|
||||||
|
size_t offset = 0, np;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = ctdb_uint32_pull(buf+offset, buflen-offset, &out->length, &np);
|
||||||
|
if (ret != 0) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
offset += np;
|
||||||
|
|
||||||
|
ret = ctdb_uint32_pull(buf+offset, buflen-offset, &out->reqid, &np);
|
||||||
|
if (ret != 0) {
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
offset += np;
|
||||||
|
|
||||||
|
*npull = offset;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sock_packet_header_set_reqid(struct sock_packet_header *h,
|
||||||
|
uint32_t reqid)
|
||||||
|
{
|
||||||
|
h->reqid = reqid;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sock_packet_header_set_length(struct sock_packet_header *h,
|
||||||
|
uint32_t length)
|
||||||
|
{
|
||||||
|
h->length = length;
|
||||||
|
}
|
@ -1383,3 +1383,16 @@ void verify_ctdb_g_lock_list(struct ctdb_g_lock_list *p1,
|
|||||||
verify_ctdb_g_lock(&p1->lock[i], &p2->lock[i]);
|
verify_ctdb_g_lock(&p1->lock[i], &p2->lock[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void fill_sock_packet_header(struct sock_packet_header *p)
|
||||||
|
{
|
||||||
|
p->length = rand32();
|
||||||
|
p->reqid = rand32();
|
||||||
|
}
|
||||||
|
|
||||||
|
void verify_sock_packet_header(struct sock_packet_header *p1,
|
||||||
|
struct sock_packet_header *p2)
|
||||||
|
{
|
||||||
|
assert(p1->length == p2->length);
|
||||||
|
assert(p1->reqid == p2->reqid);
|
||||||
|
}
|
||||||
|
@ -350,4 +350,8 @@ void fill_ctdb_g_lock_list(TALLOC_CTX *mem_ctx, struct ctdb_g_lock_list *p);
|
|||||||
void verify_ctdb_g_lock_list(struct ctdb_g_lock_list *p1,
|
void verify_ctdb_g_lock_list(struct ctdb_g_lock_list *p1,
|
||||||
struct ctdb_g_lock_list *p2);
|
struct ctdb_g_lock_list *p2);
|
||||||
|
|
||||||
|
void fill_sock_packet_header(struct sock_packet_header *p);
|
||||||
|
void verify_sock_packet_header(struct sock_packet_header *p1,
|
||||||
|
struct sock_packet_header *p2);
|
||||||
|
|
||||||
#endif /* __CTDB_PROTOCOL_COMMON_H__ */
|
#endif /* __CTDB_PROTOCOL_COMMON_H__ */
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
|
|
||||||
#include "protocol/protocol_basic.c"
|
#include "protocol/protocol_basic.c"
|
||||||
#include "protocol/protocol_types.c"
|
#include "protocol/protocol_types.c"
|
||||||
|
#include "protocol/protocol_sock.c"
|
||||||
|
|
||||||
#include "tests/src/protocol_common.h"
|
#include "tests/src/protocol_common.h"
|
||||||
|
|
||||||
@ -75,6 +76,8 @@ PROTOCOL_TYPE1_TEST(struct ctdb_server_id, ctdb_server_id);
|
|||||||
PROTOCOL_TYPE1_TEST(struct ctdb_g_lock, ctdb_g_lock);
|
PROTOCOL_TYPE1_TEST(struct ctdb_g_lock, ctdb_g_lock);
|
||||||
PROTOCOL_TYPE3_TEST(struct ctdb_g_lock_list, ctdb_g_lock_list);
|
PROTOCOL_TYPE3_TEST(struct ctdb_g_lock_list, ctdb_g_lock_list);
|
||||||
|
|
||||||
|
PROTOCOL_TYPE1_TEST(struct sock_packet_header, sock_packet_header);
|
||||||
|
|
||||||
static void test_ctdb_rec_buffer_read_write(void)
|
static void test_ctdb_rec_buffer_read_write(void)
|
||||||
{
|
{
|
||||||
TALLOC_CTX *mem_ctx = talloc_new(NULL);
|
TALLOC_CTX *mem_ctx = talloc_new(NULL);
|
||||||
@ -176,6 +179,8 @@ int main(int argc, char *argv[])
|
|||||||
TEST_FUNC(ctdb_g_lock)();
|
TEST_FUNC(ctdb_g_lock)();
|
||||||
TEST_FUNC(ctdb_g_lock_list)();
|
TEST_FUNC(ctdb_g_lock_list)();
|
||||||
|
|
||||||
|
TEST_FUNC(sock_packet_header)();
|
||||||
|
|
||||||
test_ctdb_rec_buffer_read_write();
|
test_ctdb_rec_buffer_read_write();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -400,7 +400,8 @@ def build(bld):
|
|||||||
protocol_client.c
|
protocol_client.c
|
||||||
protocol_debug.c
|
protocol_debug.c
|
||||||
protocol_util.c
|
protocol_util.c
|
||||||
protocol_event.c'''),
|
protocol_event.c
|
||||||
|
protocol_sock.c'''),
|
||||||
includes='include',
|
includes='include',
|
||||||
deps='replace talloc tdb')
|
deps='replace talloc tdb')
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user