return a->addr->ip_equals(a->addr, b->addr);
}
-/**
- * Outbound callback
- */
-static void send_esp(void *data, esp_packet_t *packet)
+CALLBACK(send_esp, void,
+ void *data, esp_packet_t *packet)
{
charon->sender->send_no_marker(charon->sender, (packet_t*)packet);
}
-/**
- * Receiver callback
- */
-static void receiver_esp_cb(void *data, packet_t *packet)
+CALLBACK(receiver_esp_cb, void,
+ void *data, packet_t *packet)
{
ipsec->processor->queue_inbound(ipsec->processor,
esp_packet_create_from_packet(packet));
}
-/**
- * Inbound callback
- */
-static void deliver_plain(private_kernel_libipsec_router_t *this,
- ip_packet_t *packet)
+CALLBACK(deliver_plain, void,
+ private_kernel_libipsec_router_t *this, ip_packet_t *packet)
{
tun_device_t *tun;
tun_entry_t *entry, lookup = {
METHOD(kernel_libipsec_router_t, destroy, void,
private_kernel_libipsec_router_t *this)
{
- charon->receiver->del_esp_cb(charon->receiver,
- (receiver_esp_cb_t)receiver_esp_cb);
- ipsec->processor->unregister_outbound(ipsec->processor,
- (ipsec_outbound_cb_t)send_esp);
- ipsec->processor->unregister_inbound(ipsec->processor,
- (ipsec_inbound_cb_t)deliver_plain);
+ charon->receiver->del_esp_cb(charon->receiver, receiver_esp_cb);
+ ipsec->processor->unregister_outbound(ipsec->processor, send_esp);
+ ipsec->processor->unregister_inbound(ipsec->processor, deliver_plain);
charon->kernel->remove_listener(charon->kernel, &this->public.listener);
this->lock->destroy(this->lock);
this->tuns->destroy(this->tuns);
charon->kernel->add_listener(charon->kernel, &this->public.listener);
ipsec->processor->register_outbound(ipsec->processor, send_esp, NULL);
- ipsec->processor->register_inbound(ipsec->processor,
- (ipsec_inbound_cb_t)deliver_plain, this);
- charon->receiver->add_esp_cb(charon->receiver,
- (receiver_esp_cb_t)receiver_esp_cb, NULL);
+ ipsec->processor->register_inbound(ipsec->processor, deliver_plain, this);
+ charon->receiver->add_esp_cb(charon->receiver, receiver_esp_cb, NULL);
lib->processor->queue_job(lib->processor,
(job_t*)callback_job_create((callback_job_cb_t)handle_plain, this,
NULL, (callback_job_cancel_t)return_false));