diff options
author | Dmitry Kozlov <xeb@mail.ru> | 2016-04-06 23:44:29 +0300 |
---|---|---|
committer | Dmitry Kozlov <xeb@mail.ru> | 2016-04-06 23:44:29 +0300 |
commit | 950c13a76e76438d6dd40a8e716ad351e546ed46 (patch) | |
tree | 4bce909f298665b0898d21b07a930ff4e24241dc /accel-pppd | |
parent | 452b75a037d10b6d059b073899d861436b53e143 (diff) | |
download | accel-ppp-950c13a76e76438d6dd40a8e716ad351e546ed46.tar.gz accel-ppp-950c13a76e76438d6dd40a8e716ad351e546ed46.zip |
radius: do not mark request as active if send function fails
Diffstat (limited to 'accel-pppd')
-rw-r--r-- | accel-pppd/radius/serv.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/accel-pppd/radius/serv.c b/accel-pppd/radius/serv.c index 4313a389..9b59d04b 100644 --- a/accel-pppd/radius/serv.c +++ b/accel-pppd/radius/serv.c @@ -176,6 +176,7 @@ int rad_server_req_cancel(struct rad_req_t *req, int full) int rad_server_req_enter(struct rad_req_t *req) { struct timespec ts; + int r = 0; if (req->serv->need_free) return -1; @@ -224,10 +225,13 @@ int rad_server_req_enter(struct rad_req_t *req) req->active = 1; - if (req->send) - return req->send(req, 0); + if (req->send) { + r = req->send(req, 0); + if (r) + req->active = 0; + } - return 0; + return r; } void rad_server_req_exit(struct rad_req_t *req) |