On Fri, Jul 1, 2016 at 2:21 PM, Daniel Jurgens <danielj@xxxxxxxxxxxx> wrote: > On 7/1/2016 11:29 AM, Paul Moore wrote: >> On Thu, Jun 23, 2016 at 3:52 PM, Dan Jurgens <danielj@xxxxxxxxxxxx> wrote: >>> From: Daniel Jurgens <danielj@xxxxxxxxxxxx> >>> >>> Add a type and access vector for PKeys. Implement the qp_pkey_access >>> and mad_agent_pkey_access hooks to check that the caller has >>> permission to access the PKey on the given subnet prefix. Add an >>> interface to get the PKey SID. Walk the PKey ocontexts to find an entry >>> for the given subnet prefix and pkey. >>> >>> Signed-off-by: Daniel Jurgens <danielj@xxxxxxxxxxxx> >>> Reviewed-by: Eli Cohen <eli@xxxxxxxxxxxx> >>> --- >>> include/linux/lsm_audit.h | 7 ++++ >>> security/selinux/hooks.c | 41 ++++++++++++++++++++++++ >>> security/selinux/include/classmap.h | 2 ++ >>> security/selinux/include/initial_sid_to_string.h | 1 + >>> security/selinux/include/security.h | 2 ++ >>> security/selinux/ss/services.c | 41 ++++++++++++++++++++++++ >>> 6 files changed, 94 insertions(+) >>> >>> diff --git a/include/linux/lsm_audit.h b/include/linux/lsm_audit.h >>> index ffb9c9d..8ff7eae 100644 >>> --- a/include/linux/lsm_audit.h >>> +++ b/include/linux/lsm_audit.h >>> @@ -45,6 +45,11 @@ struct lsm_ioctlop_audit { >>> u16 cmd; >>> }; >>> >>> +struct lsm_pkey_audit { >>> + u64 subnet_prefix; >>> + u16 pkey; >>> +}; >>> + >>> /* Auxiliary data to use in generating the audit record. */ >>> struct common_audit_data { >>> char type; >>> @@ -59,6 +64,7 @@ struct common_audit_data { >>> #define LSM_AUDIT_DATA_INODE 9 >>> #define LSM_AUDIT_DATA_DENTRY 10 >>> #define LSM_AUDIT_DATA_IOCTL_OP 11 >>> +#define LSM_AUDIT_DATA_PKEY 12 >>> union { >>> struct path path; >>> struct dentry *dentry; >>> @@ -75,6 +81,7 @@ struct common_audit_data { >>> #endif >>> char *kmod_name; >>> struct lsm_ioctlop_audit *op; >>> + struct lsm_pkey_audit *pkey; >>> } u; >>> /* this union contains LSM specific data */ >>> union { >> Please correct me if I'm wrong, but I don't recall seeing any code in >> the patchset which actually logs the extra IB information in the audit >> record, did I miss it? > > I didn't make any changes to the audit logging. The messages look like this. > [245259.895597] audit: type=1400 audit(1467392186.710:631): avc: denied { access } for pid=27519 comm="ib_write_bw" scontext=root:sysadm_r:sysadm_t:s0 tcontext=system_u:object_r:staff_allowed_pkey_t:s0 tclass=infiniband_pkey permissive=1 So why are you adding fields to the common_audit_data structure? If you don't think the IB specific data is worth recording in the audit log, don't record it in the structure. If you do believe it is important to record these IB details, please write the necessary code. >> I wondered about this earlier in the patchset when we were discussing >> the policy format, and I'm still wondering; perhaps you can help me >> understand IB a bit better ... >> >> From what I gather, the partition key is the IB security boundary, not >> the subnet, is that true? If so, why are we including the subnet with >> the partition key value/label? I understand the low/high pkey range >> as a way of simplifying the policy, but I don't quite understand the >> point of tying the subnet to the partition key label. Would you ever >> want to have multiple labels for a single partition key, or should it >> be a single label for the partition key regardless of the subnet? >> > Each subnet can have a different partition configuration and a node can be on multiple subnets. By specifying the subnet prefix along with the pkey value the user has flexibility to have different policy for different subnets, instead of a global PKey space that would require coordinating the partition configuration across all subnets. Perhaps a better explanation of partitions and subnets are in order, especially for those of like me who are new to IB. -- paul moore security @ redhat _______________________________________________ Selinux mailing list Selinux@xxxxxxxxxxxxx To unsubscribe, send email to Selinux-leave@xxxxxxxxxxxxx. To get help, send an email containing "help" to Selinux-request@xxxxxxxxxxxxx.