summaryrefslogtreecommitdiff
path: root/accel-pppd/ppp/lcp_opt_magic.c
diff options
context:
space:
mode:
authorDmitry Kozlov <xeb@mail.ru>2014-08-26 11:18:29 +0400
committerDmitry Kozlov <xeb@mail.ru>2014-08-26 11:18:29 +0400
commit538246933be69bb539811ca15c98725c9736a22b (patch)
tree1cf655304e63f14c10d89cd043338776297222da /accel-pppd/ppp/lcp_opt_magic.c
parent0f036dcf3085880ef18786abf40f5d2e6c1b97fc (diff)
downloadaccel-ppp-538246933be69bb539811ca15c98725c9736a22b.tar.gz
accel-ppp-538246933be69bb539811ca15c98725c9736a22b.zip
ppp: make LCP magic number negotiation not mandatory
Diffstat (limited to 'accel-pppd/ppp/lcp_opt_magic.c')
-rw-r--r--accel-pppd/ppp/lcp_opt_magic.c34
1 files changed, 25 insertions, 9 deletions
diff --git a/accel-pppd/ppp/lcp_opt_magic.c b/accel-pppd/ppp/lcp_opt_magic.c
index bf392091..81eadd6d 100644
--- a/accel-pppd/ppp/lcp_opt_magic.c
+++ b/accel-pppd/ppp/lcp_opt_magic.c
@@ -13,6 +13,7 @@ static void magic_free(struct ppp_lcp_t *lcp, struct lcp_option_t *opt);
static int magic_send_conf_req(struct ppp_lcp_t *lcp, struct lcp_option_t *opt, uint8_t *ptr);
static int magic_send_conf_nak(struct ppp_lcp_t *lcp, struct lcp_option_t *opt, uint8_t *ptr);
static int magic_recv_conf_req(struct ppp_lcp_t *lcp, struct lcp_option_t *opt, uint8_t *ptr);
+static int magic_recv_conf_rej(struct ppp_lcp_t *lcp, struct lcp_option_t *opt, uint8_t *ptr);
static void magic_print(void (*print)(const char *fmt,...),struct lcp_option_t*, uint8_t *ptr);
struct magic_option_t
@@ -27,6 +28,7 @@ static struct lcp_option_handler_t magic_opt_hnd=
.send_conf_req = magic_send_conf_req,
.send_conf_nak = magic_send_conf_nak,
.recv_conf_req = magic_recv_conf_req,
+ .recv_conf_rej = magic_recv_conf_rej,
.free = magic_free,
.print = magic_print,
};
@@ -35,7 +37,7 @@ static struct lcp_option_t *magic_init(struct ppp_lcp_t *lcp)
{
struct magic_option_t *magic_opt = _malloc(sizeof(*magic_opt));
memset(magic_opt, 0, sizeof(*magic_opt));
- magic_opt->magic = random();
+ do { magic_opt->magic = random(); } while (magic_opt->magic == 0);
magic_opt->opt.id = CI_MAGIC;
magic_opt->opt.len = 6;
@@ -53,21 +55,25 @@ static void magic_free(struct ppp_lcp_t *lcp, struct lcp_option_t *opt)
static int magic_send_conf_req(struct ppp_lcp_t *lcp, struct lcp_option_t *opt, uint8_t *ptr)
{
- struct magic_option_t *magic_opt=container_of(opt,typeof(*magic_opt),opt);
+ struct magic_option_t *magic_opt = container_of(opt, typeof(*magic_opt), opt);
struct lcp_opt32_t *opt32 = (struct lcp_opt32_t *)ptr;
- opt32->hdr.id=CI_MAGIC;
- opt32->hdr.len=6;
- opt32->val=htonl(magic_opt->magic);
+
+ if (!magic_opt->magic)
+ return 0;
+
+ opt32->hdr.id = CI_MAGIC;
+ opt32->hdr.len = 6;
+ opt32->val = htonl(magic_opt->magic);
return 6;
}
static int magic_send_conf_nak(struct ppp_lcp_t *lcp, struct lcp_option_t *opt, uint8_t *ptr)
{
- struct magic_option_t *magic_opt=container_of(opt,typeof(*magic_opt),opt);
+ struct magic_option_t *magic_opt = container_of(opt, typeof(*magic_opt), opt);
struct lcp_opt32_t *opt32 = (struct lcp_opt32_t *)ptr;
- opt32->hdr.id=CI_MAGIC;
- opt32->hdr.len=6;
- opt32->val=random();
+ opt32->hdr.id = CI_MAGIC;
+ opt32->hdr.len = 6;
+ do { opt32->val = random(); } while (opt32->val == magic_opt->magic);
return 6;
}
@@ -88,6 +94,16 @@ static int magic_recv_conf_req(struct ppp_lcp_t *lcp, struct lcp_option_t *opt,
return LCP_OPT_ACK;
}
+static int magic_recv_conf_rej(struct ppp_lcp_t *lcp, struct lcp_option_t *opt, uint8_t *ptr)
+{
+ struct magic_option_t *magic_opt = container_of(opt, typeof(*magic_opt), opt);
+
+ magic_opt->magic = 0;
+ lcp->magic = 0;
+
+ return 0;
+}
+
static void magic_print(void (*print)(const char *fmt,...),struct lcp_option_t *opt, uint8_t *ptr)
{
struct magic_option_t *magic_opt = container_of(opt, typeof(*magic_opt), opt);