OpenCores
URL https://opencores.org/ocsvn/or1k_soc_on_altera_embedded_dev_kit/or1k_soc_on_altera_embedded_dev_kit/trunk

Subversion Repositories or1k_soc_on_altera_embedded_dev_kit

[/] [or1k_soc_on_altera_embedded_dev_kit/] [tags/] [linux-2.6/] [linux-2.6.24_or32_unified_v2.3/] [net/] [ipv6/] [xfrm6_state.c] - Diff between revs 3 and 8

Only display areas with differences | Details | Blame | View Log

Rev 3 Rev 8
/*
/*
 * xfrm6_state.c: based on xfrm4_state.c
 * xfrm6_state.c: based on xfrm4_state.c
 *
 *
 * Authors:
 * Authors:
 *      Mitsuru KANDA @USAGI
 *      Mitsuru KANDA @USAGI
 *      Kazunori MIYAZAWA @USAGI
 *      Kazunori MIYAZAWA @USAGI
 *      Kunihiro Ishiguro <kunihiro@ipinfusion.com>
 *      Kunihiro Ishiguro <kunihiro@ipinfusion.com>
 *              IPv6 support
 *              IPv6 support
 *      YOSHIFUJI Hideaki @USAGI
 *      YOSHIFUJI Hideaki @USAGI
 *              Split up af-specific portion
 *              Split up af-specific portion
 *
 *
 */
 */
 
 
#include <net/xfrm.h>
#include <net/xfrm.h>
#include <linux/pfkeyv2.h>
#include <linux/pfkeyv2.h>
#include <linux/ipsec.h>
#include <linux/ipsec.h>
#include <net/ipv6.h>
#include <net/ipv6.h>
#include <net/addrconf.h>
#include <net/addrconf.h>
 
 
static struct xfrm_state_afinfo xfrm6_state_afinfo;
static struct xfrm_state_afinfo xfrm6_state_afinfo;
 
 
static void
static void
__xfrm6_init_tempsel(struct xfrm_state *x, struct flowi *fl,
__xfrm6_init_tempsel(struct xfrm_state *x, struct flowi *fl,
                     struct xfrm_tmpl *tmpl,
                     struct xfrm_tmpl *tmpl,
                     xfrm_address_t *daddr, xfrm_address_t *saddr)
                     xfrm_address_t *daddr, xfrm_address_t *saddr)
{
{
        /* Initialize temporary selector matching only
        /* Initialize temporary selector matching only
         * to current session. */
         * to current session. */
        ipv6_addr_copy((struct in6_addr *)&x->sel.daddr, &fl->fl6_dst);
        ipv6_addr_copy((struct in6_addr *)&x->sel.daddr, &fl->fl6_dst);
        ipv6_addr_copy((struct in6_addr *)&x->sel.saddr, &fl->fl6_src);
        ipv6_addr_copy((struct in6_addr *)&x->sel.saddr, &fl->fl6_src);
        x->sel.dport = xfrm_flowi_dport(fl);
        x->sel.dport = xfrm_flowi_dport(fl);
        x->sel.dport_mask = htons(0xffff);
        x->sel.dport_mask = htons(0xffff);
        x->sel.sport = xfrm_flowi_sport(fl);
        x->sel.sport = xfrm_flowi_sport(fl);
        x->sel.sport_mask = htons(0xffff);
        x->sel.sport_mask = htons(0xffff);
        x->sel.prefixlen_d = 128;
        x->sel.prefixlen_d = 128;
        x->sel.prefixlen_s = 128;
        x->sel.prefixlen_s = 128;
        x->sel.proto = fl->proto;
        x->sel.proto = fl->proto;
        x->sel.ifindex = fl->oif;
        x->sel.ifindex = fl->oif;
        x->id = tmpl->id;
        x->id = tmpl->id;
        if (ipv6_addr_any((struct in6_addr*)&x->id.daddr))
        if (ipv6_addr_any((struct in6_addr*)&x->id.daddr))
                memcpy(&x->id.daddr, daddr, sizeof(x->sel.daddr));
                memcpy(&x->id.daddr, daddr, sizeof(x->sel.daddr));
        memcpy(&x->props.saddr, &tmpl->saddr, sizeof(x->props.saddr));
        memcpy(&x->props.saddr, &tmpl->saddr, sizeof(x->props.saddr));
        if (ipv6_addr_any((struct in6_addr*)&x->props.saddr))
        if (ipv6_addr_any((struct in6_addr*)&x->props.saddr))
                memcpy(&x->props.saddr, saddr, sizeof(x->props.saddr));
                memcpy(&x->props.saddr, saddr, sizeof(x->props.saddr));
        x->props.mode = tmpl->mode;
        x->props.mode = tmpl->mode;
        x->props.reqid = tmpl->reqid;
        x->props.reqid = tmpl->reqid;
        x->props.family = AF_INET6;
        x->props.family = AF_INET6;
}
}
 
 
static int
static int
__xfrm6_state_sort(struct xfrm_state **dst, struct xfrm_state **src, int n)
__xfrm6_state_sort(struct xfrm_state **dst, struct xfrm_state **src, int n)
{
{
        int i;
        int i;
        int j = 0;
        int j = 0;
 
 
        /* Rule 1: select IPsec transport except AH */
        /* Rule 1: select IPsec transport except AH */
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i]->props.mode == XFRM_MODE_TRANSPORT &&
                if (src[i]->props.mode == XFRM_MODE_TRANSPORT &&
                    src[i]->id.proto != IPPROTO_AH) {
                    src[i]->id.proto != IPPROTO_AH) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
        if (j == n)
        if (j == n)
                goto end;
                goto end;
 
 
        /* Rule 2: select MIPv6 RO or inbound trigger */
        /* Rule 2: select MIPv6 RO or inbound trigger */
#if defined(CONFIG_IPV6_MIP6) || defined(CONFIG_IPV6_MIP6_MODULE)
#if defined(CONFIG_IPV6_MIP6) || defined(CONFIG_IPV6_MIP6_MODULE)
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i] &&
                if (src[i] &&
                    (src[i]->props.mode == XFRM_MODE_ROUTEOPTIMIZATION ||
                    (src[i]->props.mode == XFRM_MODE_ROUTEOPTIMIZATION ||
                     src[i]->props.mode == XFRM_MODE_IN_TRIGGER)) {
                     src[i]->props.mode == XFRM_MODE_IN_TRIGGER)) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
        if (j == n)
        if (j == n)
                goto end;
                goto end;
