blob: f8667a3fda9ee2797d493e2701913ef3c1f93d82 [file] [log] [blame]
Thomas Gleixner1ccea772019-05-19 15:51:43 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Huw Daviescb72d382016-06-27 15:02:46 -04002/*
3 * CALIPSO - Common Architecture Label IPv6 Security Option
4 *
5 * This is an implementation of the CALIPSO protocol as specified in
6 * RFC 5570.
7 *
8 * Authors: Paul Moore <paul@paul-moore.com>
9 * Huw Davies <huw@codeweavers.com>
Huw Daviescb72d382016-06-27 15:02:46 -040010 */
11
12/*
13 * (c) Copyright Hewlett-Packard Development Company, L.P., 2006
14 * (c) Copyright Huw Davies <huw@codeweavers.com>, 2015
Huw Daviescb72d382016-06-27 15:02:46 -040015 */
16
17#ifndef _CALIPSO_H
18#define _CALIPSO_H
19
20#include <linux/types.h>
21#include <linux/rcupdate.h>
22#include <linux/list.h>
23#include <linux/net.h>
24#include <linux/skbuff.h>
25#include <net/netlabel.h>
26#include <net/request_sock.h>
Reshetova, Elenaedcd9272017-07-04 15:53:06 +030027#include <linux/refcount.h>
Huw Daviescb72d382016-06-27 15:02:46 -040028#include <asm/unaligned.h>
29
30/* known doi values */
31#define CALIPSO_DOI_UNKNOWN 0x00000000
32
33/* doi mapping types */
34#define CALIPSO_MAP_UNKNOWN 0
35#define CALIPSO_MAP_PASS 2
36
37/*
38 * CALIPSO DOI definitions
39 */
40
41/* DOI definition struct */
42struct calipso_doi {
43 u32 doi;
44 u32 type;
45
Reshetova, Elenaedcd9272017-07-04 15:53:06 +030046 refcount_t refcount;
Huw Daviescb72d382016-06-27 15:02:46 -040047 struct list_head list;
48 struct rcu_head rcu;
49};
50
Huw Davies4fee5242016-06-27 15:06:17 -040051/*
52 * Sysctl Variables
53 */
54extern int calipso_cache_enabled;
55extern int calipso_cache_bucketsize;
56
Huw Daviescb72d382016-06-27 15:02:46 -040057#ifdef CONFIG_NETLABEL
58int __init calipso_init(void);
59void calipso_exit(void);
Huw Davies2e532b72016-06-27 15:06:17 -040060bool calipso_validate(const struct sk_buff *skb, const unsigned char *option);
Huw Daviescb72d382016-06-27 15:02:46 -040061#else
62static inline int __init calipso_init(void)
63{
64 return 0;
65}
66
67static inline void calipso_exit(void)
68{
69}
Huw Davies2e532b72016-06-27 15:06:17 -040070static inline bool calipso_validate(const struct sk_buff *skb,
71 const unsigned char *option)
72{
73 return true;
74}
Huw Daviescb72d382016-06-27 15:02:46 -040075#endif /* CONFIG_NETLABEL */
76
77#endif /* _CALIPSO_H */