aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2010-07-06 12:46:40 +0200
committerTobias Brunner <tobias@strongswan.org>2010-09-02 19:01:24 +0200
commit4e258e63c3771509ff529a6369aa4bd44d5fb882 (patch)
tree63f89238230606693c138003eaaf3feaa13b59ed /src
parent01563352e8f95c24d50cb7e987aa9afed639dd44 (diff)
downloadstrongswan-4e258e63c3771509ff529a6369aa4bd44d5fb882.tar.bz2
strongswan-4e258e63c3771509ff529a6369aa4bd44d5fb882.tar.xz
Moved migrate job creation to kernel event handler.
Diffstat (limited to 'src')
-rw-r--r--src/libcharon/kernel/kernel_handler.c19
-rw-r--r--src/libcharon/plugins/kernel_netlink/kernel_netlink_ipsec.c9
-rw-r--r--src/libcharon/plugins/kernel_pfkey/kernel_pfkey_ipsec.c9
3 files changed, 22 insertions, 15 deletions
diff --git a/src/libcharon/kernel/kernel_handler.c b/src/libcharon/kernel/kernel_handler.c
index b4fe1efed..4fae6cde2 100644
--- a/src/libcharon/kernel/kernel_handler.c
+++ b/src/libcharon/kernel/kernel_handler.c
@@ -18,8 +18,9 @@
#include <hydra.h>
#include <daemon.h>
#include <processing/jobs/acquire_job.h>
-#include <processing/jobs/rekey_child_sa_job.h>
#include <processing/jobs/delete_child_sa_job.h>
+#include <processing/jobs/migrate_job.h>
+#include <processing/jobs/rekey_child_sa_job.h>
#include <processing/jobs/update_sa_job.h>
typedef struct private_kernel_handler_t private_kernel_handler_t;
@@ -87,6 +88,21 @@ METHOD(kernel_listener_t, mapping, bool,
return TRUE;
}
+METHOD(kernel_listener_t, migrate, bool,
+ private_kernel_handler_t *this, u_int32_t reqid,
+ traffic_selector_t *src_ts, traffic_selector_t *dst_ts,
+ policy_dir_t direction, host_t *local, host_t *remote)
+{
+ job_t *job;
+ DBG1(DBG_KNL, "creating migrate job for policy %R === %R %N with "
+ "reqid {%u}", src_ts, dst_ts, policy_dir_names, direction,
+ reqid, local);
+ job = (job_t*)migrate_job_create(reqid, src_ts, dst_ts, direction, local,
+ remote);
+ hydra->processor->queue_job(hydra->processor, job);
+ return TRUE;
+}
+
METHOD(kernel_handler_t, destroy, void,
private_kernel_handler_t *this)
{
@@ -105,6 +121,7 @@ kernel_handler_t *kernel_handler_create()
.acquire = _acquire,
.expire = _expire,
.mapping = _mapping,
+ .migrate = _migrate,
},
.destroy = _destroy,
},
diff --git a/src/libcharon/plugins/kernel_netlink/kernel_netlink_ipsec.c b/src/libcharon/plugins/kernel_netlink/kernel_netlink_ipsec.c
index 8d4d2c933..6d971bdbc 100644
--- a/src/libcharon/plugins/kernel_netlink/kernel_netlink_ipsec.c
+++ b/src/libcharon/plugins/kernel_netlink/kernel_netlink_ipsec.c
@@ -41,7 +41,6 @@
#include <threading/mutex.h>
#include <utils/hashtable.h>
#include <processing/jobs/callback_job.h>
-#include <processing/jobs/migrate_job.h>
/** required for Linux 2.6.26 kernel and later */
#ifndef XFRM_STATE_AF_UNSPEC
@@ -632,7 +631,6 @@ static void process_migrate(private_kernel_netlink_ipsec_t *this, struct nlmsghd
size_t rtasize;
u_int32_t reqid = 0;
policy_dir_t dir;
- job_t *job;
policy_id = (struct xfrm_userpolicy_id*)NLMSG_DATA(hdr);
rta = XFRM_RTA(hdr, struct xfrm_userpolicy_id);
@@ -683,11 +681,8 @@ static void process_migrate(private_kernel_netlink_ipsec_t *this, struct nlmsghd
if (src_ts && dst_ts && local && remote)
{
- DBG1(DBG_KNL, "creating migrate job for policy %R === %R %N with reqid {%u}",
- src_ts, dst_ts, policy_dir_names, dir, reqid, local);
- job = (job_t*)migrate_job_create(reqid, src_ts, dst_ts, dir,
- local, remote);
- hydra->processor->queue_job(hydra->processor, job);
+ charon->kernel_interface->migrate(charon->kernel_interface, reqid,
+ src_ts, dst_ts, dir, local, remote);
}
else
{
diff --git a/src/libcharon/plugins/kernel_pfkey/kernel_pfkey_ipsec.c b/src/libcharon/plugins/kernel_pfkey/kernel_pfkey_ipsec.c
index 28cc98021..91e46cbf2 100644
--- a/src/libcharon/plugins/kernel_pfkey/kernel_pfkey_ipsec.c
+++ b/src/libcharon/plugins/kernel_pfkey/kernel_pfkey_ipsec.c
@@ -60,7 +60,6 @@
#include <threading/thread.h>
#include <threading/mutex.h>
#include <processing/jobs/callback_job.h>
-#include <processing/jobs/migrate_job.h>
/** non linux specific */
#ifndef IPPROTO_COMP
@@ -982,7 +981,6 @@ static void process_migrate(private_kernel_pfkey_ipsec_t *this, struct sadb_msg*
policy_dir_t dir;
u_int32_t reqid = 0;
host_t *local = NULL, *remote = NULL;
- job_t *job;
DBG2(DBG_KNL, "received an SADB_X_MIGRATE");
@@ -1014,11 +1012,8 @@ static void process_migrate(private_kernel_pfkey_ipsec_t *this, struct sadb_msg*
if (src_ts && dst_ts && local && remote)
{
- DBG1(DBG_KNL, "creating migrate job for policy %R === %R %N with reqid {%u}",
- src_ts, dst_ts, policy_dir_names, dir, reqid, local);
- job = (job_t*)migrate_job_create(reqid, src_ts, dst_ts, dir,
- local, remote);
- hydra->processor->queue_job(hydra->processor, job);
+ charon->kernel_interface->migrate(charon->kernel_interface, reqid,
+ src_ts, dst_ts, dir, local, remote);
}
else
{