#endif
#endif
 
 
        /* Rule 3: select IPsec transport AH */
        /* Rule 3: select IPsec transport AH */
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i] &&
                if (src[i] &&
                    src[i]->props.mode == XFRM_MODE_TRANSPORT &&
                    src[i]->props.mode == XFRM_MODE_TRANSPORT &&
                    src[i]->id.proto == IPPROTO_AH) {
                    src[i]->id.proto == IPPROTO_AH) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
        if (j == n)
        if (j == n)
                goto end;
                goto end;
 
 
        /* Rule 4: select IPsec tunnel */
        /* Rule 4: select IPsec tunnel */
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i] &&
                if (src[i] &&
                    (src[i]->props.mode == XFRM_MODE_TUNNEL ||
                    (src[i]->props.mode == XFRM_MODE_TUNNEL ||
                     src[i]->props.mode == XFRM_MODE_BEET)) {
                     src[i]->props.mode == XFRM_MODE_BEET)) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
        if (likely(j == n))
        if (likely(j == n))
                goto end;
                goto end;
 
 
        /* Final rule */
        /* Final rule */
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i]) {
                if (src[i]) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
 
 
 end:
 end:
        return 0;
        return 0;
}
}
 
 
static int
static int
__xfrm6_tmpl_sort(struct xfrm_tmpl **dst, struct xfrm_tmpl **src, int n)
__xfrm6_tmpl_sort(struct xfrm_tmpl **dst, struct xfrm_tmpl **src, int n)
{
{
        int i;
        int i;
        int j = 0;
        int j = 0;
 
 
        /* Rule 1: select IPsec transport */
        /* Rule 1: select IPsec transport */
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i]->mode == XFRM_MODE_TRANSPORT) {
                if (src[i]->mode == XFRM_MODE_TRANSPORT) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
        if (j == n)
        if (j == n)
                goto end;
                goto end;
 
 
        /* Rule 2: select MIPv6 RO or inbound trigger */
        /* Rule 2: select MIPv6 RO or inbound trigger */
#if defined(CONFIG_IPV6_MIP6) || defined(CONFIG_IPV6_MIP6_MODULE)
#if defined(CONFIG_IPV6_MIP6) || defined(CONFIG_IPV6_MIP6_MODULE)
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i] &&
                if (src[i] &&
                    (src[i]->mode == XFRM_MODE_ROUTEOPTIMIZATION ||
                    (src[i]->mode == XFRM_MODE_ROUTEOPTIMIZATION ||
                     src[i]->mode == XFRM_MODE_IN_TRIGGER)) {
                     src[i]->mode == XFRM_MODE_IN_TRIGGER)) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
        if (j == n)
        if (j == n)
                goto end;
                goto end;
#endif
#endif
 
 
        /* Rule 3: select IPsec tunnel */
        /* Rule 3: select IPsec tunnel */
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i] &&
                if (src[i] &&
                    (src[i]->mode == XFRM_MODE_TUNNEL ||
                    (src[i]->mode == XFRM_MODE_TUNNEL ||
                     src[i]->mode == XFRM_MODE_BEET)) {
                     src[i]->mode == XFRM_MODE_BEET)) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
        if (likely(j == n))
        if (likely(j == n))
                goto end;
                goto end;
 
 
        /* Final rule */
        /* Final rule */
        for (i = 0; i < n; i++) {
        for (i = 0; i < n; i++) {
                if (src[i]) {
                if (src[i]) {
                        dst[j++] = src[i];
                        dst[j++] = src[i];
                        src[i] = NULL;
                        src[i] = NULL;
                }
                }
        }
        }
 
 
 end:
 end:
        return 0;
        return 0;
}
}
 
 
static struct xfrm_state_afinfo xfrm6_state_afinfo = {
static struct xfrm_state_afinfo xfrm6_state_afinfo = {
        .family                 = AF_INET6,
        .family                 = AF_INET6,
        .owner                  = THIS_MODULE,
        .owner                  = THIS_MODULE,
        .init_tempsel           = __xfrm6_init_tempsel,
        .init_tempsel           = __xfrm6_init_tempsel,
        .tmpl_sort              = __xfrm6_tmpl_sort,
        .tmpl_sort              = __xfrm6_tmpl_sort,
        .state_sort             = __xfrm6_state_sort,
        .state_sort             = __xfrm6_state_sort,
        .output                 = xfrm6_output,
        .output                 = xfrm6_output,
};
};
 
 
void __init xfrm6_state_init(void)
void __init xfrm6_state_init(void)
{
{
        xfrm_state_register_afinfo(&xfrm6_state_afinfo);
        xfrm_state_register_afinfo(&xfrm6_state_afinfo);
}
}
 
 
void xfrm6_state_fini(void)
void xfrm6_state_fini(void)
{
{
        xfrm_state_unregister_afinfo(&xfrm6_state_afinfo);
        xfrm_state_unregister_afinfo(&xfrm6_state_afinfo);
}
}
 
 
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.