From: Martin Willi Date: Wed, 21 Dec 2011 14:02:02 +0000 (+0100) Subject: Queue IKEv1 INFORMATIONALS with higher priority to process notifies first X-Git-Tag: 5.0.0~338^2~9^2~116 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=dc8e964775c63ffa5d6646728115d63f7a19224a;p=thirdparty%2Fstrongswan.git Queue IKEv1 INFORMATIONALS with higher priority to process notifies first --- diff --git a/src/libcharon/sa/ikev1/task_manager_v1.c b/src/libcharon/sa/ikev1/task_manager_v1.c index 2274752091..c0bc03045c 100644 --- a/src/libcharon/sa/ikev1/task_manager_v1.c +++ b/src/libcharon/sa/ikev1/task_manager_v1.c @@ -688,7 +688,7 @@ static status_t process_request(private_task_manager_t *this, break; case INFORMATIONAL_V1: task = (task_t *)informational_create(this->ike_sa, NULL); - this->passive_tasks->insert_last(this->passive_tasks, task); + this->passive_tasks->insert_first(this->passive_tasks, task); break; case TRANSACTION: if (this->ike_sa->get_state(this->ike_sa) == IKE_ESTABLISHED) @@ -904,7 +904,7 @@ METHOD(task_manager_t, process_message, status_t, if ((mid && mid == this->initiating.mid) || (this->initiating.mid == 0 && msg->get_exchange_type(msg) == this->initiating.type && - this->active_tasks->get_count(this->active_tasks))) + this->active_tasks->get_count(this->active_tasks))) { msg->set_request(msg, FALSE); status = parse_message(this, msg);