mirror of
https://github.com/samba-team/samba.git
synced 2025-01-11 05:18:09 +03:00
another place where we could send a partial packet
(This used to be ctdb commit 4e0c57718a0c9f51b5b2e02bbf516c63c5be0a35)
This commit is contained in:
parent
53586a4a74
commit
dcd23d47a7
@ -225,7 +225,7 @@ static void queue_io_handler(struct event_context *ev, struct fd_event *fde,
|
||||
int ctdb_queue_send(struct ctdb_queue *queue, uint8_t *data, uint32_t length)
|
||||
{
|
||||
struct ctdb_queue_pkt *pkt;
|
||||
uint32_t length2;
|
||||
uint32_t length2, full_length;
|
||||
|
||||
if (queue->alignment) {
|
||||
/* enforce the length and alignment rules from the tcp packet allocator */
|
||||
@ -238,6 +238,8 @@ int ctdb_queue_send(struct ctdb_queue *queue, uint8_t *data, uint32_t length)
|
||||
if (length2 != length) {
|
||||
memset(data+length, 0, length2-length);
|
||||
}
|
||||
|
||||
full_length = length2;
|
||||
|
||||
/* if the queue is empty then try an immediate write, avoiding
|
||||
queue overhead. This relies on non-blocking sockets */
|
||||
@ -268,7 +270,7 @@ int ctdb_queue_send(struct ctdb_queue *queue, uint8_t *data, uint32_t length)
|
||||
CTDB_NO_MEMORY(queue->ctdb, pkt->data);
|
||||
|
||||
pkt->length = length2;
|
||||
pkt->full_length = length2;
|
||||
pkt->full_length = full_length;
|
||||
|
||||
if (queue->out_queue == NULL && queue->fd != -1) {
|
||||
EVENT_FD_WRITEABLE(queue->fde);
|
||||
|
Loading…
Reference in New Issue
Block a user