summaryrefslogtreecommitdiff
path: root/accel-pppd
diff options
context:
space:
mode:
authorDmitry Kozlov <xeb@mail.ru>2016-04-06 23:44:29 +0300
committerDmitry Kozlov <xeb@mail.ru>2016-04-06 23:44:29 +0300
commit950c13a76e76438d6dd40a8e716ad351e546ed46 (patch)
tree4bce909f298665b0898d21b07a930ff4e24241dc /accel-pppd
parent452b75a037d10b6d059b073899d861436b53e143 (diff)
downloadaccel-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.c10
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)