added primitive kqueue support
This commit is contained in:
parent
e957f7a1a1
commit
8ed69e7152
28
qse/configure
vendored
28
qse/configure
vendored
@ -17312,7 +17312,20 @@ fi
|
|||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
for ac_header in sys/resource.h sys/wait.h sys/syscall.h sys/sendfile.h sys/epoll.h sys/ioctl.h
|
for ac_header in sys/resource.h sys/wait.h sys/syscall.h sys/ioctl.h
|
||||||
|
do :
|
||||||
|
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
||||||
|
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
||||||
|
if eval test \"x\$"$as_ac_Header"\" = x"yes"; then :
|
||||||
|
cat >>confdefs.h <<_ACEOF
|
||||||
|
#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
|
||||||
|
_ACEOF
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
done
|
||||||
|
|
||||||
|
for ac_header in sys/sendfile.h sys/epoll.h sys/event.h
|
||||||
do :
|
do :
|
||||||
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
|
||||||
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default"
|
||||||
@ -17932,6 +17945,19 @@ $as_echo "#define HAVE_EPOLL 1" >>confdefs.h
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
for ac_func in kqueue kqueue1 kevent
|
||||||
|
do :
|
||||||
|
as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh`
|
||||||
|
ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var"
|
||||||
|
if eval test \"x\$"$as_ac_var"\" = x"yes"; then :
|
||||||
|
cat >>confdefs.h <<_ACEOF
|
||||||
|
#define `$as_echo "HAVE_$ac_func" | $as_tr_cpp` 1
|
||||||
|
_ACEOF
|
||||||
|
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for main in -lunicows" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for main in -lunicows" >&5
|
||||||
$as_echo_n "checking for main in -lunicows... " >&6; }
|
$as_echo_n "checking for main in -lunicows... " >&6; }
|
||||||
if ${ac_cv_lib_unicows_main+:} false; then :
|
if ${ac_cv_lib_unicows_main+:} false; then :
|
||||||
|
@ -101,7 +101,8 @@ dnl check header files.
|
|||||||
AC_HEADER_STDC
|
AC_HEADER_STDC
|
||||||
AC_CHECK_HEADERS([stddef.h wchar.h wctype.h errno.h signal.h fcntl.h dirent.h])
|
AC_CHECK_HEADERS([stddef.h wchar.h wctype.h errno.h signal.h fcntl.h dirent.h])
|
||||||
AC_CHECK_HEADERS([time.h sys/time.h utime.h spawn.h execinfo.h ucontext.h])
|
AC_CHECK_HEADERS([time.h sys/time.h utime.h spawn.h execinfo.h ucontext.h])
|
||||||
AC_CHECK_HEADERS([sys/resource.h sys/wait.h sys/syscall.h sys/sendfile.h sys/epoll.h sys/ioctl.h])
|
AC_CHECK_HEADERS([sys/resource.h sys/wait.h sys/syscall.h sys/ioctl.h])
|
||||||
|
AC_CHECK_HEADERS([sys/sendfile.h sys/epoll.h sys/event.h])
|
||||||
AC_CHECK_HEADERS([sys/sysctl.h sys/socket.h sys/sockio.h ifaddrs.h])
|
AC_CHECK_HEADERS([sys/sysctl.h sys/socket.h sys/sockio.h ifaddrs.h])
|
||||||
AC_CHECK_HEADERS([net/if.h net/if_dl.h], [], [], [
|
AC_CHECK_HEADERS([net/if.h net/if_dl.h], [], [], [
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@ -215,6 +216,8 @@ then
|
|||||||
AC_DEFINE(HAVE_EPOLL, 1, [epoll support])
|
AC_DEFINE(HAVE_EPOLL, 1, [epoll support])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
AC_CHECK_FUNCS([kqueue kqueue1 kevent])
|
||||||
|
|
||||||
dnl check is the import library for unicows.dll exists
|
dnl check is the import library for unicows.dll exists
|
||||||
dnl this check doesn't look for a particular symbol
|
dnl this check doesn't look for a particular symbol
|
||||||
dnl but for the symbol 'main' since i want to check
|
dnl but for the symbol 'main' since i want to check
|
||||||
|
@ -86,10 +86,11 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
QSE_EXPORT qse_mux_t* qse_mux_open (
|
QSE_EXPORT qse_mux_t* qse_mux_open (
|
||||||
qse_mmgr_t* mmgr,
|
qse_mmgr_t* mmgr,
|
||||||
qse_size_t xtnsize,
|
qse_size_t xtnsize,
|
||||||
qse_mux_evtfun_t evtfun,
|
qse_mux_evtfun_t evtfun,
|
||||||
qse_size_t capahint
|
qse_size_t capahint,
|
||||||
|
qse_mux_errnum_t* errnum
|
||||||
);
|
);
|
||||||
|
|
||||||
QSE_EXPORT void qse_mux_close (
|
QSE_EXPORT void qse_mux_close (
|
||||||
|
@ -194,6 +194,15 @@
|
|||||||
/* Define to 1 if you have the `iswctype' function. */
|
/* Define to 1 if you have the `iswctype' function. */
|
||||||
#undef HAVE_ISWCTYPE
|
#undef HAVE_ISWCTYPE
|
||||||
|
|
||||||
|
/* Define to 1 if you have the `kevent' function. */
|
||||||
|
#undef HAVE_KEVENT
|
||||||
|
|
||||||
|
/* Define to 1 if you have the `kqueue' function. */
|
||||||
|
#undef HAVE_KQUEUE
|
||||||
|
|
||||||
|
/* Define to 1 if you have the `kqueue1' function. */
|
||||||
|
#undef HAVE_KQUEUE1
|
||||||
|
|
||||||
/* Define if you have the libdl library or equivalent. */
|
/* Define if you have the libdl library or equivalent. */
|
||||||
#undef HAVE_LIBDL
|
#undef HAVE_LIBDL
|
||||||
|
|
||||||
@ -438,6 +447,9 @@
|
|||||||
/* Define to 1 if you have the <sys/epoll.h> header file. */
|
/* Define to 1 if you have the <sys/epoll.h> header file. */
|
||||||
#undef HAVE_SYS_EPOLL_H
|
#undef HAVE_SYS_EPOLL_H
|
||||||
|
|
||||||
|
/* Define to 1 if you have the <sys/event.h> header file. */
|
||||||
|
#undef HAVE_SYS_EVENT_H
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/ioctl.h> header file. */
|
/* Define to 1 if you have the <sys/ioctl.h> header file. */
|
||||||
#undef HAVE_SYS_IOCTL_H
|
#undef HAVE_SYS_IOCTL_H
|
||||||
|
|
||||||
|
@ -51,12 +51,16 @@
|
|||||||
# if defined(HAVE_SYS_TIME_H)
|
# if defined(HAVE_SYS_TIME_H)
|
||||||
# include <sys/time.h>
|
# include <sys/time.h>
|
||||||
# endif
|
# endif
|
||||||
# if defined(HAVE_SYS_EPOLL_H)
|
# if defined(HAVE_SYS_EVENT_H) && defined(HAVE_KQUEUE) && defined(HAVE_KEVENT)
|
||||||
|
# include <sys/event.h>
|
||||||
|
# define USE_KQUEUE
|
||||||
|
# elif defined(HAVE_SYS_EPOLL_H)
|
||||||
# include <sys/epoll.h>
|
# include <sys/epoll.h>
|
||||||
# if defined(HAVE_EPOLL_CREATE)
|
# if defined(HAVE_EPOLL_CREATE)
|
||||||
# define USE_EPOLL
|
# define USE_EPOLL
|
||||||
# endif
|
# endif
|
||||||
# elif defined(HAVE_POLL_H)
|
# elif defined(HAVE_POLL_H)
|
||||||
|
/* TODO */
|
||||||
# define USE_POLL
|
# define USE_POLL
|
||||||
# else
|
# else
|
||||||
# define USE_SELECT
|
# define USE_SELECT
|
||||||
@ -82,6 +86,19 @@ struct qse_mux_t
|
|||||||
int ubound;
|
int ubound;
|
||||||
} me;
|
} me;
|
||||||
|
|
||||||
|
#elif defined(USE_KQUEUE)
|
||||||
|
|
||||||
|
int kq;
|
||||||
|
|
||||||
|
/* event list: TODO: find the optimal size or make it auto-scalable */
|
||||||
|
struct kevent evlist[512];
|
||||||
|
int size;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
qse_mux_evt_t** ptr;
|
||||||
|
int ubound;
|
||||||
|
} me;
|
||||||
|
|
||||||
#elif defined(USE_EPOLL)
|
#elif defined(USE_EPOLL)
|
||||||
int fd;
|
int fd;
|
||||||
struct
|
struct
|
||||||
@ -106,10 +123,14 @@ struct qse_mux_t
|
|||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
int qse_mux_init (qse_mux_t* mux, qse_mmgr_t* mmgr, qse_mux_evtfun_t evtfun, qse_size_t capahint);
|
int qse_mux_init (
|
||||||
|
qse_mux_t* mux,
|
||||||
|
qse_mmgr_t* mmgr,
|
||||||
|
qse_mux_evtfun_t evtfun,
|
||||||
|
qse_size_t capahint
|
||||||
|
);
|
||||||
void qse_mux_fini (qse_mux_t* mux);
|
void qse_mux_fini (qse_mux_t* mux);
|
||||||
|
|
||||||
|
|
||||||
#if defined(_WIN32)
|
#if defined(_WIN32)
|
||||||
static qse_mux_errnum_t skerr_to_errnum (DWORD e)
|
static qse_mux_errnum_t skerr_to_errnum (DWORD e)
|
||||||
{
|
{
|
||||||
@ -210,7 +231,10 @@ static qse_mux_errnum_t skerr_to_errnum (int e)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
qse_mux_t* qse_mux_open (qse_mmgr_t* mmgr, qse_size_t xtnsize, qse_mux_evtfun_t evtfun, qse_size_t capahint)
|
qse_mux_t* qse_mux_open (
|
||||||
|
qse_mmgr_t* mmgr, qse_size_t xtnsize,
|
||||||
|
qse_mux_evtfun_t evtfun, qse_size_t capahint,
|
||||||
|
qse_mux_errnum_t* errnum)
|
||||||
{
|
{
|
||||||
qse_mux_t* mux;
|
qse_mux_t* mux;
|
||||||
|
|
||||||
@ -219,6 +243,7 @@ qse_mux_t* qse_mux_open (qse_mmgr_t* mmgr, qse_size_t xtnsize, qse_mux_evtfun_t
|
|||||||
{
|
{
|
||||||
if (qse_mux_init (mux, mmgr, evtfun, capahint) <= -1)
|
if (qse_mux_init (mux, mmgr, evtfun, capahint) <= -1)
|
||||||
{
|
{
|
||||||
|
if (errnum) *errnum = qse_mux_geterrnum (mux);
|
||||||
QSE_MMGR_FREE (mmgr, mux);
|
QSE_MMGR_FREE (mmgr, mux);
|
||||||
mux = QSE_NULL;
|
mux = QSE_NULL;
|
||||||
}
|
}
|
||||||
@ -234,7 +259,9 @@ void qse_mux_close (qse_mux_t* mux)
|
|||||||
QSE_MMGR_FREE (mux->mmgr, mux);
|
QSE_MMGR_FREE (mux->mmgr, mux);
|
||||||
}
|
}
|
||||||
|
|
||||||
int qse_mux_init (qse_mux_t* mux, qse_mmgr_t* mmgr, qse_mux_evtfun_t evtfun, qse_size_t capahint)
|
int qse_mux_init (
|
||||||
|
qse_mux_t* mux, qse_mmgr_t* mmgr,
|
||||||
|
qse_mux_evtfun_t evtfun, qse_size_t capahint)
|
||||||
{
|
{
|
||||||
QSE_MEMSET (mux, 0, QSE_SIZEOF(*mux));
|
QSE_MEMSET (mux, 0, QSE_SIZEOF(*mux));
|
||||||
mux->mmgr = mmgr;
|
mux->mmgr = mmgr;
|
||||||
@ -251,6 +278,28 @@ int qse_mux_init (qse_mux_t* mux, qse_mmgr_t* mmgr, qse_mux_evtfun_t evtfun, qse
|
|||||||
FD_ZERO (&mux->wset);
|
FD_ZERO (&mux->wset);
|
||||||
mux->maxhnd = -1;
|
mux->maxhnd = -1;
|
||||||
|
|
||||||
|
#elif defined(USE_KQUEUE)
|
||||||
|
|
||||||
|
#if defined(HAVE_KQUEUE1) && defined(O_CLOEXEC)
|
||||||
|
mux->kq = kqueue1 (O_CLOEXEC);
|
||||||
|
#else
|
||||||
|
mux->kq = kqueue ();
|
||||||
|
#endif
|
||||||
|
if (mux->kq <= -1)
|
||||||
|
{
|
||||||
|
mux->errnum = skerr_to_errnum (errno);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(HAVE_KQUEUE1) && defined(O_CLOEXEC)
|
||||||
|
/* nothing to do */
|
||||||
|
#elif defined(FD_CLOEXEC)
|
||||||
|
{
|
||||||
|
int flag = fcntl (mux->kq, F_GETFD);
|
||||||
|
if (flag >= 0) fcntl (mux->kq, F_SETFD, flag | FD_CLOEXEC);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#elif defined(USE_EPOLL)
|
#elif defined(USE_EPOLL)
|
||||||
#if defined(HAVE_EPOLL_CREATE1) && defined(O_CLOEXEC)
|
#if defined(HAVE_EPOLL_CREATE1) && defined(O_CLOEXEC)
|
||||||
mux->fd = epoll_create1 (O_CLOEXEC);
|
mux->fd = epoll_create1 (O_CLOEXEC);
|
||||||
@ -273,6 +322,7 @@ int qse_mux_init (qse_mux_t* mux, qse_mmgr_t* mmgr, qse_mux_evtfun_t evtfun, qse
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#elif defined(__OS2__)
|
#elif defined(__OS2__)
|
||||||
|
|
||||||
/* nothing special to do */
|
/* nothing special to do */
|
||||||
|
|
||||||
#else
|
#else
|
||||||
@ -306,6 +356,23 @@ void qse_mux_fini (qse_mux_t* mux)
|
|||||||
mux->maxhnd = -1;
|
mux->maxhnd = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#elif defined(USE_KQUEUE)
|
||||||
|
close (mux->kq);
|
||||||
|
|
||||||
|
if (mux->me.ptr)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < mux->me.ubound; i++)
|
||||||
|
{
|
||||||
|
if (mux->me.ptr[i])
|
||||||
|
QSE_MMGR_FREE (mux->mmgr, mux->me.ptr[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
QSE_MMGR_FREE (mux->mmgr, mux->me.ptr);
|
||||||
|
mux->me.ubound = 0;
|
||||||
|
}
|
||||||
|
|
||||||
#elif defined(USE_EPOLL)
|
#elif defined(USE_EPOLL)
|
||||||
close (mux->fd);
|
close (mux->fd);
|
||||||
|
|
||||||
@ -411,6 +478,74 @@ int qse_mux_insert (qse_mux_t* mux, const qse_mux_evt_t* evt)
|
|||||||
mux->size++;
|
mux->size++;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
#elif defined(USE_KQUEUE)
|
||||||
|
struct kevent chlist[2];
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
/* TODO: study if it is better to put 'evt' to the udata
|
||||||
|
* field of chlist? */
|
||||||
|
|
||||||
|
if (evt->mask & QSE_MUX_IN)
|
||||||
|
{
|
||||||
|
EV_SET (&chlist[count], evt->hnd,
|
||||||
|
EVFILT_READ, EV_ADD | EV_ENABLE, 0, 0, 0);
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (evt->mask & QSE_MUX_OUT)
|
||||||
|
{
|
||||||
|
EV_SET (&chlist[count], evt->hnd,
|
||||||
|
EVFILT_WRITE, EV_ADD | EV_ENABLE, 0, 0, 0);
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count == 0 || evt->hnd < 0)
|
||||||
|
{
|
||||||
|
mux->errnum = QSE_MUX_EINVAL;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (evt->hnd >= mux->me.ubound)
|
||||||
|
{
|
||||||
|
qse_mux_evt_t** tmp;
|
||||||
|
int ubound;
|
||||||
|
|
||||||
|
ubound = evt->hnd + 1;
|
||||||
|
ubound = ALIGN_TO (ubound, 128);
|
||||||
|
|
||||||
|
tmp = QSE_MMGR_REALLOC (mux->mmgr, mux->me.ptr, QSE_SIZEOF(*mux->me.ptr) * ubound);
|
||||||
|
if (tmp == QSE_NULL)
|
||||||
|
{
|
||||||
|
mux->errnum = QSE_MUX_ENOMEM;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
QSE_MEMSET (&tmp[mux->me.ubound], 0, QSE_SIZEOF(*mux->me.ptr) * (ubound - mux->me.ubound));
|
||||||
|
mux->me.ptr = tmp;
|
||||||
|
mux->me.ubound = ubound;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!mux->me.ptr[evt->hnd])
|
||||||
|
{
|
||||||
|
mux->me.ptr[evt->hnd] = QSE_MMGR_ALLOC (mux->mmgr, QSE_SIZEOF(*evt));
|
||||||
|
if (!mux->me.ptr[evt->hnd])
|
||||||
|
{
|
||||||
|
mux->errnum = QSE_MUX_ENOMEM;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* add the event */
|
||||||
|
if (kevent (mux->kq, chlist, count, QSE_NULL, 0, QSE_NULL) <= -1)
|
||||||
|
{
|
||||||
|
mux->errnum = skerr_to_errnum (errno);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
*mux->me.ptr[evt->hnd] = *evt;
|
||||||
|
mux->size++;
|
||||||
|
return 0;
|
||||||
|
|
||||||
#elif defined(USE_EPOLL)
|
#elif defined(USE_EPOLL)
|
||||||
struct epoll_event ev;
|
struct epoll_event ev;
|
||||||
|
|
||||||
@ -590,6 +725,50 @@ done:
|
|||||||
mux->size--;
|
mux->size--;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
#elif defined(USE_KQUEUE)
|
||||||
|
|
||||||
|
qse_mux_evt_t* mevt;
|
||||||
|
struct kevent chlist[2];
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
if (mux->size <= 0 || evt->hnd < 0 || evt->hnd >= mux->me.ubound)
|
||||||
|
{
|
||||||
|
mux->errnum = QSE_MUX_EINVAL;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
mevt = mux->me.ptr[evt->hnd];
|
||||||
|
if (mevt->hnd != evt->hnd)
|
||||||
|
{
|
||||||
|
/* already deleted??? */
|
||||||
|
mux->errnum = QSE_MUX_EINVAL;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* compose the change list */
|
||||||
|
if (mevt->mask & QSE_MUX_IN)
|
||||||
|
{
|
||||||
|
EV_SET (&chlist[count], evt->hnd,
|
||||||
|
EVFILT_READ, EV_DELETE | EV_DISABLE, 0, 0, 0);
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
if (mevt->mask & QSE_MUX_OUT)
|
||||||
|
{
|
||||||
|
EV_SET (&chlist[count], evt->hnd,
|
||||||
|
EVFILT_WRITE, EV_DELETE | EV_DISABLE, 0, 0, 0);
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* delte the event by applying the change list */
|
||||||
|
if (kevent (mux->kq, chlist, count, QSE_NULL, 0, QSE_NULL) <= -1)
|
||||||
|
{
|
||||||
|
mux->errnum = skerr_to_errnum (errno);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
mux->size--;
|
||||||
|
return 0;
|
||||||
|
|
||||||
#elif defined(USE_EPOLL)
|
#elif defined(USE_EPOLL)
|
||||||
if (mux->ee.len <= 0)
|
if (mux->ee.len <= 0)
|
||||||
{
|
{
|
||||||
@ -629,7 +808,6 @@ done:
|
|||||||
mux->size--;
|
mux->size--;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* TODO */
|
/* TODO */
|
||||||
mux->errnum = QSE_MUX_ENOIMPL;
|
mux->errnum = QSE_MUX_ENOIMPL;
|
||||||
@ -685,6 +863,50 @@ int qse_mux_poll (qse_mux_t* mux, const qse_ntime_t* tmout)
|
|||||||
|
|
||||||
return n;
|
return n;
|
||||||
|
|
||||||
|
#elif defined(USE_KQUEUE)
|
||||||
|
int nevs;
|
||||||
|
struct timespec ts;
|
||||||
|
|
||||||
|
ts.tv_sec = tmout->sec;
|
||||||
|
ts.tv_nsec = tmout->nsec;
|
||||||
|
|
||||||
|
/* wait for events */
|
||||||
|
nevs = kevent (mux->kq, QSE_NULL, 0,
|
||||||
|
mux->evlist, QSE_COUNTOF(mux->evlist), &ts);
|
||||||
|
if (nevs <= -1)
|
||||||
|
{
|
||||||
|
mux->errnum = skerr_to_errnum(errno);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nevs > 0)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
qse_mux_hnd_t fd;
|
||||||
|
qse_mux_evt_t* evt, xevt;
|
||||||
|
|
||||||
|
for (i = 0; i < nevs; i++)
|
||||||
|
{
|
||||||
|
if (mux->evlist[i].flags & EV_ERROR) continue;
|
||||||
|
|
||||||
|
fd = mux->evlist[i].ident;
|
||||||
|
evt = mux->me.ptr[fd];
|
||||||
|
if (!evt || evt->hnd != fd) continue;
|
||||||
|
|
||||||
|
xevt = *evt;
|
||||||
|
xevt.mask = 0;
|
||||||
|
|
||||||
|
if ((evt->mask & QSE_MUX_IN) &&
|
||||||
|
mux->evlist[i].filter == EVFILT_READ) xevt.mask |= QSE_MUX_IN;
|
||||||
|
if ((evt->mask & QSE_MUX_OUT) &&
|
||||||
|
mux->evlist[i].filter == EVFILT_WRITE) xevt.mask |= QSE_MUX_OUT;
|
||||||
|
|
||||||
|
if (xevt.mask > 0) mux->evtfun (mux, &xevt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nevs;
|
||||||
|
|
||||||
#elif defined(USE_EPOLL)
|
#elif defined(USE_EPOLL)
|
||||||
int nfds, i;
|
int nfds, i;
|
||||||
qse_mux_evt_t* evt, xevt;
|
qse_mux_evt_t* evt, xevt;
|
||||||
|
@ -1008,7 +1008,7 @@ static void* mux_open (qse_httpd_t* httpd, qse_httpd_muxcb_t cbfun)
|
|||||||
qse_mux_t* mux;
|
qse_mux_t* mux;
|
||||||
mux_xtn_t* xtn;
|
mux_xtn_t* xtn;
|
||||||
|
|
||||||
mux = qse_mux_open (httpd->mmgr, QSE_SIZEOF(*xtn), dispatch_muxcb, 256);
|
mux = qse_mux_open (httpd->mmgr, QSE_SIZEOF(*xtn), dispatch_muxcb, 256, QSE_NULL);
|
||||||
if (!mux)
|
if (!mux)
|
||||||
{
|
{
|
||||||
qse_httpd_seterrnum (httpd, QSE_HTTPD_ESYSERR);
|
qse_httpd_seterrnum (httpd, QSE_HTTPD_ESYSERR);
|
||||||
|
Loading…
Reference in New Issue
Block a user