Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
torvalds
GitHub Repository: torvalds/linux
Path: blob/master/security/landlock/setup.c
29265 views
1
// SPDX-License-Identifier: GPL-2.0-only
2
/*
3
* Landlock LSM - Security framework setup
4
*
5
* Copyright © 2016-2020 Mickaël Salaün <[email protected]>
6
* Copyright © 2018-2020 ANSSI
7
*/
8
9
#include <linux/bits.h>
10
#include <linux/init.h>
11
#include <linux/lsm_hooks.h>
12
#include <uapi/linux/lsm.h>
13
14
#include "common.h"
15
#include "cred.h"
16
#include "errata.h"
17
#include "fs.h"
18
#include "id.h"
19
#include "net.h"
20
#include "setup.h"
21
#include "task.h"
22
23
bool landlock_initialized __ro_after_init = false;
24
25
const struct lsm_id landlock_lsmid = {
26
.name = LANDLOCK_NAME,
27
.id = LSM_ID_LANDLOCK,
28
};
29
30
struct lsm_blob_sizes landlock_blob_sizes __ro_after_init = {
31
.lbs_cred = sizeof(struct landlock_cred_security),
32
.lbs_file = sizeof(struct landlock_file_security),
33
.lbs_inode = sizeof(struct landlock_inode_security),
34
.lbs_superblock = sizeof(struct landlock_superblock_security),
35
};
36
37
int landlock_errata __ro_after_init;
38
39
static void __init compute_errata(void)
40
{
41
size_t i;
42
43
#ifndef __has_include
44
/*
45
* This is a safeguard to make sure the compiler implements
46
* __has_include (see errata.h).
47
*/
48
WARN_ON_ONCE(1);
49
return;
50
#endif
51
52
for (i = 0; landlock_errata_init[i].number; i++) {
53
const int prev_errata = landlock_errata;
54
55
if (WARN_ON_ONCE(landlock_errata_init[i].abi >
56
landlock_abi_version))
57
continue;
58
59
landlock_errata |= BIT(landlock_errata_init[i].number - 1);
60
WARN_ON_ONCE(prev_errata == landlock_errata);
61
}
62
}
63
64
static int __init landlock_init(void)
65
{
66
compute_errata();
67
landlock_add_cred_hooks();
68
landlock_add_task_hooks();
69
landlock_add_fs_hooks();
70
landlock_add_net_hooks();
71
landlock_init_id();
72
landlock_initialized = true;
73
pr_info("Up and running.\n");
74
return 0;
75
}
76
77
DEFINE_LSM(LANDLOCK_NAME) = {
78
.name = LANDLOCK_NAME,
79
.init = landlock_init,
80
.blobs = &landlock_blob_sizes,
81
};
82
83