mirror of
https://github.com/wg/wrk
synced 2025-01-24 20:53:51 +08:00
import updated ae from redis 2.6.8
This commit is contained in:
parent
6d143f164d
commit
17b79717f6
2
NOTICE
2
NOTICE
@ -14,7 +14,9 @@ This product includes software developed by Salvatore Sanfilippo and
|
|||||||
other contributors to the redis project.
|
other contributors to the redis project.
|
||||||
|
|
||||||
Copyright (c) 2006-2010, Salvatore Sanfilippo <antirez at gmail dot com>
|
Copyright (c) 2006-2010, Salvatore Sanfilippo <antirez at gmail dot com>
|
||||||
|
Copyright (c) 2009-2012, Salvatore Sanfilippo <antirez at gmail dot com>
|
||||||
Copyright (C) 2009 Harish Mallipeddi - harish.mallipeddi@gmail.com
|
Copyright (C) 2009 Harish Mallipeddi - harish.mallipeddi@gmail.com
|
||||||
|
Copyright (c) 2012, Joyent, Inc. All rights reserved.
|
||||||
|
|
||||||
Copyright (c) 2006-2009, Salvatore Sanfilippo
|
Copyright (c) 2006-2009, Salvatore Sanfilippo
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
57
src/ae.c
57
src/ae.c
@ -35,7 +35,10 @@
|
|||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <poll.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
#include "ae.h"
|
#include "ae.h"
|
||||||
#include "zmalloc.h"
|
#include "zmalloc.h"
|
||||||
@ -43,14 +46,18 @@
|
|||||||
|
|
||||||
/* Include the best multiplexing layer supported by this system.
|
/* Include the best multiplexing layer supported by this system.
|
||||||
* The following should be ordered by performances, descending. */
|
* The following should be ordered by performances, descending. */
|
||||||
#ifdef HAVE_EPOLL
|
#ifdef HAVE_EVPORT
|
||||||
#include "ae_epoll.c"
|
#include "ae_evport.c"
|
||||||
#else
|
#else
|
||||||
|
#ifdef HAVE_EPOLL
|
||||||
|
#include "ae_epoll.c"
|
||||||
|
#else
|
||||||
#ifdef HAVE_KQUEUE
|
#ifdef HAVE_KQUEUE
|
||||||
#include "ae_kqueue.c"
|
#include "ae_kqueue.c"
|
||||||
#else
|
#else
|
||||||
#include "ae_select.c"
|
#include "ae_select.c"
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
aeEventLoop *aeCreateEventLoop(int setsize) {
|
aeEventLoop *aeCreateEventLoop(int setsize) {
|
||||||
@ -62,6 +69,7 @@ aeEventLoop *aeCreateEventLoop(int setsize) {
|
|||||||
eventLoop->fired = zmalloc(sizeof(aeFiredEvent)*setsize);
|
eventLoop->fired = zmalloc(sizeof(aeFiredEvent)*setsize);
|
||||||
if (eventLoop->events == NULL || eventLoop->fired == NULL) goto err;
|
if (eventLoop->events == NULL || eventLoop->fired == NULL) goto err;
|
||||||
eventLoop->setsize = setsize;
|
eventLoop->setsize = setsize;
|
||||||
|
eventLoop->lastTime = time(NULL);
|
||||||
eventLoop->timeEventHead = NULL;
|
eventLoop->timeEventHead = NULL;
|
||||||
eventLoop->timeEventNextId = 0;
|
eventLoop->timeEventNextId = 0;
|
||||||
eventLoop->stop = 0;
|
eventLoop->stop = 0;
|
||||||
@ -97,7 +105,10 @@ void aeStop(aeEventLoop *eventLoop) {
|
|||||||
int aeCreateFileEvent(aeEventLoop *eventLoop, int fd, int mask,
|
int aeCreateFileEvent(aeEventLoop *eventLoop, int fd, int mask,
|
||||||
aeFileProc *proc, void *clientData)
|
aeFileProc *proc, void *clientData)
|
||||||
{
|
{
|
||||||
if (fd >= eventLoop->setsize) return AE_ERR;
|
if (fd >= eventLoop->setsize) {
|
||||||
|
errno = ERANGE;
|
||||||
|
return AE_ERR;
|
||||||
|
}
|
||||||
aeFileEvent *fe = &eventLoop->events[fd];
|
aeFileEvent *fe = &eventLoop->events[fd];
|
||||||
|
|
||||||
if (aeApiAddEvent(eventLoop, fd, mask) == -1)
|
if (aeApiAddEvent(eventLoop, fd, mask) == -1)
|
||||||
@ -231,6 +242,24 @@ static int processTimeEvents(aeEventLoop *eventLoop) {
|
|||||||
int processed = 0;
|
int processed = 0;
|
||||||
aeTimeEvent *te;
|
aeTimeEvent *te;
|
||||||
long long maxId;
|
long long maxId;
|
||||||
|
time_t now = time(NULL);
|
||||||
|
|
||||||
|
/* If the system clock is moved to the future, and then set back to the
|
||||||
|
* right value, time events may be delayed in a random way. Often this
|
||||||
|
* means that scheduled operations will not be performed soon enough.
|
||||||
|
*
|
||||||
|
* Here we try to detect system clock skews, and force all the time
|
||||||
|
* events to be processed ASAP when this happens: the idea is that
|
||||||
|
* processing events earlier is less dangerous than delaying them
|
||||||
|
* indefinitely, and practice suggests it is. */
|
||||||
|
if (now < eventLoop->lastTime) {
|
||||||
|
te = eventLoop->timeEventHead;
|
||||||
|
while(te) {
|
||||||
|
te->when_sec = 0;
|
||||||
|
te = te->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
eventLoop->lastTime = now;
|
||||||
|
|
||||||
te = eventLoop->timeEventHead;
|
te = eventLoop->timeEventHead;
|
||||||
maxId = eventLoop->timeEventNextId-1;
|
maxId = eventLoop->timeEventNextId-1;
|
||||||
@ -369,21 +398,19 @@ int aeProcessEvents(aeEventLoop *eventLoop, int flags)
|
|||||||
/* Wait for millseconds until the given file descriptor becomes
|
/* Wait for millseconds until the given file descriptor becomes
|
||||||
* writable/readable/exception */
|
* writable/readable/exception */
|
||||||
int aeWait(int fd, int mask, long long milliseconds) {
|
int aeWait(int fd, int mask, long long milliseconds) {
|
||||||
struct timeval tv;
|
struct pollfd pfd;
|
||||||
fd_set rfds, wfds, efds;
|
|
||||||
int retmask = 0, retval;
|
int retmask = 0, retval;
|
||||||
|
|
||||||
tv.tv_sec = milliseconds/1000;
|
memset(&pfd, 0, sizeof(pfd));
|
||||||
tv.tv_usec = (milliseconds%1000)*1000;
|
pfd.fd = fd;
|
||||||
FD_ZERO(&rfds);
|
if (mask & AE_READABLE) pfd.events |= POLLIN;
|
||||||
FD_ZERO(&wfds);
|
if (mask & AE_WRITABLE) pfd.events |= POLLOUT;
|
||||||
FD_ZERO(&efds);
|
|
||||||
|
|
||||||
if (mask & AE_READABLE) FD_SET(fd,&rfds);
|
if ((retval = poll(&pfd, 1, milliseconds))== 1) {
|
||||||
if (mask & AE_WRITABLE) FD_SET(fd,&wfds);
|
if (pfd.revents & POLLIN) retmask |= AE_READABLE;
|
||||||
if ((retval = select(fd+1, &rfds, &wfds, &efds, &tv)) > 0) {
|
if (pfd.revents & POLLOUT) retmask |= AE_WRITABLE;
|
||||||
if (FD_ISSET(fd,&rfds)) retmask |= AE_READABLE;
|
if (pfd.revents & POLLERR) retmask |= AE_WRITABLE;
|
||||||
if (FD_ISSET(fd,&wfds)) retmask |= AE_WRITABLE;
|
if (pfd.revents & POLLHUP) retmask |= AE_WRITABLE;
|
||||||
return retmask;
|
return retmask;
|
||||||
} else {
|
} else {
|
||||||
return retval;
|
return retval;
|
||||||
|
3
src/ae.h
3
src/ae.h
@ -2,7 +2,7 @@
|
|||||||
* for the Jim's event-loop (Jim is a Tcl interpreter) but later translated
|
* for the Jim's event-loop (Jim is a Tcl interpreter) but later translated
|
||||||
* it in form of a library for easy reuse.
|
* it in form of a library for easy reuse.
|
||||||
*
|
*
|
||||||
* Copyright (c) 2006-2010, Salvatore Sanfilippo <antirez at gmail dot com>
|
* Copyright (c) 2006-2012, Salvatore Sanfilippo <antirez at gmail dot com>
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -88,6 +88,7 @@ typedef struct aeEventLoop {
|
|||||||
int maxfd; /* highest file descriptor currently registered */
|
int maxfd; /* highest file descriptor currently registered */
|
||||||
int setsize; /* max number of file descriptors tracked */
|
int setsize; /* max number of file descriptors tracked */
|
||||||
long long timeEventNextId;
|
long long timeEventNextId;
|
||||||
|
time_t lastTime; /* Used to detect system clock skew */
|
||||||
aeFileEvent *events; /* Registered events */
|
aeFileEvent *events; /* Registered events */
|
||||||
aeFiredEvent *fired; /* Fired events */
|
aeFiredEvent *fired; /* Fired events */
|
||||||
aeTimeEvent *timeEventHead;
|
aeTimeEvent *timeEventHead;
|
||||||
|
@ -1,6 +1,33 @@
|
|||||||
/* Linux epoll(2) based ae.c module
|
/* Linux epoll(2) based ae.c module
|
||||||
* Copyright (C) 2009-2010 Salvatore Sanfilippo - antirez@gmail.com
|
*
|
||||||
* Released under the BSD license. See the COPYING file for more info. */
|
* Copyright (c) 2009-2012, Salvatore Sanfilippo <antirez at gmail dot com>
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* * 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.
|
||||||
|
* * Neither the name of Redis nor the names of its contributors may be used
|
||||||
|
* to endorse or promote products derived from this software without
|
||||||
|
* specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <sys/epoll.h>
|
#include <sys/epoll.h>
|
||||||
|
|
||||||
@ -89,6 +116,8 @@ static int aeApiPoll(aeEventLoop *eventLoop, struct timeval *tvp) {
|
|||||||
|
|
||||||
if (e->events & EPOLLIN) mask |= AE_READABLE;
|
if (e->events & EPOLLIN) mask |= AE_READABLE;
|
||||||
if (e->events & EPOLLOUT) mask |= AE_WRITABLE;
|
if (e->events & EPOLLOUT) mask |= AE_WRITABLE;
|
||||||
|
if (e->events & EPOLLERR) mask |= AE_WRITABLE;
|
||||||
|
if (e->events & EPOLLHUP) mask |= AE_WRITABLE;
|
||||||
eventLoop->fired[j].fd = e->data.fd;
|
eventLoop->fired[j].fd = e->data.fd;
|
||||||
eventLoop->fired[j].mask = mask;
|
eventLoop->fired[j].mask = mask;
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,33 @@
|
|||||||
/* Kqueue(2)-based ae.c module
|
/* Kqueue(2)-based ae.c module
|
||||||
|
*
|
||||||
* Copyright (C) 2009 Harish Mallipeddi - harish.mallipeddi@gmail.com
|
* Copyright (C) 2009 Harish Mallipeddi - harish.mallipeddi@gmail.com
|
||||||
* Released under the BSD license. See the COPYING file for more info. */
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* * 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.
|
||||||
|
* * Neither the name of Redis nor the names of its contributors may be used
|
||||||
|
* to endorse or promote products derived from this software without
|
||||||
|
* specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/event.h>
|
#include <sys/event.h>
|
||||||
|
@ -1,6 +1,33 @@
|
|||||||
/* Select()-based ae.c module
|
/* Select()-based ae.c module.
|
||||||
* Copyright (C) 2009-2010 Salvatore Sanfilippo - antirez@gmail.com
|
*
|
||||||
* Released under the BSD license. See the COPYING file for more info. */
|
* Copyright (c) 2009-2012, Salvatore Sanfilippo <antirez at gmail dot com>
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* * 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.
|
||||||
|
* * Neither the name of Redis nor the names of its contributors may be used
|
||||||
|
* to endorse or promote products derived from this software without
|
||||||
|
* specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user