diff options
-rw-r--r-- | sys/netinet/ip_output.c | 89 |
1 files changed, 24 insertions, 65 deletions
diff --git a/sys/netinet/ip_output.c b/sys/netinet/ip_output.c index 36e911f76be..5ccf119abe8 100644 --- a/sys/netinet/ip_output.c +++ b/sys/netinet/ip_output.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip_output.c,v 1.38 1999/01/08 21:51:22 provos Exp $ */ +/* $OpenBSD: ip_output.c,v 1.39 1999/01/11 00:42:53 angelos Exp $ */ /* $NetBSD: ip_output.c,v 1.28 1996/02/13 23:43:07 christos Exp $ */ /* @@ -369,70 +369,6 @@ ip_output(m0, va_alist) return ENXIO; } - /* Check for tunneling */ - if ((tdb->tdb_flags & TDBF_TUNNELING) && - (tdb->tdb_xform->xf_type != XF_IP4)){ -#ifdef ENCDEBUG - if (encdebug) - printf("ip_output(): tunneling\n"); -#endif /* ENCDEBUG */ - - /* - * Register first use, - * setup expiration timer - */ - if (tdb->tdb_first_use == 0) { - tdb->tdb_first_use = time.tv_sec; - - if (tdb->tdb_flags & TDBF_FIRSTUSE) { - exp = get_expiration(); - if (exp == NULL) - goto expbail; - exp->exp_dst.s_addr = - tdb->tdb_dst.s_addr; - exp->exp_spi = tdb->tdb_spi; - exp->exp_sproto = - tdb->tdb_sproto; - exp->exp_timeout = - tdb->tdb_first_use + - tdb->tdb_exp_first_use; - put_expiration(exp); - } - - if ((tdb->tdb_flags & - TDBF_SOFT_FIRSTUSE) && - (tdb->tdb_soft_first_use <= - tdb->tdb_exp_first_use)) { - exp = get_expiration(); - if (exp == NULL) - goto expbail; - exp->exp_dst.s_addr = - tdb->tdb_dst.s_addr; - exp->exp_spi = tdb->tdb_spi; - exp->exp_sproto = - tdb->tdb_sproto; - exp->exp_timeout = - tdb->tdb_first_use + - tdb->tdb_soft_first_use; - put_expiration(exp); - } - } - - /* - * Fix checksum here, AH and ESP fix the - * checksum in their output routines. - */ - ip->ip_sum = in_cksum(m, hlen); - error = ipe4_output(m, gw, tdb, &mp); - if (mp == NULL) - error = EFAULT; - if (error) { - RTFREE(re->re_rt); - return error; - } - m = mp; - } - #ifdef ENCDEBUG if (encdebug) printf("ip_output(): calling %s\n", @@ -478,6 +414,29 @@ expbail: } } + /* Check for tunneling */ + if ((tdb->tdb_flags & TDBF_TUNNELING) && + (tdb->tdb_xform->xf_type != XF_IP4)){ +#ifdef ENCDEBUG + if (encdebug) + printf("ip_output(): tunneling\n"); +#endif /* ENCDEBUG */ + + /* + * Fix checksum here, AH and ESP fix the + * checksum in their output routines. + */ + ip->ip_sum = in_cksum(m, hlen); + error = ipe4_output(m, gw, tdb, &mp); + if (mp == NULL) + error = EFAULT; + if (error) { + RTFREE(re->re_rt); + return error; + } + m = mp; + } + if (tdb->tdb_xform->xf_type == XF_IP4) { /* * Fix checksum if IP-IP; AH and ESP fix the |