removed all aio* files. all relevant functions are available in a different project, mio
This commit is contained in:
@ -1,9 +1,6 @@
|
||||
pkgincludedir = $(includedir)/qse/si
|
||||
|
||||
pkginclude_HEADERS = \
|
||||
aio.h \
|
||||
aio-pro.h \
|
||||
aio-sck.h \
|
||||
cnd.h \
|
||||
dir.h \
|
||||
fio.h \
|
||||
|
@ -133,12 +133,11 @@ am__can_run_installinfo = \
|
||||
n|no|NO) false;; \
|
||||
*) (install-info --version) >/dev/null 2>&1;; \
|
||||
esac
|
||||
am__pkginclude_HEADERS_DIST = aio.h aio-pro.h aio-sck.h cnd.h dir.h \
|
||||
fio.h fs.h glob.h intr.h log.h mtx.h mux.h netlink.h nwad.h \
|
||||
nwif.h nwio.h os.h pio.h rwl.h sck.h sinfo.h sio.h spl.h \
|
||||
task.h thr.h tio.h App.hpp Condition.hpp Mutex.hpp \
|
||||
SocketAddress.hpp Socket.hpp SpinLock.hpp TcpServer.hpp \
|
||||
Thread.hpp
|
||||
am__pkginclude_HEADERS_DIST = cnd.h dir.h fio.h fs.h glob.h intr.h \
|
||||
log.h mtx.h mux.h netlink.h nwad.h nwif.h nwio.h os.h pio.h \
|
||||
rwl.h sck.h sinfo.h sio.h spl.h task.h thr.h tio.h App.hpp \
|
||||
Condition.hpp Mutex.hpp SocketAddress.hpp Socket.hpp \
|
||||
SpinLock.hpp TcpServer.hpp Thread.hpp
|
||||
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
||||
am__vpath_adj = case $$p in \
|
||||
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
||||
@ -355,10 +354,9 @@ target_alias = @target_alias@
|
||||
top_build_prefix = @top_build_prefix@
|
||||
top_builddir = @top_builddir@
|
||||
top_srcdir = @top_srcdir@
|
||||
pkginclude_HEADERS = aio.h aio-pro.h aio-sck.h cnd.h dir.h fio.h fs.h \
|
||||
glob.h intr.h log.h mtx.h mux.h netlink.h nwad.h nwif.h nwio.h \
|
||||
os.h pio.h rwl.h sck.h sinfo.h sio.h spl.h task.h thr.h tio.h \
|
||||
$(am__append_1)
|
||||
pkginclude_HEADERS = cnd.h dir.h fio.h fs.h glob.h intr.h log.h mtx.h \
|
||||
mux.h netlink.h nwad.h nwif.h nwio.h os.h pio.h rwl.h sck.h \
|
||||
sinfo.h sio.h spl.h task.h thr.h tio.h $(am__append_1)
|
||||
all: all-am
|
||||
|
||||
.SUFFIXES:
|
||||
|
@ -1,164 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*
|
||||
Copyright (c) 2006-2016 Chung, Hyung-Hwan. All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions
|
||||
are met:
|
||||
1. Redistributions of source code must retain the above copyright
|
||||
notice, this list of conditions and the following disclaimer.
|
||||
2. Redistributions in binary form must reproduce the above copyright
|
||||
notice, this list of conditions and the following disclaimer in the
|
||||
documentation and/or other materials provided with the distribution.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR
|
||||
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WAfRRANTIES
|
||||
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_SI_AIO_PRO_H_
|
||||
#define _QSE_SI_AIO_PRO_H_
|
||||
|
||||
#include <qse/si/aio.h>
|
||||
|
||||
enum qse_aio_dev_pro_sid_t
|
||||
{
|
||||
QSE_AIO_DEV_PRO_MASTER = -1,
|
||||
QSE_AIO_DEV_PRO_IN = 0,
|
||||
QSE_AIO_DEV_PRO_OUT = 1,
|
||||
QSE_AIO_DEV_PRO_ERR = 2
|
||||
};
|
||||
typedef enum qse_aio_dev_pro_sid_t qse_aio_dev_pro_sid_t;
|
||||
|
||||
typedef struct qse_aio_dev_pro_t qse_aio_dev_pro_t;
|
||||
typedef struct qse_aio_dev_pro_slave_t qse_aio_dev_pro_slave_t;
|
||||
|
||||
typedef int (*qse_aio_dev_pro_on_read_t) (qse_aio_dev_pro_t* dev, const void* data, qse_aio_iolen_t len, qse_aio_dev_pro_sid_t sid);
|
||||
typedef int (*qse_aio_dev_pro_on_write_t) (qse_aio_dev_pro_t* dev, qse_aio_iolen_t wrlen, void* wrctx);
|
||||
typedef void (*qse_aio_dev_pro_on_close_t) (qse_aio_dev_pro_t* dev, qse_aio_dev_pro_sid_t sid);
|
||||
|
||||
struct qse_aio_dev_pro_t
|
||||
{
|
||||
QSE_AIO_DEV_HEADERS;
|
||||
|
||||
int flags;
|
||||
qse_intptr_t child_pid; /* defined to qse_intptr_t to hide pid_t */
|
||||
qse_aio_dev_pro_slave_t* slave[3];
|
||||
int slave_count;
|
||||
|
||||
qse_aio_dev_pro_on_read_t on_read;
|
||||
qse_aio_dev_pro_on_write_t on_write;
|
||||
qse_aio_dev_pro_on_close_t on_close;
|
||||
|
||||
qse_mchar_t* mcmd;
|
||||
};
|
||||
|
||||
struct qse_aio_dev_pro_slave_t
|
||||
{
|
||||
QSE_AIO_DEV_HEADERS;
|
||||
qse_aio_dev_pro_sid_t id;
|
||||
qse_aio_syshnd_t pfd;
|
||||
qse_aio_dev_pro_t* master; /* parent device */
|
||||
};
|
||||
|
||||
enum qse_aio_dev_pro_make_flag_t
|
||||
{
|
||||
QSE_AIO_DEV_PRO_WRITEIN = (1 << 0),
|
||||
QSE_AIO_DEV_PRO_READOUT = (1 << 1),
|
||||
QSE_AIO_DEV_PRO_READERR = (1 << 2),
|
||||
|
||||
QSE_AIO_DEV_PRO_ERRTOOUT = (1 << 3),
|
||||
QSE_AIO_DEV_PRO_OUTTOERR = (1 << 4),
|
||||
|
||||
QSE_AIO_DEV_PRO_INTONUL = (1 << 5),
|
||||
QSE_AIO_DEV_PRO_OUTTONUL = (1 << 6),
|
||||
QSE_AIO_DEV_PRO_ERRTONUL = (1 << 7),
|
||||
|
||||
STUO_DEV_PRO_DROPIN = (1 << 8),
|
||||
STUO_DEV_PRO_DROPOUT = (1 << 9),
|
||||
STUO_DEV_PRO_DROPERR = (1 << 10),
|
||||
|
||||
|
||||
QSE_AIO_DEV_PRO_SHELL = (1 << 13),
|
||||
|
||||
/* perform no waitpid() on a child process upon device destruction.
|
||||
* you should set this flag if your application has automatic child
|
||||
* process reaping enabled. for instance, SIGCHLD is set to SIG_IGN
|
||||
* on POSIX.1-2001 compliant systems */
|
||||
QSE_AIO_DEV_PRO_FORGET_CHILD = (1 << 14),
|
||||
|
||||
|
||||
QSE_AIO_DEV_PRO_FORGET_DIEHARD_CHILD = (1 << 15)
|
||||
};
|
||||
typedef enum qse_aio_dev_pro_make_flag_t qse_aio_dev_pro_make_flag_t;
|
||||
|
||||
typedef struct qse_aio_dev_pro_make_t qse_aio_dev_pro_make_t;
|
||||
struct qse_aio_dev_pro_make_t
|
||||
{
|
||||
int flags; /**< bitwise-ORed of qse_aio_dev_pro_make_flag_t enumerators */
|
||||
const void* cmd;
|
||||
qse_aio_dev_pro_on_write_t on_write; /* mandatory */
|
||||
qse_aio_dev_pro_on_read_t on_read; /* mandatory */
|
||||
qse_aio_dev_pro_on_close_t on_close; /* optional */
|
||||
};
|
||||
|
||||
|
||||
enum qse_aio_dev_pro_ioctl_cmd_t
|
||||
{
|
||||
QSE_AIO_DEV_PRO_CLOSE,
|
||||
QSE_AIO_DEV_PRO_KILL_CHILD
|
||||
};
|
||||
typedef enum qse_aio_dev_pro_ioctl_cmd_t qse_aio_dev_pro_ioctl_cmd_t;
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
QSE_EXPORT qse_aio_dev_pro_t* qse_aio_dev_pro_make (
|
||||
qse_aio_t* aio,
|
||||
qse_size_t xtnsize,
|
||||
const qse_aio_dev_pro_make_t* data
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_dev_pro_kill (
|
||||
qse_aio_dev_pro_t* pro
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_pro_write (
|
||||
qse_aio_dev_pro_t* pro,
|
||||
const void* data,
|
||||
qse_aio_iolen_t len,
|
||||
void* wrctx
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_pro_timedwrite (
|
||||
qse_aio_dev_pro_t* pro,
|
||||
const void* data,
|
||||
qse_aio_iolen_t len,
|
||||
const qse_ntime_t* tmout,
|
||||
void* wrctx
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_pro_close (
|
||||
qse_aio_dev_pro_t* pro,
|
||||
qse_aio_dev_pro_sid_t sid
|
||||
);
|
||||
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_pro_killchild (
|
||||
qse_aio_dev_pro_t* pro
|
||||
);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
@ -1,597 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*
|
||||
Copyright (c) 2006-2016 Chung, Hyung-Hwan. All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions
|
||||
are met:
|
||||
1. Redistributions of source code must retain the above copyright
|
||||
notice, this list of conditions and the following disclaimer.
|
||||
2. Redistributions in binary form must reproduce the above copyright
|
||||
notice, this list of conditions and the following disclaimer in the
|
||||
documentation and/or other materials provided with the distribution.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR
|
||||
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WAfRRANTIES
|
||||
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_SI_AIO_SCK_H_
|
||||
#define _QSE_SI_AIO_SCK_H_
|
||||
|
||||
#include <qse/si/aio.h>
|
||||
|
||||
/* ========================================================================= */
|
||||
/* TOOD: move these to a separte file */
|
||||
|
||||
#define QSE_AIO_ETHHDR_PROTO_IP4 0x0800
|
||||
#define QSE_AIO_ETHHDR_PROTO_ARP 0x0806
|
||||
#define QSE_AIO_ETHHDR_PROTO_8021Q 0x8100 /* 802.1Q VLAN */
|
||||
#define QSE_AIO_ETHHDR_PROTO_IP6 0x86DD
|
||||
|
||||
|
||||
#define QSE_AIO_ARPHDR_OPCODE_REQUEST 1
|
||||
#define QSE_AIO_ARPHDR_OPCODE_REPLY 2
|
||||
|
||||
#define QSE_AIO_ARPHDR_HTYPE_ETH 0x0001
|
||||
#define QSE_AIO_ARPHDR_PTYPE_IP4 0x0800
|
||||
|
||||
#define QSE_AIO_ETHADDR_LEN 6
|
||||
#define QSE_AIO_IP4ADDR_LEN 4
|
||||
#define QSE_AIO_IP6ADDR_LEN 16
|
||||
|
||||
|
||||
#if defined(__GNUC__)
|
||||
# define QSE_AIO_PACKED __attribute__((__packed__))
|
||||
|
||||
#else
|
||||
# define QSE_AIO_PACKED
|
||||
# QSE_AIO_PACK_PUSH pack(push)
|
||||
# QSE_AIO_PACK_PUSH pack(push)
|
||||
# QSE_AIO_PACK(x) pack(x)
|
||||
#endif
|
||||
|
||||
|
||||
#if defined(__GNUC__)
|
||||
/* nothing */
|
||||
#else
|
||||
#pragma pack(push)
|
||||
#pragma pack(1)
|
||||
#endif
|
||||
struct QSE_AIO_PACKED qse_aio_ethaddr_t
|
||||
{
|
||||
qse_uint8_t v[QSE_AIO_ETHADDR_LEN];
|
||||
};
|
||||
typedef struct qse_aio_ethaddr_t qse_aio_ethaddr_t;
|
||||
|
||||
struct QSE_AIO_PACKED qse_aio_ip4addr_t
|
||||
{
|
||||
qse_uint8_t v[QSE_AIO_IP4ADDR_LEN];
|
||||
};
|
||||
typedef struct qse_aio_ip4addr_t qse_aio_ip4addr_t;
|
||||
|
||||
struct QSE_AIO_PACKED qse_aio_ip6addr_t
|
||||
{
|
||||
qse_uint8_t v[QSE_AIO_IP6ADDR_LEN];
|
||||
};
|
||||
typedef struct qse_aio_ip6addr_t qse_aio_ip6addr_t;
|
||||
|
||||
struct QSE_AIO_PACKED qse_aio_ethhdr_t
|
||||
{
|
||||
qse_uint8_t dest[QSE_AIO_ETHADDR_LEN];
|
||||
qse_uint8_t source[QSE_AIO_ETHADDR_LEN];
|
||||
qse_uint16_t proto;
|
||||
};
|
||||
typedef struct qse_aio_ethhdr_t qse_aio_ethhdr_t;
|
||||
|
||||
struct QSE_AIO_PACKED qse_aio_arphdr_t
|
||||
{
|
||||
qse_uint16_t htype; /* hardware type (ethernet: 0x0001) */
|
||||
qse_uint16_t ptype; /* protocol type (ipv4: 0x0800) */
|
||||
qse_uint8_t hlen; /* hardware address length (ethernet: 6) */
|
||||
qse_uint8_t plen; /* protocol address length (ipv4 :4) */
|
||||
qse_uint16_t opcode; /* operation code */
|
||||
};
|
||||
typedef struct qse_aio_arphdr_t qse_aio_arphdr_t;
|
||||
|
||||
/* arp payload for ipv4 over ethernet */
|
||||
struct QSE_AIO_PACKED qse_aio_etharp_t
|
||||
{
|
||||
qse_uint8_t sha[QSE_AIO_ETHADDR_LEN]; /* source hardware address */
|
||||
qse_uint8_t spa[QSE_AIO_IP4ADDR_LEN]; /* source protocol address */
|
||||
qse_uint8_t tha[QSE_AIO_ETHADDR_LEN]; /* target hardware address */
|
||||
qse_uint8_t tpa[QSE_AIO_IP4ADDR_LEN]; /* target protocol address */
|
||||
};
|
||||
typedef struct qse_aio_etharp_t qse_aio_etharp_t;
|
||||
|
||||
struct QSE_AIO_PACKED qse_aio_etharp_pkt_t
|
||||
{
|
||||
qse_aio_ethhdr_t ethhdr;
|
||||
qse_aio_arphdr_t arphdr;
|
||||
qse_aio_etharp_t arppld;
|
||||
};
|
||||
typedef struct qse_aio_etharp_pkt_t qse_aio_etharp_pkt_t;
|
||||
|
||||
|
||||
struct qse_aio_iphdr_t
|
||||
{
|
||||
#if defined(QSE_ENDIAN_LITTLE)
|
||||
qse_uint8_t ihl:4;
|
||||
qse_uint8_t version:4;
|
||||
#elif defined(QSE_ENDIAN_BIG)
|
||||
qse_uint8_t version:4;
|
||||
qse_uint8_t ihl:4;
|
||||
#else
|
||||
# UNSUPPORTED ENDIAN
|
||||
#endif
|
||||
qse_int8_t tos;
|
||||
qse_int16_t tot_len;
|
||||
qse_int16_t id;
|
||||
qse_int16_t frag_off;
|
||||
qse_int8_t ttl;
|
||||
qse_int8_t protocol;
|
||||
qse_int16_t check;
|
||||
qse_int32_t saddr;
|
||||
qse_int32_t daddr;
|
||||
/*The options start here. */
|
||||
};
|
||||
typedef struct qse_aio_iphdr_t qse_aio_iphdr_t;
|
||||
|
||||
|
||||
struct QSE_AIO_PACKED qse_aio_icmphdr_t
|
||||
{
|
||||
qse_uint8_t type; /* message type */
|
||||
qse_uint8_t code; /* subcode */
|
||||
qse_uint16_t checksum;
|
||||
union
|
||||
{
|
||||
struct
|
||||
{
|
||||
qse_uint16_t id;
|
||||
qse_uint16_t seq;
|
||||
} echo;
|
||||
|
||||
qse_uint32_t gateway;
|
||||
|
||||
struct
|
||||
{
|
||||
qse_uint16_t frag_unused;
|
||||
qse_uint16_t mtu;
|
||||
} frag; /* path mut discovery */
|
||||
} u;
|
||||
};
|
||||
typedef struct qse_aio_icmphdr_t qse_aio_icmphdr_t;
|
||||
|
||||
#if defined(__GNUC__)
|
||||
/* nothing */
|
||||
#else
|
||||
#pragma pack(pop)
|
||||
#endif
|
||||
|
||||
/* ICMP types */
|
||||
#define QSE_AIO_ICMP_ECHO_REPLY 0
|
||||
#define QSE_AIO_ICMP_UNREACH 3 /* destination unreachable */
|
||||
#define QSE_AIO_ICMP_SOURCE_QUENCE 4
|
||||
#define QSE_AIO_ICMP_REDIRECT 5
|
||||
#define QSE_AIO_ICMP_ECHO_REQUEST 8
|
||||
#define QSE_AIO_ICMP_TIME_EXCEEDED 11
|
||||
#define QSE_AIO_ICMP_PARAM_PROBLEM 12
|
||||
#define QSE_AIO_ICMP_TIMESTAMP_REQUEST 13
|
||||
#define QSE_AIO_ICMP_TIMESTAMP_REPLY 14
|
||||
#define QSE_AIO_ICMP_INFO_REQUEST 15
|
||||
#define QSE_AIO_ICMP_INFO_REPLY 16
|
||||
#define QSE_AIO_ICMP_ADDR_MASK_REQUEST 17
|
||||
#define QSE_AIO_ICMP_ADDR_MASK_REPLY 18
|
||||
|
||||
/* Subcode for QSE_AIO_ICMP_UNREACH */
|
||||
#define QSE_AIO_ICMP_UNREACH_NET 0
|
||||
#define QSE_AIO_ICMP_UNREACH_HOST 1
|
||||
#define QSE_AIO_ICMP_UNREACH_PROTOCOL 2
|
||||
#define QSE_AIO_ICMP_UNREACH_PORT 3
|
||||
#define QSE_AIO_ICMP_UNREACH_FRAG_NEEDED 4
|
||||
|
||||
/* Subcode for QSE_AIO_ICMP_REDIRECT */
|
||||
#define QSE_AIO_ICMP_REDIRECT_NET 0
|
||||
#define QSE_AIO_ICMP_REDIRECT_HOST 1
|
||||
#define QSE_AIO_ICMP_REDIRECT_NETTOS 2
|
||||
#define QSE_AIO_ICMP_REDIRECT_HOSTTOS 3
|
||||
|
||||
/* Subcode for QSE_AIO_ICMP_TIME_EXCEEDED */
|
||||
#define QSE_AIO_ICMP_TIME_EXCEEDED_TTL 0
|
||||
#define QSE_AIO_ICMP_TIME_EXCEEDED_FRAGTIME 1
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
typedef int qse_aio_sckfam_t;
|
||||
|
||||
struct qse_aio_sckaddr_t
|
||||
{
|
||||
qse_aio_sckfam_t family;
|
||||
qse_uint8_t data[128]; /* TODO: use the actual sockaddr size */
|
||||
};
|
||||
typedef struct qse_aio_sckaddr_t qse_aio_sckaddr_t;
|
||||
|
||||
#if (QSE_SIZEOF_SOCKLEN_T == QSE_SIZEOF_INT)
|
||||
#if defined(QSE_AIO_SOCKLEN_T_IS_SIGNED)
|
||||
typedef int qse_aio_scklen_t;
|
||||
#else
|
||||
typedef unsigned int qse_aio_scklen_t;
|
||||
#endif
|
||||
#elif (QSE_SIZEOF_SOCKLEN_T == QSE_SIZEOF_LONG)
|
||||
#if defined(QSE_AIO_SOCKLEN_T_IS_SIGNED)
|
||||
typedef long qse_aio_scklen_t;
|
||||
#else
|
||||
typedef unsigned long qse_aio_scklen_t;
|
||||
#endif
|
||||
#else
|
||||
typedef int qse_aio_scklen_t;
|
||||
#endif
|
||||
|
||||
#if defined(_WIN32)
|
||||
# define QSE_AIO_IOCP_KEY 1
|
||||
/*
|
||||
typedef HANDLE qse_aio_syshnd_t;
|
||||
typedef SOCKET qse_aio_sckhnd_t;
|
||||
# define QSE_AIO_SCKHND_INVALID (INVALID_SOCKET)
|
||||
*/
|
||||
|
||||
typedef qse_uintptr_t qse_aio_sckhnd_t;
|
||||
# define QSE_AIO_SCKHND_INVALID (~(qse_aio_sck_hnd_t)0)
|
||||
|
||||
#else
|
||||
typedef int qse_aio_sckhnd_t;
|
||||
# define QSE_AIO_SCKHND_INVALID (-1)
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
enum qse_aio_dev_sck_ioctl_cmd_t
|
||||
{
|
||||
QSE_AIO_DEV_SCK_BIND,
|
||||
QSE_AIO_DEV_SCK_CONNECT,
|
||||
QSE_AIO_DEV_SCK_LISTEN
|
||||
};
|
||||
typedef enum qse_aio_dev_sck_ioctl_cmd_t qse_aio_dev_sck_ioctl_cmd_t;
|
||||
|
||||
|
||||
#define QSE_AIO_DEV_SCK_SET_PROGRESS(dev,bit) do { \
|
||||
(dev)->state &= ~QSE_AIO_DEV_SCK_ALL_PROGRESS_BITS; \
|
||||
(dev)->state |= (bit); \
|
||||
} while(0)
|
||||
|
||||
#define QSE_AIO_DEV_SCK_GET_PROGRESS(dev) ((dev)->state & QSE_AIO_DEV_SCK_ALL_PROGRESS_BITS)
|
||||
|
||||
enum qse_aio_dev_sck_state_t
|
||||
{
|
||||
/* the following items(progress bits) are mutually exclusive */
|
||||
QSE_AIO_DEV_SCK_CONNECTING = (1 << 0),
|
||||
QSE_AIO_DEV_SCK_CONNECTING_SSL = (1 << 1),
|
||||
QSE_AIO_DEV_SCK_CONNECTED = (1 << 2),
|
||||
QSE_AIO_DEV_SCK_LISTENING = (1 << 3),
|
||||
QSE_AIO_DEV_SCK_ACCEPTING_SSL = (1 << 4),
|
||||
QSE_AIO_DEV_SCK_ACCEPTED = (1 << 5),
|
||||
|
||||
/* the following items can be bitwise-ORed with an exclusive item above */
|
||||
QSE_AIO_DEV_SCK_INTERCEPTED = (1 << 15),
|
||||
|
||||
|
||||
/* convenience bit masks */
|
||||
QSE_AIO_DEV_SCK_ALL_PROGRESS_BITS = (QSE_AIO_DEV_SCK_CONNECTING |
|
||||
QSE_AIO_DEV_SCK_CONNECTING_SSL |
|
||||
QSE_AIO_DEV_SCK_CONNECTED |
|
||||
QSE_AIO_DEV_SCK_LISTENING |
|
||||
QSE_AIO_DEV_SCK_ACCEPTING_SSL |
|
||||
QSE_AIO_DEV_SCK_ACCEPTED)
|
||||
};
|
||||
typedef enum qse_aio_dev_sck_state_t qse_aio_dev_sck_state_t;
|
||||
|
||||
typedef struct qse_aio_dev_sck_t qse_aio_dev_sck_t;
|
||||
|
||||
typedef int (*qse_aio_dev_sck_on_read_t) (
|
||||
qse_aio_dev_sck_t* dev,
|
||||
const void* data,
|
||||
qse_aio_iolen_t dlen,
|
||||
const qse_aio_sckaddr_t* srcaddr
|
||||
);
|
||||
|
||||
typedef int (*qse_aio_dev_sck_on_write_t) (
|
||||
qse_aio_dev_sck_t* dev,
|
||||
qse_aio_iolen_t wrlen,
|
||||
void* wrctx,
|
||||
const qse_aio_sckaddr_t* dstaddr
|
||||
);
|
||||
|
||||
typedef void (*qse_aio_dev_sck_on_disconnect_t) (
|
||||
qse_aio_dev_sck_t* dev
|
||||
);
|
||||
|
||||
typedef int (*qse_aio_dev_sck_on_connect_t) (
|
||||
qse_aio_dev_sck_t* dev
|
||||
);
|
||||
|
||||
enum qse_aio_dev_sck_type_t
|
||||
{
|
||||
QSE_AIO_DEV_SCK_TCP4,
|
||||
QSE_AIO_DEV_SCK_TCP6,
|
||||
QSE_AIO_DEV_SCK_UPD4,
|
||||
QSE_AIO_DEV_SCK_UDP6,
|
||||
|
||||
/* ARP at the ethernet layer */
|
||||
QSE_AIO_DEV_SCK_ARP,
|
||||
QSE_AIO_DEV_SCK_ARP_DGRAM,
|
||||
|
||||
/* ICMP at the IPv4 layer */
|
||||
QSE_AIO_DEV_SCK_ICMP4,
|
||||
|
||||
/* ICMP at the IPv6 layer */
|
||||
QSE_AIO_DEV_SCK_ICMP6
|
||||
|
||||
#if 0
|
||||
QSE_AIO_DEV_SCK_RAW, /* raw L2-level packet */
|
||||
#endif
|
||||
};
|
||||
typedef enum qse_aio_dev_sck_type_t qse_aio_dev_sck_type_t;
|
||||
|
||||
typedef struct qse_aio_dev_sck_make_t qse_aio_dev_sck_make_t;
|
||||
struct qse_aio_dev_sck_make_t
|
||||
{
|
||||
qse_aio_dev_sck_type_t type;
|
||||
qse_aio_dev_sck_on_write_t on_write;
|
||||
qse_aio_dev_sck_on_read_t on_read;
|
||||
qse_aio_dev_sck_on_disconnect_t on_disconnect;
|
||||
};
|
||||
|
||||
enum qse_aio_dev_sck_bind_option_t
|
||||
{
|
||||
QSE_AIO_DEV_SCK_BIND_BROADCAST = (1 << 0),
|
||||
QSE_AIO_DEV_SCK_BIND_REUSEADDR = (1 << 1),
|
||||
QSE_AIO_DEV_SCK_BIND_REUSEPORT = (1 << 2),
|
||||
QSE_AIO_DEV_SCK_BIND_TRANSPARENT = (1 << 3),
|
||||
|
||||
/* TODO: more options --- SO_RCVBUF, SO_SNDBUF, SO_RCVTIMEO, SO_SNDTIMEO, SO_KEEPALIVE */
|
||||
/* BINDTODEVICE??? */
|
||||
|
||||
QSE_AIO_DEV_SCK_BIND_SSL = (1 << 15)
|
||||
};
|
||||
typedef enum qse_aio_dev_sck_bind_option_t qse_aio_dev_sck_bind_option_t;
|
||||
|
||||
typedef struct qse_aio_dev_sck_bind_t qse_aio_dev_sck_bind_t;
|
||||
struct qse_aio_dev_sck_bind_t
|
||||
{
|
||||
int options;
|
||||
qse_aio_sckaddr_t localaddr;
|
||||
/* TODO: add device name for BIND_TO_DEVICE */
|
||||
|
||||
const qse_mchar_t* ssl_certfile;
|
||||
const qse_mchar_t* ssl_keyfile;
|
||||
qse_ntime_t accept_tmout;
|
||||
};
|
||||
|
||||
enum qse_aio_def_sck_connect_option_t
|
||||
{
|
||||
QSE_AIO_DEV_SCK_CONNECT_SSL = (1 << 15)
|
||||
};
|
||||
typedef enum qse_aio_dev_sck_connect_option_t qse_aio_dev_sck_connect_option_t;
|
||||
|
||||
typedef struct qse_aio_dev_sck_connect_t qse_aio_dev_sck_connect_t;
|
||||
struct qse_aio_dev_sck_connect_t
|
||||
{
|
||||
int options;
|
||||
qse_aio_sckaddr_t remoteaddr;
|
||||
qse_ntime_t connect_tmout;
|
||||
qse_aio_dev_sck_on_connect_t on_connect;
|
||||
};
|
||||
|
||||
typedef struct qse_aio_dev_sck_listen_t qse_aio_dev_sck_listen_t;
|
||||
struct qse_aio_dev_sck_listen_t
|
||||
{
|
||||
int backlogs;
|
||||
qse_aio_dev_sck_on_connect_t on_connect; /* optional, but new connections are dropped immediately without this */
|
||||
};
|
||||
|
||||
typedef struct qse_aio_dev_sck_accept_t qse_aio_dev_sck_accept_t;
|
||||
struct qse_aio_dev_sck_accept_t
|
||||
{
|
||||
qse_aio_syshnd_t sck;
|
||||
/* TODO: add timeout */
|
||||
qse_aio_sckaddr_t remoteaddr;
|
||||
};
|
||||
|
||||
struct qse_aio_dev_sck_t
|
||||
{
|
||||
QSE_AIO_DEV_HEADERS;
|
||||
|
||||
qse_aio_dev_sck_type_t type;
|
||||
qse_aio_sckhnd_t sck;
|
||||
|
||||
int state;
|
||||
|
||||
/* remote peer address for a stateful stream socket. valid if one of the
|
||||
* followings is set in state:
|
||||
* QSE_AIO_DEV_TCP_ACCEPTING_SSL
|
||||
* QSE_AIO_DEV_TCP_ACCEPTED
|
||||
* QSE_AIO_DEV_TCP_CONNECTED
|
||||
* QSE_AIO_DEV_TCP_CONNECTING
|
||||
* QSE_AIO_DEV_TCP_CONNECTING_SSL
|
||||
*
|
||||
* also used as a placeholder to store source address for
|
||||
* a stateless socket */
|
||||
qse_aio_sckaddr_t remoteaddr;
|
||||
|
||||
/* local socket address */
|
||||
qse_aio_sckaddr_t localaddr;
|
||||
|
||||
/* original destination address */
|
||||
qse_aio_sckaddr_t orgdstaddr;
|
||||
|
||||
qse_aio_dev_sck_on_write_t on_write;
|
||||
qse_aio_dev_sck_on_read_t on_read;
|
||||
|
||||
/* return 0 on succes, -1 on failure.
|
||||
* called on a new tcp device for an accepted client or
|
||||
* on a tcp device conntected to a remote server */
|
||||
qse_aio_dev_sck_on_connect_t on_connect;
|
||||
qse_aio_dev_sck_on_disconnect_t on_disconnect;
|
||||
|
||||
/* timer job index for handling
|
||||
* - connect() timeout for a connecting socket.
|
||||
* - SSL_accept() timeout for a socket accepting SSL */
|
||||
qse_aio_tmridx_t tmrjob_index;
|
||||
|
||||
/* connect timeout, ssl-connect timeout, ssl-accept timeout.
|
||||
* it denotes timeout duration under some circumstances
|
||||
* or an absolute expiry time under some other circumstances. */
|
||||
qse_ntime_t tmout;
|
||||
|
||||
void* ssl_ctx;
|
||||
void* ssl;
|
||||
|
||||
};
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
QSE_EXPORT qse_aio_sckhnd_t qse_aio_openasyncsck (
|
||||
qse_aio_t* aio,
|
||||
int domain,
|
||||
int type,
|
||||
int proto
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_closeasyncsck (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_sckhnd_t sck
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_makesckasync (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_sckhnd_t sck
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_getsckaddrinfo (
|
||||
qse_aio_t* aio,
|
||||
const qse_aio_sckaddr_t* addr,
|
||||
qse_aio_scklen_t* len,
|
||||
qse_aio_sckfam_t* family
|
||||
);
|
||||
|
||||
/*
|
||||
* The qse_aio_getsckaddrport() function returns the port number of a socket
|
||||
* address in the host byte order. If the address doesn't support the port
|
||||
* number, it returns 0.
|
||||
*/
|
||||
QSE_EXPORT qse_uint16_t qse_aio_getsckaddrport (
|
||||
const qse_aio_sckaddr_t* addr
|
||||
);
|
||||
|
||||
/*
|
||||
* The qse_aio_getsckaddrifindex() function returns an interface number.
|
||||
* If the address doesn't support the interface number, it returns 0. */
|
||||
QSE_EXPORT int qse_aio_getsckaddrifindex (
|
||||
const qse_aio_sckaddr_t* addr
|
||||
);
|
||||
|
||||
|
||||
QSE_EXPORT void qse_aio_sckaddr_initforip4 (
|
||||
qse_aio_sckaddr_t* sckaddr,
|
||||
qse_uint16_t port,
|
||||
qse_aio_ip4addr_t* ip4addr
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_sckaddr_initforip6 (
|
||||
qse_aio_sckaddr_t* sckaddr,
|
||||
qse_uint16_t port,
|
||||
qse_aio_ip6addr_t* ip6addr
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_sckaddr_initforeth (
|
||||
qse_aio_sckaddr_t* sckaddr,
|
||||
int ifindex,
|
||||
qse_aio_ethaddr_t* ethaddr
|
||||
);
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
QSE_EXPORT qse_aio_dev_sck_t* qse_aio_dev_sck_make (
|
||||
qse_aio_t* aio,
|
||||
qse_size_t xtnsize,
|
||||
const qse_aio_dev_sck_make_t* info
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_sck_bind (
|
||||
qse_aio_dev_sck_t* dev,
|
||||
qse_aio_dev_sck_bind_t* info
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_sck_connect (
|
||||
qse_aio_dev_sck_t* dev,
|
||||
qse_aio_dev_sck_connect_t* info
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_sck_listen (
|
||||
qse_aio_dev_sck_t* dev,
|
||||
qse_aio_dev_sck_listen_t* info
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_sck_write (
|
||||
qse_aio_dev_sck_t* dev,
|
||||
const void* data,
|
||||
qse_aio_iolen_t len,
|
||||
void* wrctx,
|
||||
const qse_aio_sckaddr_t* dstaddr
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_sck_timedwrite (
|
||||
qse_aio_dev_sck_t* dev,
|
||||
const void* data,
|
||||
qse_aio_iolen_t len,
|
||||
const qse_ntime_t* tmout,
|
||||
void* wrctx,
|
||||
const qse_aio_sckaddr_t* dstaddr
|
||||
);
|
||||
|
||||
#if defined(QSE_AIO_HAVE_INLINE)
|
||||
|
||||
static QSE_INLINE void qse_aio_dev_sck_halt (qse_aio_dev_sck_t* sck)
|
||||
{
|
||||
qse_aio_dev_halt ((qse_aio_dev_t*)sck);
|
||||
}
|
||||
|
||||
static QSE_INLINE int qse_aio_dev_sck_read (qse_aio_dev_sck_t* sck, int enabled)
|
||||
{
|
||||
return qse_aio_dev_read ((qse_aio_dev_t*)sck, enabled);
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
#define qse_aio_dev_sck_halt(sck) qse_aio_dev_halt((qse_aio_dev_t*)sck)
|
||||
#define qse_aio_dev_sck_read(sck,enabled) qse_aio_dev_read((qse_aio_dev_t*)sck, enabled)
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
QSE_EXPORT qse_uint16_t qse_aio_checksumip (
|
||||
const void* hdr,
|
||||
qse_size_t len
|
||||
);
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
|
||||
#endif
|
@ -1,438 +0,0 @@
|
||||
/*
|
||||
* $Id$
|
||||
*
|
||||
Copyright (c) 2006-2016 Chung, Hyung-Hwan. All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions
|
||||
are met:
|
||||
1. Redistributions of source code must retain the above copyright
|
||||
notice, this list of conditions and the following disclaimer.
|
||||
2. Redistributions in binary form must reproduce the above copyright
|
||||
notice, this list of conditions and the following disclaimer in the
|
||||
documentation and/or other materials provided with the distribution.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR
|
||||
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WAfRRANTIES
|
||||
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#ifndef _QSE_SI_AIO_H_
|
||||
#define _QSE_SI_AIO_H_
|
||||
|
||||
#include <qse/types.h>
|
||||
#include <qse/macros.h>
|
||||
#include <qse/cmn/time.h>
|
||||
|
||||
#if defined(_WIN32)
|
||||
typedef qse_uintptr_t qse_aio_syshnd_t;
|
||||
#define QSE_AIO_SYSHND_INVALID (~(qse_uintptr_t)0)
|
||||
#else
|
||||
typedef int qse_aio_syshnd_t;
|
||||
#define QSE_AIO_SYSHND_INVALID (-1)
|
||||
#endif
|
||||
|
||||
typedef struct qse_aio_devaddr_t qse_aio_devaddr_t;
|
||||
struct qse_aio_devaddr_t
|
||||
{
|
||||
int len;
|
||||
void* ptr;
|
||||
};
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
typedef struct qse_aio_t qse_aio_t;
|
||||
typedef struct qse_aio_dev_t qse_aio_dev_t;
|
||||
typedef struct qse_aio_dev_mth_t qse_aio_dev_mth_t;
|
||||
typedef struct qse_aio_dev_evcb_t qse_aio_dev_evcb_t;
|
||||
|
||||
typedef struct qse_aio_wq_t qse_aio_wq_t;
|
||||
typedef qse_intptr_t qse_aio_iolen_t; /* NOTE: this is a signed type */
|
||||
|
||||
enum qse_aio_errnum_t
|
||||
{
|
||||
QSE_AIO_ENOERR,
|
||||
QSE_AIO_ENOIMPL,
|
||||
QSE_AIO_ESYSERR,
|
||||
QSE_AIO_EINTERN,
|
||||
|
||||
QSE_AIO_ENOMEM,
|
||||
QSE_AIO_EINVAL,
|
||||
QSE_AIO_EEXIST,
|
||||
QSE_AIO_ENOENT,
|
||||
QSE_AIO_ENOSUP, /* not supported */
|
||||
QSE_AIO_EMFILE, /* too many open files */
|
||||
QSE_AIO_ENFILE,
|
||||
QSE_AIO_EAGAIN,
|
||||
QSE_AIO_ECONRF, /* connection refused */
|
||||
QSE_AIO_ECONRS, /* connection reset */
|
||||
QSE_AIO_ENOCAPA, /* no capability */
|
||||
QSE_AIO_ETMOUT, /* timed out */
|
||||
QSE_AIO_EPERM, /* operation not permitted */
|
||||
|
||||
QSE_AIO_EDEVMAKE,
|
||||
QSE_AIO_EDEVERR,
|
||||
QSE_AIO_EDEVHUP
|
||||
};
|
||||
|
||||
typedef enum qse_aio_errnum_t qse_aio_errnum_t;
|
||||
|
||||
enum qse_aio_stopreq_t
|
||||
{
|
||||
QSE_AIO_STOPREQ_NONE = 0,
|
||||
QSE_AIO_STOPREQ_TERMINATION,
|
||||
QSE_AIO_STOPREQ_WATCHER_ERROR
|
||||
};
|
||||
typedef enum qse_aio_stopreq_t qse_aio_stopreq_t;
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
#define QSE_AIO_TMRIDX_INVALID ((qse_aio_tmridx_t)-1)
|
||||
|
||||
typedef qse_size_t qse_aio_tmridx_t;
|
||||
|
||||
typedef struct qse_aio_tmrjob_t qse_aio_tmrjob_t;
|
||||
|
||||
typedef void (*qse_aio_tmrjob_handler_t) (
|
||||
qse_aio_t* aio,
|
||||
const qse_ntime_t* now,
|
||||
qse_aio_tmrjob_t* tmrjob
|
||||
);
|
||||
|
||||
struct qse_aio_tmrjob_t
|
||||
{
|
||||
void* ctx;
|
||||
qse_ntime_t when;
|
||||
qse_aio_tmrjob_handler_t handler;
|
||||
qse_aio_tmridx_t* idxptr; /* pointer to the index holder */
|
||||
};
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
struct qse_aio_dev_mth_t
|
||||
{
|
||||
/* ------------------------------------------------------------------ */
|
||||
/* mandatory. called in qse_aio_makedev() */
|
||||
int (*make) (qse_aio_dev_t* dev, void* ctx);
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
/* mandatory. called in qse_aio_killdev(). also called in qse_aio_makedev() upon
|
||||
* failure after make() success.
|
||||
*
|
||||
* when 'force' is 0, the return value of -1 causes the device to be a
|
||||
* zombie. the kill method is called periodically on a zombie device
|
||||
* until the method returns 0.
|
||||
*
|
||||
* when 'force' is 1, the called should not return -1. If it does, the
|
||||
* method is called once more only with the 'force' value of 2.
|
||||
*
|
||||
* when 'force' is 2, the device is destroyed regardless of the return value.
|
||||
*/
|
||||
int (*kill) (qse_aio_dev_t* dev, int force);
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
qse_aio_syshnd_t (*getsyshnd) (qse_aio_dev_t* dev); /* mandatory. called in qse_aio_makedev() after successful make() */
|
||||
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
/* return -1 on failure, 0 if no data is availble, 1 otherwise.
|
||||
* when returning 1, *len must be sent to the length of data read.
|
||||
* if *len is set to 0, it's treated as EOF. */
|
||||
int (*read) (qse_aio_dev_t* dev, void* data, qse_aio_iolen_t* len, qse_aio_devaddr_t* srcaddr);
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
int (*write) (qse_aio_dev_t* dev, const void* data, qse_aio_iolen_t* len, const qse_aio_devaddr_t* dstaddr);
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
int (*ioctl) (qse_aio_dev_t* dev, int cmd, void* arg);
|
||||
|
||||
};
|
||||
|
||||
struct qse_aio_dev_evcb_t
|
||||
{
|
||||
/* return -1 on failure. 0 or 1 on success.
|
||||
* when 0 is returned, it doesn't attempt to perform actual I/O.
|
||||
* when 1 is returned, it attempts to perform actual I/O. */
|
||||
int (*ready) (qse_aio_dev_t* dev, int events);
|
||||
|
||||
/* return -1 on failure, 0 or 1 on success.
|
||||
* when 0 is returned, the main loop stops the attempt to read more data.
|
||||
* when 1 is returned, the main loop attempts to read more data without*/
|
||||
int (*on_read) (qse_aio_dev_t* dev, const void* data, qse_aio_iolen_t len, const qse_aio_devaddr_t* srcaddr);
|
||||
|
||||
/* return -1 on failure, 0 on success.
|
||||
* wrlen is the length of data written. it is the length of the originally
|
||||
* posted writing request for a stream device. For a non stream device, it
|
||||
* may be shorter than the originally posted length. */
|
||||
int (*on_write) (qse_aio_dev_t* dev, qse_aio_iolen_t wrlen, void* wrctx, const qse_aio_devaddr_t* dstaddr);
|
||||
};
|
||||
|
||||
struct qse_aio_wq_t
|
||||
{
|
||||
qse_aio_wq_t* next;
|
||||
qse_aio_wq_t* prev;
|
||||
|
||||
qse_aio_iolen_t olen; /* original data length */
|
||||
qse_uint8_t* ptr; /* pointer to data */
|
||||
qse_aio_iolen_t len; /* remaining data length */
|
||||
void* ctx;
|
||||
qse_aio_dev_t* dev; /* back-pointer to the device */
|
||||
|
||||
qse_aio_tmridx_t tmridx;
|
||||
qse_aio_devaddr_t dstaddr;
|
||||
};
|
||||
|
||||
#define QSE_AIO_WQ_INIT(wq) ((wq)->next = (wq)->prev = (wq))
|
||||
#define QSE_AIO_WQ_TAIL(wq) ((wq)->prev)
|
||||
#define QSE_AIO_WQ_HEAD(wq) ((wq)->next)
|
||||
#define QSE_AIO_WQ_ISEMPTY(wq) (QSE_AIO_WQ_HEAD(wq) == (wq))
|
||||
#define QSE_AIO_WQ_ISNODE(wq,x) ((wq) != (x))
|
||||
#define QSE_AIO_WQ_ISHEAD(wq,x) (QSE_AIO_WQ_HEAD(wq) == (x))
|
||||
#define QSE_AIO_WQ_ISTAIL(wq,x) (QSE_AIO_WQ_TAIL(wq) == (x))
|
||||
|
||||
#define QSE_AIO_WQ_NEXT(x) ((x)->next)
|
||||
#define QSE_AIO_WQ_PREV(x) ((x)->prev)
|
||||
|
||||
#define QSE_AIO_WQ_LINK(p,x,n) do { \
|
||||
qse_aio_wq_t* pp = (p), * nn = (n); \
|
||||
(x)->prev = (p); \
|
||||
(x)->next = (n); \
|
||||
nn->prev = (x); \
|
||||
pp->next = (x); \
|
||||
} while (0)
|
||||
|
||||
#define QSE_AIO_WQ_UNLINK(x) do { \
|
||||
qse_aio_wq_t* pp = (x)->prev, * nn = (x)->next; \
|
||||
nn->prev = pp; pp->next = nn; \
|
||||
} while (0)
|
||||
|
||||
#define QSE_AIO_WQ_REPL(o,n) do { \
|
||||
qse_aio_wq_t* oo = (o), * nn = (n); \
|
||||
nn->next = oo->next; \
|
||||
nn->next->prev = nn; \
|
||||
nn->prev = oo->prev; \
|
||||
nn->prev->next = nn; \
|
||||
} while (0)
|
||||
|
||||
/* insert an item at the back of the queue */
|
||||
/*#define QSE_AIO_WQ_ENQ(wq,x) QSE_AIO_WQ_LINK(QSE_AIO_WQ_TAIL(wq), x, QSE_AIO_WQ_TAIL(wq)->next)*/
|
||||
#define QSE_AIO_WQ_ENQ(wq,x) QSE_AIO_WQ_LINK(QSE_AIO_WQ_TAIL(wq), x, wq)
|
||||
|
||||
/* remove an item in the front from the queue */
|
||||
#define QSE_AIO_WQ_DEQ(wq) QSE_AIO_WQ_UNLINK(QSE_AIO_WQ_HEAD(wq))
|
||||
|
||||
#define QSE_AIO_DEV_HEADERS \
|
||||
qse_aio_t* aio; \
|
||||
qse_size_t dev_size; \
|
||||
int dev_capa; \
|
||||
qse_aio_dev_mth_t* dev_mth; \
|
||||
qse_aio_dev_evcb_t* dev_evcb; \
|
||||
qse_aio_wq_t wq; \
|
||||
qse_aio_dev_t* dev_prev; \
|
||||
qse_aio_dev_t* dev_next
|
||||
|
||||
struct qse_aio_dev_t
|
||||
{
|
||||
QSE_AIO_DEV_HEADERS;
|
||||
};
|
||||
|
||||
enum qse_aio_dev_capa_t
|
||||
{
|
||||
QSE_AIO_DEV_CAPA_VIRTUAL = (1 << 0),
|
||||
QSE_AIO_DEV_CAPA_IN = (1 << 1),
|
||||
QSE_AIO_DEV_CAPA_OUT = (1 << 2),
|
||||
/* #QSE_AIO_DEV_CAPA_PRI is meaningful only if #QSE_AIO_DEV_CAPA_IN is set */
|
||||
QSE_AIO_DEV_CAPA_PRI = (1 << 3),
|
||||
QSE_AIO_DEV_CAPA_STREAM = (1 << 4),
|
||||
QSE_AIO_DEV_CAPA_OUT_QUEUED = (1 << 5),
|
||||
|
||||
/* internal use only. never set this bit to the dev_capa field */
|
||||
QSE_AIO_DEV_CAPA_IN_DISABLED = (1 << 9),
|
||||
QSE_AIO_DEV_CAPA_IN_CLOSED = (1 << 10),
|
||||
QSE_AIO_DEV_CAPA_OUT_CLOSED = (1 << 11),
|
||||
QSE_AIO_DEV_CAPA_IN_WATCHED = (1 << 12),
|
||||
QSE_AIO_DEV_CAPA_OUT_WATCHED = (1 << 13),
|
||||
QSE_AIO_DEV_CAPA_PRI_WATCHED = (1 << 14), /**< can be set only if QSE_AIO_DEV_CAPA_IN_WATCHED is set */
|
||||
|
||||
QSE_AIO_DEV_CAPA_ACTIVE = (1 << 15),
|
||||
QSE_AIO_DEV_CAPA_HALTED = (1 << 16),
|
||||
QSE_AIO_DEV_CAPA_ZOMBIE = (1 << 17)
|
||||
};
|
||||
typedef enum qse_aio_dev_capa_t qse_aio_dev_capa_t;
|
||||
|
||||
enum qse_aio_dev_watch_cmd_t
|
||||
{
|
||||
QSE_AIO_DEV_WATCH_START,
|
||||
QSE_AIO_DEV_WATCH_UPDATE,
|
||||
QSE_AIO_DEV_WATCH_RENEW, /* automatic update */
|
||||
QSE_AIO_DEV_WATCH_STOP
|
||||
};
|
||||
typedef enum qse_aio_dev_watch_cmd_t qse_aio_dev_watch_cmd_t;
|
||||
|
||||
enum qse_aio_dev_event_t
|
||||
{
|
||||
QSE_AIO_DEV_EVENT_IN = (1 << 0),
|
||||
QSE_AIO_DEV_EVENT_OUT = (1 << 1),
|
||||
|
||||
QSE_AIO_DEV_EVENT_PRI = (1 << 2),
|
||||
QSE_AIO_DEV_EVENT_HUP = (1 << 3),
|
||||
QSE_AIO_DEV_EVENT_ERR = (1 << 4)
|
||||
};
|
||||
typedef enum qse_aio_dev_event_t qse_aio_dev_event_t;
|
||||
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
QSE_EXPORT qse_aio_t* qse_aio_open (
|
||||
qse_mmgr_t* mmgr,
|
||||
qse_size_t xtnsize,
|
||||
qse_size_t tmrcapa, /**< initial timer capacity */
|
||||
qse_aio_errnum_t* errnum
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_close (
|
||||
qse_aio_t* aio
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_init (
|
||||
qse_aio_t* aio,
|
||||
qse_mmgr_t* mmgr,
|
||||
qse_size_t tmrcapa
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_fini (
|
||||
qse_aio_t* aio
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_exec (
|
||||
qse_aio_t* aio
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_loop (
|
||||
qse_aio_t* aio
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_stop (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_stopreq_t stopreq
|
||||
);
|
||||
|
||||
QSE_EXPORT qse_aio_dev_t* qse_aio_makedev (
|
||||
qse_aio_t* aio,
|
||||
qse_size_t dev_size,
|
||||
qse_aio_dev_mth_t* dev_mth,
|
||||
qse_aio_dev_evcb_t* dev_evcb,
|
||||
void* make_ctx
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_killdev (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_dev_t* dev
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_ioctl (
|
||||
qse_aio_dev_t* dev,
|
||||
int cmd,
|
||||
void* arg
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_watch (
|
||||
qse_aio_dev_t* dev,
|
||||
qse_aio_dev_watch_cmd_t cmd,
|
||||
/** 0 or bitwise-ORed of #QSE_AIO_DEV_EVENT_IN and #QSE_AIO_DEV_EVENT_OUT */
|
||||
int events
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_read (
|
||||
qse_aio_dev_t* dev,
|
||||
int enabled
|
||||
);
|
||||
|
||||
/**
|
||||
* The qse_aio_dev_write() function posts a writing request.
|
||||
* It attempts to write data immediately if there is no pending requests.
|
||||
* If writing fails, it returns -1. If writing succeeds, it calls the
|
||||
* on_write callback. If the callback fails, it returns -1. If the callback
|
||||
* succeeds, it returns 1. If no immediate writing is possible, the request
|
||||
* is enqueued to a pending request list. If enqueing gets successful,
|
||||
* it returns 0. otherwise it returns -1.
|
||||
*/
|
||||
QSE_EXPORT int qse_aio_dev_write (
|
||||
qse_aio_dev_t* dev,
|
||||
const void* data,
|
||||
qse_aio_iolen_t len,
|
||||
void* wrctx,
|
||||
const qse_aio_devaddr_t* dstaddr
|
||||
);
|
||||
|
||||
|
||||
QSE_EXPORT int qse_aio_dev_timedwrite (
|
||||
qse_aio_dev_t* dev,
|
||||
const void* data,
|
||||
qse_aio_iolen_t len,
|
||||
const qse_ntime_t* tmout,
|
||||
void* wrctx,
|
||||
const qse_aio_devaddr_t* dstaddr
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_dev_halt (
|
||||
qse_aio_dev_t* dev
|
||||
);
|
||||
|
||||
/**
|
||||
* The qse_aio_instmrjob() function schedules a new event.
|
||||
*
|
||||
* \return #QSE_AIO_TMRIDX_INVALID on failure, valid index on success.
|
||||
*/
|
||||
|
||||
QSE_EXPORT qse_aio_tmridx_t qse_aio_instmrjob (
|
||||
qse_aio_t* aio,
|
||||
const qse_aio_tmrjob_t* job
|
||||
);
|
||||
|
||||
QSE_EXPORT qse_aio_tmridx_t qse_aio_updtmrjob (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_tmridx_t index,
|
||||
const qse_aio_tmrjob_t* job
|
||||
);
|
||||
|
||||
QSE_EXPORT void qse_aio_deltmrjob (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_tmridx_t index
|
||||
);
|
||||
|
||||
/**
|
||||
* The qse_aio_gettmrjob() function returns the
|
||||
* pointer to the registered event at the given index.
|
||||
*/
|
||||
QSE_EXPORT qse_aio_tmrjob_t* qse_aio_gettmrjob (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_tmridx_t index
|
||||
);
|
||||
|
||||
QSE_EXPORT int qse_aio_gettmrjobdeadline (
|
||||
qse_aio_t* aio,
|
||||
qse_aio_tmridx_t index,
|
||||
qse_ntime_t* deadline
|
||||
);
|
||||
|
||||
/* ========================================================================= */
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
#endif
|
Reference in New Issue
Block a user