2015-04-14 17:20:05 +10:00
/*
CTDB protocol marshalling
Copyright ( C ) Amitay Isaacs 2015
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 <tdb.h>
# include "protocol.h"
# include "protocol_api.h"
# include "protocol_private.h"
2016-04-22 00:45:01 +10:00
size_t ctdb_req_call_len ( struct ctdb_req_header * h , struct ctdb_req_call * c )
{
2017-07-19 14:30:47 +10:00
return ctdb_req_header_len ( h ) +
ctdb_uint32_len ( & c - > flags ) +
ctdb_uint32_len ( & c - > db_id ) +
ctdb_uint32_len ( & c - > callid ) +
ctdb_uint32_len ( & c - > hopcount ) +
ctdb_tdb_datan_len ( & c - > key ) +
ctdb_tdb_datan_len ( & c - > calldata ) ;
2016-04-22 00:45:01 +10:00
}
2015-04-14 17:20:05 +10:00
int ctdb_req_call_push ( struct ctdb_req_header * h , struct ctdb_req_call * c ,
2016-05-01 22:13:35 +10:00
uint8_t * buf , size_t * buflen )
2015-04-14 17:20:05 +10:00
{
2017-07-19 14:30:47 +10:00
size_t offset = 0 ;
2017-06-30 17:15:47 +10:00
size_t length , np ;
2017-07-19 14:30:47 +10:00
uint32_t u32 ;
2015-04-14 17:20:05 +10:00
if ( c - > key . dsize = = 0 ) {
return EINVAL ;
}
2016-04-29 15:35:12 +10:00
length = ctdb_req_call_len ( h , c ) ;
2016-05-01 22:13:35 +10:00
if ( * buflen < length ) {
* buflen = length ;
2016-04-22 01:08:11 +10:00
return EMSGSIZE ;
2015-04-14 17:20:05 +10:00
}
2016-05-01 22:13:35 +10:00
h - > length = * buflen ;
2017-07-19 14:30:47 +10:00
ctdb_req_header_push ( h , buf + offset , & np ) ;
offset + = np ;
ctdb_uint32_push ( & c - > flags , buf + offset , & np ) ;
offset + = np ;
ctdb_uint32_push ( & c - > db_id , buf + offset , & np ) ;
offset + = np ;
ctdb_uint32_push ( & c - > callid , buf + offset , & np ) ;
offset + = np ;
ctdb_uint32_push ( & c - > hopcount , buf + offset , & np ) ;
offset + = np ;
u32 = ctdb_tdb_data_len ( & c - > key ) ;
ctdb_uint32_push ( & u32 , buf + offset , & np ) ;
offset + = np ;
u32 = ctdb_tdb_data_len ( & c - > calldata ) ;
ctdb_uint32_push ( & u32 , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:30:47 +10:00
ctdb_tdb_data_push ( & c - > key , buf + offset , & np ) ;
offset + = np ;
ctdb_tdb_data_push ( & c - > calldata , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 01:25:06 +10:00
int ctdb_req_call_pull ( uint8_t * buf , size_t buflen ,
2015-04-14 17:20:05 +10:00
struct ctdb_req_header * h ,
TALLOC_CTX * mem_ctx ,
struct ctdb_req_call * c )
{
2017-07-19 14:30:47 +10:00
struct ctdb_req_header header ;
size_t offset = 0 , np ;
uint32_t u32 ;
2016-04-21 23:50:01 +10:00
int ret ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:30:47 +10:00
ret = ctdb_req_header_pull ( buf + offset , buflen - offset , & header , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:30:47 +10:00
offset + = np ;
if ( h ! = NULL ) {
* h = header ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 14:30:47 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & c - > flags , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 14:30:47 +10:00
offset + = np ;
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & c - > db_id , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 14:30:47 +10:00
offset + = np ;
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & c - > callid , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:30:47 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:30:47 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & c - > hopcount , & np ) ;
if ( ret ! = 0 ) {
return ret ;
}
offset + = np ;
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & u32 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
}
offset + = np ;
c - > key . dsize = u32 ;
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & u32 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-03-10 15:43:37 +11:00
}
2017-07-19 14:30:47 +10:00
offset + = np ;
c - > calldata . dsize = u32 ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:30:47 +10:00
if ( buflen - offset < c - > key . dsize ) {
return EMSGSIZE ;
}
2016-04-21 23:50:01 +10:00
2017-07-19 14:30:47 +10:00
ret = ctdb_tdb_data_pull ( buf + offset , c - > key . dsize , mem_ctx , & c - > key ,
2017-06-30 17:15:47 +10:00
& np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:30:47 +10:00
offset + = np ;
if ( buflen - offset < c - > calldata . dsize ) {
return EMSGSIZE ;
}
2016-04-21 23:50:01 +10:00
2017-07-19 14:30:47 +10:00
ret = ctdb_tdb_data_pull ( buf + offset , c - > calldata . dsize ,
2017-06-30 17:15:47 +10:00
mem_ctx , & c - > calldata , & np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:30:47 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 00:45:01 +10:00
size_t ctdb_reply_call_len ( struct ctdb_req_header * h ,
struct ctdb_reply_call * c )
{
2017-07-19 14:36:45 +10:00
return ctdb_req_header_len ( h ) +
ctdb_int32_len ( & c - > status ) +
ctdb_tdb_datan_len ( & c - > data ) ;
2016-04-22 00:45:01 +10:00
}
2015-04-14 17:20:05 +10:00
int ctdb_reply_call_push ( struct ctdb_req_header * h , struct ctdb_reply_call * c ,
2016-05-01 22:13:35 +10:00
uint8_t * buf , size_t * buflen )
2015-04-14 17:20:05 +10:00
{
2017-07-19 14:36:45 +10:00
size_t offset = 0 , np ;
size_t length ;
2015-04-14 17:20:05 +10:00
2016-04-29 15:35:12 +10:00
length = ctdb_reply_call_len ( h , c ) ;
2016-05-01 22:13:35 +10:00
if ( * buflen < length ) {
* buflen = length ;
2016-04-22 01:08:11 +10:00
return EMSGSIZE ;
2015-04-14 17:20:05 +10:00
}
2016-05-01 22:13:35 +10:00
h - > length = * buflen ;
2017-07-19 14:36:45 +10:00
ctdb_req_header_push ( h , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:36:45 +10:00
ctdb_int32_push ( & c - > status , buf + offset , & np ) ;
offset + = np ;
ctdb_tdb_datan_push ( & c - > data , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 01:25:06 +10:00
int ctdb_reply_call_pull ( uint8_t * buf , size_t buflen ,
2015-04-14 17:20:05 +10:00
struct ctdb_req_header * h ,
TALLOC_CTX * mem_ctx ,
struct ctdb_reply_call * c )
{
2017-07-19 14:36:45 +10:00
struct ctdb_req_header header ;
size_t offset = 0 , np ;
2016-04-21 23:50:01 +10:00
int ret ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:36:45 +10:00
ret = ctdb_req_header_pull ( buf + offset , buflen - offset , & header , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:36:45 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
2016-03-10 15:43:37 +11:00
if ( h ! = NULL ) {
2017-07-19 14:36:45 +10:00
* h = header ;
2016-03-10 15:43:37 +11:00
}
2015-04-14 17:20:05 +10:00
2017-07-19 14:36:45 +10:00
ret = ctdb_int32_pull ( buf + offset , buflen - offset , & c - > status , & np ) ;
if ( ret ! = 0 ) {
return ret ;
}
offset + = np ;
2016-04-21 23:50:01 +10:00
2017-07-19 14:36:45 +10:00
ret = ctdb_tdb_datan_pull ( buf + offset , buflen - offset ,
mem_ctx , & c - > data , & np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:36:45 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 00:45:01 +10:00
size_t ctdb_reply_error_len ( struct ctdb_req_header * h ,
struct ctdb_reply_error * c )
{
2017-07-19 14:41:45 +10:00
return ctdb_req_header_len ( h ) +
ctdb_int32_len ( & c - > status ) +
ctdb_tdb_datan_len ( & c - > msg ) ;
2016-04-22 00:45:01 +10:00
}
2015-04-14 17:20:05 +10:00
int ctdb_reply_error_push ( struct ctdb_req_header * h , struct ctdb_reply_error * c ,
2016-05-01 22:13:35 +10:00
uint8_t * buf , size_t * buflen )
2015-04-14 17:20:05 +10:00
{
2017-07-19 14:41:45 +10:00
size_t offset = 0 , np ;
size_t length ;
2015-04-14 17:20:05 +10:00
2016-04-29 15:35:12 +10:00
length = ctdb_reply_error_len ( h , c ) ;
2016-05-01 22:13:35 +10:00
if ( * buflen < length ) {
* buflen = length ;
2016-04-22 01:08:11 +10:00
return EMSGSIZE ;
2015-04-14 17:20:05 +10:00
}
2016-05-01 22:13:35 +10:00
h - > length = * buflen ;
2017-07-19 14:41:45 +10:00
ctdb_req_header_push ( h , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:41:45 +10:00
ctdb_int32_push ( & c - > status , buf + offset , & np ) ;
offset + = np ;
ctdb_tdb_datan_push ( & c - > msg , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 01:25:06 +10:00
int ctdb_reply_error_pull ( uint8_t * buf , size_t buflen ,
2015-04-14 17:20:05 +10:00
struct ctdb_req_header * h ,
TALLOC_CTX * mem_ctx ,
struct ctdb_reply_error * c )
{
2017-07-19 14:41:45 +10:00
struct ctdb_req_header header ;
size_t offset = 0 , np ;
2016-04-21 23:50:01 +10:00
int ret ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:41:45 +10:00
ret = ctdb_req_header_pull ( buf + offset , buflen - offset , & header , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:41:45 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
2016-03-10 15:43:37 +11:00
if ( h ! = NULL ) {
2017-07-19 14:41:45 +10:00
* h = header ;
2016-03-10 15:43:37 +11:00
}
2015-04-14 17:20:05 +10:00
2017-07-19 14:41:45 +10:00
ret = ctdb_int32_pull ( buf + offset , buflen - offset , & c - > status , & np ) ;
if ( ret ! = 0 ) {
return ret ;
}
offset + = np ;
2016-04-21 23:50:01 +10:00
2017-07-19 14:41:45 +10:00
ret = ctdb_tdb_datan_pull ( buf + offset , buflen - offset , mem_ctx , & c - > msg ,
& np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:41:45 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 00:45:01 +10:00
size_t ctdb_req_dmaster_len ( struct ctdb_req_header * h ,
struct ctdb_req_dmaster * c )
{
2017-07-19 14:58:21 +10:00
return ctdb_req_header_len ( h ) +
ctdb_uint32_len ( & c - > db_id ) +
ctdb_padding_len ( 4 ) +
ctdb_uint64_len ( & c - > rsn ) +
ctdb_uint32_len ( & c - > dmaster ) +
ctdb_tdb_datan_len ( & c - > key ) +
ctdb_tdb_datan_len ( & c - > data ) ;
2016-04-22 00:45:01 +10:00
}
2015-04-14 17:20:05 +10:00
int ctdb_req_dmaster_push ( struct ctdb_req_header * h , struct ctdb_req_dmaster * c ,
2016-05-01 22:13:35 +10:00
uint8_t * buf , size_t * buflen )
2015-04-14 17:20:05 +10:00
{
2017-07-19 14:58:21 +10:00
size_t offset = 0 , np ;
size_t length ;
uint32_t u32 ;
2015-04-14 17:20:05 +10:00
2016-04-29 15:35:12 +10:00
length = ctdb_req_dmaster_len ( h , c ) ;
2016-05-01 22:13:35 +10:00
if ( * buflen < length ) {
* buflen = length ;
2016-04-22 01:08:11 +10:00
return EMSGSIZE ;
2015-04-14 17:20:05 +10:00
}
2016-05-01 22:13:35 +10:00
h - > length = * buflen ;
2017-07-19 14:58:21 +10:00
ctdb_req_header_push ( h , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:58:21 +10:00
ctdb_uint32_push ( & c - > db_id , buf + offset , & np ) ;
offset + = np ;
ctdb_padding_push ( 4 , buf + offset , & np ) ;
offset + = np ;
ctdb_uint64_push ( & c - > rsn , buf + offset , & np ) ;
offset + = np ;
ctdb_uint32_push ( & c - > dmaster , buf + offset , & np ) ;
offset + = np ;
u32 = ctdb_tdb_data_len ( & c - > key ) ;
ctdb_uint32_push ( & u32 , buf + offset , & np ) ;
offset + = np ;
u32 = ctdb_tdb_data_len ( & c - > data ) ;
ctdb_uint32_push ( & u32 , buf + offset , & np ) ;
offset + = np ;
ctdb_tdb_data_push ( & c - > key , buf + offset , & np ) ;
offset + = np ;
ctdb_tdb_data_push ( & c - > data , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 01:25:06 +10:00
int ctdb_req_dmaster_pull ( uint8_t * buf , size_t buflen ,
2015-04-14 17:20:05 +10:00
struct ctdb_req_header * h ,
TALLOC_CTX * mem_ctx ,
struct ctdb_req_dmaster * c )
{
2017-07-19 14:58:21 +10:00
struct ctdb_req_header header ;
size_t offset = 0 , np ;
uint32_t u32 ;
2016-04-21 23:50:01 +10:00
int ret ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:58:21 +10:00
ret = ctdb_req_header_pull ( buf + offset , buflen - offset , & header , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:58:21 +10:00
offset + = np ;
if ( h ! = NULL ) {
* h = header ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 14:58:21 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & c - > db_id , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 14:58:21 +10:00
offset + = np ;
ret = ctdb_padding_pull ( buf + offset , buflen - offset , 4 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 14:58:21 +10:00
offset + = np ;
ret = ctdb_uint64_pull ( buf + offset , buflen - offset , & c - > rsn , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:58:21 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:58:21 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & c - > dmaster , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-03-10 15:43:37 +11:00
}
2017-07-19 14:58:21 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 14:58:21 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & u32 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
}
offset + = np ;
c - > key . dsize = u32 ;
2016-04-21 23:50:01 +10:00
2017-07-19 14:58:21 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & u32 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
}
offset + = np ;
c - > data . dsize = u32 ;
if ( buflen - offset < c - > key . dsize ) {
return EMSGSIZE ;
}
ret = ctdb_tdb_data_pull ( buf + offset , c - > key . dsize , mem_ctx , & c - > key ,
2017-06-30 17:15:47 +10:00
& np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:58:21 +10:00
offset + = np ;
if ( buflen - offset < c - > data . dsize ) {
return EMSGSIZE ;
}
2016-04-21 23:50:01 +10:00
2017-07-19 14:58:21 +10:00
ret = ctdb_tdb_data_pull ( buf + offset , c - > data . dsize , mem_ctx , & c - > data ,
& np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 14:58:21 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 00:45:01 +10:00
size_t ctdb_reply_dmaster_len ( struct ctdb_req_header * h ,
struct ctdb_reply_dmaster * c )
{
2017-07-19 15:08:21 +10:00
return ctdb_req_header_len ( h ) +
ctdb_uint32_len ( & c - > db_id ) +
ctdb_padding_len ( 4 ) +
ctdb_uint64_len ( & c - > rsn ) +
ctdb_tdb_datan_len ( & c - > key ) +
ctdb_tdb_datan_len ( & c - > data ) ;
2016-04-22 00:45:01 +10:00
}
2015-04-14 17:20:05 +10:00
int ctdb_reply_dmaster_push ( struct ctdb_req_header * h ,
struct ctdb_reply_dmaster * c ,
2016-05-01 22:13:35 +10:00
uint8_t * buf , size_t * buflen )
2015-04-14 17:20:05 +10:00
{
2017-07-19 15:08:21 +10:00
size_t offset = 0 , np ;
size_t length ;
uint32_t u32 ;
2015-04-14 17:20:05 +10:00
2016-04-29 15:35:12 +10:00
length = ctdb_reply_dmaster_len ( h , c ) ;
2016-05-01 22:13:35 +10:00
if ( * buflen < length ) {
* buflen = length ;
2016-04-22 01:08:11 +10:00
return EMSGSIZE ;
2015-04-14 17:20:05 +10:00
}
2016-05-01 22:13:35 +10:00
h - > length = * buflen ;
2017-07-19 15:08:21 +10:00
ctdb_req_header_push ( h , buf + offset , & np ) ;
offset + = np ;
ctdb_uint32_push ( & c - > db_id , buf + offset , & np ) ;
offset + = np ;
ctdb_padding_push ( 4 , buf + offset , & np ) ;
offset + = np ;
ctdb_uint64_push ( & c - > rsn , buf + offset , & np ) ;
offset + = np ;
u32 = ctdb_tdb_data_len ( & c - > key ) ;
ctdb_uint32_push ( & u32 , buf + offset , & np ) ;
offset + = np ;
u32 = ctdb_tdb_data_len ( & c - > data ) ;
ctdb_uint32_push ( & u32 , buf + offset , & np ) ;
offset + = np ;
ctdb_tdb_data_push ( & c - > key , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 15:08:21 +10:00
ctdb_tdb_data_push ( & c - > data , buf + offset , & np ) ;
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}
2016-04-22 01:25:06 +10:00
int ctdb_reply_dmaster_pull ( uint8_t * buf , size_t buflen ,
2015-04-14 17:20:05 +10:00
struct ctdb_req_header * h ,
TALLOC_CTX * mem_ctx ,
struct ctdb_reply_dmaster * c )
{
2017-07-19 15:08:21 +10:00
struct ctdb_req_header header ;
size_t offset = 0 , np ;
uint32_t u32 ;
2016-04-21 23:50:01 +10:00
int ret ;
2015-04-14 17:20:05 +10:00
2017-07-19 15:08:21 +10:00
ret = ctdb_req_header_pull ( buf + offset , buflen - offset , & header , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 15:08:21 +10:00
offset + = np ;
if ( h ! = NULL ) {
* h = header ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 15:08:21 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & c - > db_id , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 15:08:21 +10:00
offset + = np ;
ret = ctdb_padding_pull ( buf + offset , buflen - offset , 4 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-05-03 12:53:24 +10:00
}
2017-07-19 15:08:21 +10:00
offset + = np ;
ret = ctdb_uint64_pull ( buf + offset , buflen - offset , & c - > rsn , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 15:08:21 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
2017-07-19 15:08:21 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & u32 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
2016-03-10 15:43:37 +11:00
}
2017-07-19 15:08:21 +10:00
offset + = np ;
c - > key . dsize = u32 ;
2015-04-14 17:20:05 +10:00
2017-07-19 15:08:21 +10:00
ret = ctdb_uint32_pull ( buf + offset , buflen - offset , & u32 , & np ) ;
if ( ret ! = 0 ) {
return ret ;
}
offset + = np ;
c - > data . dsize = u32 ;
if ( buflen - offset < c - > key . dsize ) {
return EMSGSIZE ;
}
2016-04-21 23:50:01 +10:00
2017-07-19 15:08:21 +10:00
ret = ctdb_tdb_data_pull ( buf + offset , c - > key . dsize , mem_ctx , & c - > key ,
2017-06-30 17:15:47 +10:00
& np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 15:08:21 +10:00
offset + = np ;
2016-04-21 23:50:01 +10:00
2017-07-19 15:08:21 +10:00
if ( buflen - offset < c - > data . dsize ) {
return EMSGSIZE ;
}
ret = ctdb_tdb_data_pull ( buf + offset , c - > data . dsize , mem_ctx , & c - > data ,
& np ) ;
2016-04-21 23:50:01 +10:00
if ( ret ! = 0 ) {
return ret ;
2015-04-14 17:20:05 +10:00
}
2017-07-19 15:08:21 +10:00
offset + = np ;
2015-04-14 17:20:05 +10:00
return 0 ;
}