File: reqid.h

package info (click to toggle)
libreswan 5.2-2.3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 81,644 kB
  • sloc: ansic: 129,988; sh: 32,018; xml: 20,646; python: 10,303; makefile: 3,022; javascript: 1,506; sed: 574; yacc: 511; perl: 264; awk: 52
file content (53 lines) | stat: -rw-r--r-- 1,771 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/* reqid definitions, for libreswan
 *
 * Copyright (C) 2014 D. Hugh Redelmeier <hugh@mimosa.com>
 *
 * This library is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Library General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or (at your
 * option) any later version.  See <https://www.gnu.org/licenses/lgpl-2.1.txt>.
 *
 * This library is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Library General Public
 * License for more details.
 */

#ifndef REQID_H
#define REQID_H

#include <stdint.h>		/* for uint32_t */

/*
 * reqid definitions
 *
 * A reqid is a numerical identifier used to match IPsec SAs using
 * iptables with NETKEY/XFRM. This identifier is normally
 * automatically allocated.  It is exported to the _updown script as
 * REQID. On Linux, reqids are supported with IP Connection Tracking
 * and NAT (iptables).  Automatically generated values use the range
 * 16384 and higher.  Manually specified reqid values therefore must
 * be between 1 and 16383.
 *
 * Automatically generated reqids are allocated in groups of four, one
 * for each potential SA and pseudo SA in an SA bundle.  Their number
 * will be above 16380.  The base number will be a multiple of four.
 *
 * Manually assigned reqids are all identical for a particular connection
 * and its instantiations.
 */

typedef uint32_t reqid_t;

#define PRI_REQID "%"PRIu32
#define pri_reqid(ID) ID

#define IPSEC_MANUAL_REQID_MAX  0x3fff

reqid_t gen_reqid(void);

reqid_t reqid_ah(reqid_t r);
reqid_t reqid_esp(reqid_t r);
reqid_t reqid_ipcomp(reqid_t r);

#endif