2021-04-22 23:41:13 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
/*
|
|
|
|
* Landlock LSM - Security framework setup
|
|
|
|
*
|
|
|
|
* Copyright © 2016-2020 Mickaël Salaün <mic@digikod.net>
|
|
|
|
* Copyright © 2018-2020 ANSSI
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/lsm_hooks.h>
|
|
|
|
|
|
|
|
#include "common.h"
|
|
|
|
#include "cred.h"
|
2021-04-22 23:41:17 +08:00
|
|
|
#include "fs.h"
|
2021-04-22 23:41:14 +08:00
|
|
|
#include "ptrace.h"
|
2021-04-22 23:41:13 +08:00
|
|
|
#include "setup.h"
|
|
|
|
|
2021-04-22 23:41:17 +08:00
|
|
|
bool landlock_initialized __lsm_ro_after_init = false;
|
|
|
|
|
2021-04-22 23:41:13 +08:00
|
|
|
struct lsm_blob_sizes landlock_blob_sizes __lsm_ro_after_init = {
|
|
|
|
.lbs_cred = sizeof(struct landlock_cred_security),
|
2021-04-22 23:41:17 +08:00
|
|
|
.lbs_inode = sizeof(struct landlock_inode_security),
|
|
|
|
.lbs_superblock = sizeof(struct landlock_superblock_security),
|
2021-04-22 23:41:13 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static int __init landlock_init(void)
|
|
|
|
{
|
|
|
|
landlock_add_cred_hooks();
|
2021-04-22 23:41:14 +08:00
|
|
|
landlock_add_ptrace_hooks();
|
2021-04-22 23:41:17 +08:00
|
|
|
landlock_add_fs_hooks();
|
|
|
|
landlock_initialized = true;
|
2021-04-22 23:41:13 +08:00
|
|
|
pr_info("Up and running.\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
DEFINE_LSM(LANDLOCK_NAME) = {
|
|
|
|
.name = LANDLOCK_NAME,
|
|
|
|
.init = landlock_init,
|
|
|
|
.blobs = &landlock_blob_sizes,
|
|
|
|
};
|