diff options
author | Harald Welte <laforge@gnumonks.org> | 2018-04-25 21:13:06 +0200 |
---|---|---|
committer | Harald Welte <laforge@gnumonks.org> | 2018-04-25 21:13:06 +0200 |
commit | 76be86b201dfc51c81a4f58369ec61d881bbed81 (patch) | |
tree | 64f9ff88e238da33a738bfb13120637c51bcfa72 | |
parent | 0406bdde75fc200754021f356c481059bae42b33 (diff) |
ggsn: don't use gtp_kernel_tunnel_{add,del}() for userspace tunlaforge/kernel-fixes
Change-Id: I00cc8eb8c4d44532f975f78783ff4e12814b3416
-rw-r--r-- | ggsn/ggsn.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/ggsn/ggsn.c b/ggsn/ggsn.c index 2b0581e..6ff1312 100644 --- a/ggsn/ggsn.c +++ b/ggsn/ggsn.c @@ -380,9 +380,11 @@ static int delete_context(struct pdp_t *pdp) LOGPPDP(LOGL_ERROR, pdp, "Cannot find/free IP Pool member\n"); } - if (gtp_kernel_tunnel_del(pdp, apn->tun.cfg.dev_name)) { - LOGPPDP(LOGL_ERROR, pdp, "Cannot delete tunnel from kernel:%s\n", - strerror(errno)); + if (apn->cfg.gtpu_mode == APN_GTPU_MODE_KERNEL_GTP) { + if (gtp_kernel_tunnel_del(pdp, apn->tun.cfg.dev_name)) { + LOGPPDP(LOGL_ERROR, pdp, "Cannot delete tunnel from kernel:%s\n", + strerror(errno)); + } } return 0; @@ -688,7 +690,7 @@ int create_context_ind(struct pdp_t *pdp) in46a_to_eua(addr, num_addr, &pdp->eua); - if (apn_supports_ipv4(apn)) { + if (apn->cfg.gtpu_mode == APN_GTPU_MODE_KERNEL_GTP && apn_supports_ipv4(apn)) { /* TODO: In IPv6, EUA doesn't contain the actual IP addr/prefix! */ if (gtp_kernel_tunnel_add(pdp, apn->tun.cfg.dev_name) < 0) { LOGPPDP(LOGL_ERROR, pdp, "Cannot add tunnel to kernel: %s\n", strerror(errno)); |