From 20be49f6081d28328832b3bcfef59f5218385398 Mon Sep 17 00:00:00 2001 From: logwang Date: Tue, 26 Sep 2017 17:00:20 +0800 Subject: [PATCH] Nginx: hijack `read` and `write`. Since libssl calls `read` and `write` when SSL handshake, we must hijack these two functions, so that the network IO can pass through f-stack. --- .../src/event/modules/ngx_ff_module.c | 31 +++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/app/nginx-1.11.10/src/event/modules/ngx_ff_module.c b/app/nginx-1.11.10/src/event/modules/ngx_ff_module.c index b3fcf4231..c13dbdb9b 100644 --- a/app/nginx-1.11.10/src/event/modules/ngx_ff_module.c +++ b/app/nginx-1.11.10/src/event/modules/ngx_ff_module.c @@ -112,6 +112,9 @@ static ssize_t (*real_sendmsg)(int, const struct msghdr*, int); static ssize_t (*real_writev)(int, const struct iovec *, int); static ssize_t (*real_readv)(int, const struct iovec *, int); +static ssize_t (*real_read)(int, void *, size_t); +static ssize_t (*real_write)(int, const void *, size_t); + static int (*real_ioctl)(int, int, void *); static int (*real_gettimeofday)(struct timeval *tv, struct timezone *tz); @@ -374,6 +377,34 @@ readv(int sockfd, const struct iovec *iov, int iovcnt) } } +ssize_t +read(int sockfd, void *buf, size_t count) +{ + if (unlikely(inited == 0)) { + return SYSCALL(read)(sockfd, buf, count); + } + + if (ff_fdisused(sockfd)) { + return ff_read(sockfd, buf, count); + } else { + return SYSCALL(read)(sockfd, buf, count); + } +} + +ssize_t +write(int sockfd, const void *buf, size_t count) +{ + if (unlikely(inited == 0)) { + return SYSCALL(write)(sockfd, buf, count); + } + + if (ff_fdisused(sockfd)) { + return ff_write(sockfd, buf, count); + } else { + return SYSCALL(write)(sockfd, buf, count); + } +} + int ioctl(int sockfd, int request, void *p) {