From b67def0a55cfd15bdfca8e22380cc32a654faaba Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Fri, 8 Aug 2008 18:30:57 +0200 Subject: Add simple async wrappers around send, recv and connect To be used later :-) (This used to be commit 0d161d336ab9eeccd90d19ef1473646c3008864a) --- source3/include/async_sock.h | 45 ++++++++++++++++++++++++++++++++++++++++++++ source3/include/includes.h | 1 + 2 files changed, 46 insertions(+) create mode 100644 source3/include/async_sock.h (limited to 'source3/include') diff --git a/source3/include/async_sock.h b/source3/include/async_sock.h new file mode 100644 index 0000000000..3c90453601 --- /dev/null +++ b/source3/include/async_sock.h @@ -0,0 +1,45 @@ +/* + Unix SMB/CIFS implementation. + async socket operations + Copyright (C) Volker Lendecke 2008 + + 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 . +*/ + +#ifndef __ASYNC_SOCK_H__ +#define __ASYNC_SOCK_H__ + +#include "includes.h" + +ssize_t async_syscall_result_ssize_t(struct async_req **req, int *perrno); +size_t async_syscall_result_size_t (struct async_req **req, int *perrno); +ssize_t async_syscall_result_int (struct async_req **req, int *perrno); + +struct async_req *async_send(TALLOC_CTX *mem_ctx, struct event_context *ev, + int fd, const void *buffer, size_t length, + int flags); +struct async_req *async_sendall(TALLOC_CTX *mem_ctx, struct event_context *ev, + int fd, const void *buffer, size_t length, + int flags); +struct async_req *async_recv(TALLOC_CTX *mem_ctx, struct event_context *ev, + int fd, void *buffer, size_t length, + int flags); +struct async_req *async_recvall(TALLOC_CTX *mem_ctx, struct event_context *ev, + int fd, void *buffer, size_t length, + int flags); +struct async_req *async_connect(TALLOC_CTX *mem_ctx, struct event_context *ev, + int fd, const struct sockaddr *address, + socklen_t address_len); + +#endif diff --git a/source3/include/includes.h b/source3/include/includes.h index aa99dc0b63..8eb0ee52dd 100644 --- a/source3/include/includes.h +++ b/source3/include/includes.h @@ -723,6 +723,7 @@ typedef char fstring[FSTRING_LEN]; #include "memcache.h" #include "async_req.h" #include "async_smb.h" +#include "async_sock.h" #include "lib/smbconf/smbconf.h" -- cgit