This patch set implements an IMA namespace data structure that gets created alongside a user namespace with CLONE_NEWUSER, and lays down the foundation for namespacing the different aspects of IMA (eg. IMA-audit, IMA-measurement, IMA-appraisal). The original PoC patches [1] created a new CLONE_NEWIMA flag to explicitly control when a new IMA namespace should be created. The previously posted version 2 of this series had it hooked on the mount namespace, which was regarded as inappropriate. Based on comments, we elected to hang the IMA namepace off of the existing user namespace now. In this patch series we are adding a pointer to the user_namespace pointing to the ima_namespace. Both are now tied together and joining the user_namespace with setns() also joins the ima_namespace that was created along with it. The first patch creates the ima_namespace data, while the second patch puts the iint->flags in the namespace. The third patch uses these flags for namespacing the IMA-audit messages, enabling the same file to be audited each time it is accessed in a new namespace. Stefan Mehmet Kayaalp (2): ima: Add ns_status for storing namespaced iint data ima: mamespace audit status flags Yuqiong Sun (1): ima: extend clone() with IMA namespace support include/linux/ima.h | 67 +++++++++ include/linux/user_namespace.h | 4 + init/Kconfig | 10 ++ kernel/user.c | 7 + kernel/user_namespace.c | 18 +++ security/integrity/ima/Makefile | 3 +- security/integrity/ima/ima.h | 47 ++++++- security/integrity/ima/ima_api.c | 8 +- security/integrity/ima/ima_init.c | 4 + security/integrity/ima/ima_init_ima_ns.c | 43 ++++++ security/integrity/ima/ima_main.c | 15 ++- security/integrity/ima/ima_ns.c | 225 +++++++++++++++++++++++++++++++ 12 files changed, 443 insertions(+), 8 deletions(-) create mode 100644 security/integrity/ima/ima_init_ima_ns.c create mode 100644 security/integrity/ima/ima_ns.c -- 2.14.3