Skip to content

Commit 4ea61dc

Browse files
spellingmistaketobiasbrunner
authored andcommitted
kernel-interface: Make first reqid configurable
This can be helpful to reserve low reqids for manual configuration. Signed-off-by: Thomas Egerer <[email protected]>
1 parent 27da024 commit 4ea61dc

File tree

3 files changed

+20
-5
lines changed

3 files changed

+20
-5
lines changed

conf/options/charon.opt

+3
Original file line numberDiff line numberDiff line change
@@ -405,6 +405,9 @@ charon.routing_table
405405
charon.routing_table_prio
406406
Priority of the routing table.
407407

408+
charon.reqid_base = 1
409+
Value of the first reqid to be automatically assigned to a CHILD_SA.
410+
408411
charon.rsa_pss = no
409412
Whether to use RSA with PSS padding instead of PKCS#1 padding by default.
410413

src/libcharon/kernel/kernel_interface.c

+15-4
Original file line numberDiff line numberDiff line change
@@ -115,6 +115,11 @@ struct private_kernel_interface_t {
115115
*/
116116
linked_list_t *listeners;
117117

118+
/**
119+
* Reqid to assign next
120+
*/
121+
uint32_t next_reqid;
122+
118123
/**
119124
* Reqid entries indexed by reqids
120125
*/
@@ -373,9 +378,7 @@ METHOD(kernel_interface_t, alloc_reqid, status_t,
373378
mark_t mark_in, mark_t mark_out, uint32_t if_id_in, uint32_t if_id_out,
374379
sec_label_t *label, uint32_t *reqid)
375380
{
376-
static uint32_t counter = 0;
377381
reqid_entry_t *entry = NULL, *tmpl;
378-
status_t status = SUCCESS;
379382

380383
INIT(tmpl,
381384
.local = array_from_ts_list(local_ts),
@@ -415,7 +418,13 @@ METHOD(kernel_interface_t, alloc_reqid, status_t,
415418
entry = tmpl;
416419
if (!array_remove(this->released_reqids, ARRAY_HEAD, &entry->reqid))
417420
{
418-
entry->reqid = ++counter;
421+
if (!this->next_reqid)
422+
{
423+
this->mutex->unlock(this->mutex);
424+
reqid_entry_destroy(entry);
425+
return OUT_OF_RES;
426+
}
427+
entry->reqid = this->next_reqid++;
419428
}
420429
this->reqids_by_ts->put(this->reqids_by_ts, entry, entry);
421430
this->reqids->put(this->reqids, entry, entry);
@@ -425,7 +434,7 @@ METHOD(kernel_interface_t, alloc_reqid, status_t,
425434
entry->refs++;
426435
this->mutex->unlock(this->mutex);
427436

428-
return status;
437+
return SUCCESS;
429438
}
430439

431440
METHOD(kernel_interface_t, release_reqid, status_t,
@@ -1105,6 +1114,8 @@ kernel_interface_t *kernel_interface_create()
11051114
(hashtable_equals_t)equals_reqid, 8),
11061115
.reqids_by_ts = hashtable_create((hashtable_hash_t)hash_reqid_by_ts,
11071116
(hashtable_equals_t)equals_reqid_by_ts, 8),
1117+
.next_reqid = lib->settings->get_int(lib->settings, "%s.reqid_base", 1,
1118+
lib->ns) ?: 1,
11081119
);
11091120

11101121
ifaces = lib->settings->get_str(lib->settings,

src/libcharon/kernel/kernel_interface.h

+2-1
Original file line numberDiff line numberDiff line change
@@ -147,7 +147,8 @@ struct kernel_interface_t {
147147
* @param if_id_out outbound interface ID on SA
148148
* @param label security label (usually the one on the policy, not SA)
149149
* @param reqid allocated reqid
150-
* @return SUCCESS if reqid allocated
150+
* @return SUCCESS if reqid allocated, OUT_OF_RES if no reqid is
151+
* available due to an overflow
151152
*/
152153
status_t (*alloc_reqid)(kernel_interface_t *this,
153154
linked_list_t *local_ts, linked_list_t *remote_ts,

0 commit comments

Comments
 (0)