]> git.saurik.com Git - redis.git/blame - src/ae_select.c
maxmemory fixed, we now try to release memory just before we check for the memory...
[redis.git] / src / ae_select.c
CommitLineData
a51dcb8b 1/* Select()-based ae.c module
12d090d2 2 * Copyright (C) 2009-2010 Salvatore Sanfilippo - antirez@gmail.com
a51dcb8b 3 * Released under the BSD license. See the COPYING file for more info. */
4
5#include <string.h>
6
7typedef struct aeApiState {
621d5c19 8 fd_set rfds, wfds;
a51dcb8b 9 /* We need to have a copy of the fd sets as it's not safe to reuse
10 * FD sets after select(). */
621d5c19 11 fd_set _rfds, _wfds;
a51dcb8b 12} aeApiState;
13
14static int aeApiCreate(aeEventLoop *eventLoop) {
15 aeApiState *state = zmalloc(sizeof(aeApiState));
16
17 if (!state) return -1;
18 FD_ZERO(&state->rfds);
19 FD_ZERO(&state->wfds);
a51dcb8b 20 eventLoop->apidata = state;
21 return 0;
22}
23
24static void aeApiFree(aeEventLoop *eventLoop) {
25 zfree(eventLoop->apidata);
26}
27
28static int aeApiAddEvent(aeEventLoop *eventLoop, int fd, int mask) {
29 aeApiState *state = eventLoop->apidata;
30
31 if (mask & AE_READABLE) FD_SET(fd,&state->rfds);
32 if (mask & AE_WRITABLE) FD_SET(fd,&state->wfds);
a51dcb8b 33 return 0;
34}
35
36static void aeApiDelEvent(aeEventLoop *eventLoop, int fd, int mask) {
37 aeApiState *state = eventLoop->apidata;
38
39 if (mask & AE_READABLE) FD_CLR(fd,&state->rfds);
40 if (mask & AE_WRITABLE) FD_CLR(fd,&state->wfds);
a51dcb8b 41}
42
43static int aeApiPoll(aeEventLoop *eventLoop, struct timeval *tvp) {
44 aeApiState *state = eventLoop->apidata;
45 int retval, j, numevents = 0;
46
47 memcpy(&state->_rfds,&state->rfds,sizeof(fd_set));
48 memcpy(&state->_wfds,&state->wfds,sizeof(fd_set));
a51dcb8b 49
50 retval = select(eventLoop->maxfd+1,
621d5c19 51 &state->_rfds,&state->_wfds,NULL,tvp);
a51dcb8b 52 if (retval > 0) {
53 for (j = 0; j <= eventLoop->maxfd; j++) {
54 int mask = 0;
55 aeFileEvent *fe = &eventLoop->events[j];
56
57 if (fe->mask == AE_NONE) continue;
58 if (fe->mask & AE_READABLE && FD_ISSET(j,&state->_rfds))
59 mask |= AE_READABLE;
60 if (fe->mask & AE_WRITABLE && FD_ISSET(j,&state->_wfds))
61 mask |= AE_WRITABLE;
a51dcb8b 62 eventLoop->fired[numevents].fd = j;
63 eventLoop->fired[numevents].mask = mask;
64 numevents++;
65 }
66 }
67 return numevents;
68}
7a932b74 69
70static char *aeApiName(void) {
71 return "select";
72}