On Fri, Jun 28, 2019 at 1:22 PM Casey Schaufler <casey@xxxxxxxxxxxxxxxx> wrote: > > On 6/27/2019 5:47 PM, Xing, Cedric wrote: > >> From: Casey Schaufler [mailto:casey@xxxxxxxxxxxxxxxx] > >> Sent: Thursday, June 27, 2019 4:37 PM > >>>> This code should not be mixed in with the LSM infrastructure. > >>>> It should all be contained in its own module, under security/enclave. > >>> lsm_ema is *intended* to be part of the LSM infrastructure. > >> That's not going to fly, not for a minute. > > Why not, if there's a need for it? > > > > And what's the concern here if it becomes part of the LSM infrastructure. > > The LSM infrastructure provides a framework for hooks > and allocation of blobs. That's it. It's a layer for > connecting system features like VFS, IPC and the IP stack > to the security modules. It does not implement any policy > of it's own. We are not going to implement SGX or any other > mechanism within the LSM infrastructure. I don't think you understand the purpose of this code. It isn't implementing SGX, nor is it needed by SGX. It is providing shared infrastructure for security modules, similar to lsm_audit.c, so that security modules can enforce W^X or similar memory protection guarantees for SGX enclave memory, which has unique properties that render the existing mmap and mprotect hooks insufficient. They can certainly implement it only for SELinux, but then any other security module that wants to provide such guarantees will have to replicate that code. > > >>> It is going to be shared among all LSMs that would like to track > >> enclave pages and their origins. > >> > >> That's true for InfiniBand, tun and sctp as well. Look at their > >> implementations. > > As far as I can tell, InfiniBand, tun and sctp, all of them seemed used inside SELinux only. > > So? > > > If you had a chance to look at v1 of my series, I started by burying everything inside SELinux too. But Stephen pointed out such tracking would be needed by all LSMs so code duplication might be a concern. Thus I responded by moving it into LSM infrastructure. > > What you need to do is move all the lsm_ema code into its own > place (which could be security/enclave). Manage your internal > data as you like. LSMs (e.g. SELinux) can call your APIs if > needed. If the LSMs need to store SGX information with the file > structure they need to include that in the space they ask for in > the file blob. > > > >>> And they could be extended to store more information as deemed > >> appropriate by the LSM module. > >> > >> Which is what blobs are for, but that does not appear to be how > >> you're using either the file blob or your new ema blob. > > A lsm_ema_map pointer is stored in file->f_security. > > That's up to the individual security module to decide. > > > Each lsm_ema_map contains a list of lsm_ema structures. In my last patch, SELinux stores a ema_security_struct with every ema, by setting selinux_blob_sizes.lbs_ema_data to sizeof(ema_security_struct). > > You are managing the ema map lists. You don't need the LSM > infrastructure to do that. > > > ema_security_struct is initialized in selinux_enclave_load(), and checked in enclave_mprotect(), which is a subroutine of selinux_file_mprotect(). BTW, it is alloced/freed automatically by LSM infrastructure in security_enclave_load()/security_file_free(). > > Do you mean security_enclave_load()/security_enclave_free() ? > There is no way you can possibly have sane behavior if you're > allocation and free aren't tied to the same blob. > > >>> The last patch of this series shows how to extend EMA inside SELinux. > >> I don't see (but I admit the code doesn't make a lot of sense to me) > >> anything you couldn't do in the SELinux code by adding data to the > >> file blob. The data you're adding to the LSM infrastructure doesn't > >> belong there, and it doesn't need to be there. > > You are correct. My v1 did it inside SELinux. > > > > The key question I think is whether only SELinux needs it, or all LSMs need it. Stephen thought it was the latter (and I agree with him) so I moved it into the LSM infrastructure to be shared, just like the auditing code. > > You are both right that it doesn't belong in the SELinux code. > It also doesn't belong as part of the LSM infrastructure. > > >>>> Not acceptable for the LSM infrastructure. They > >>>> are inconsistent with the way data is used there. > >>> I'm not sure I understand this comment. > >> It means that your definition and use of the lsm_ema_blob > >> does not match the way other blobs are managed and used. > >> The LSM infrastructure uses these entries in a very particular > >> way, and you're trying to use it differently. Your might be > >> able to change the rest of the enclave system to use it > >> correctly, or you might be able to find a different place > >> for it. > > I'm still not sure why you think this (lbs_ema_data) is inconsistent with other blobs. > > > > Same as all other blobs, an LSM requests it by storing the needed size in it, and is assigned an offset, and the buffer is allocated/freed by the infrastructure. Am I missing anything? > > Yes. Aside from allocation and deletion the infrastructure does > nothing with the blobs. The blobs are used only by the security > modules. All other data is maintained and used elsewhere. SGX > specific data needs to me maintained and managed elsewhere. > > >>> As I stated in the cover letter, the primary question is how to > >> prevent SGX from being abused as a backdoor to make executable pages > >> that would otherwise not be executable without SGX. Any LSM module > >> unaware of that would leave that "hole" open. So tracking enclave pages > >> will become a common task for all LSMs that care page protections, and > >> that's why I place it inside LSM infrastructure. > >> > >> Page protections are an important part of many security features, > >> but that's beside the point. The LSM system provides mechanism for > >> providing additional restrictions to existing security mechanisms. > >> First, you create the security mechanism (e.g. enclaves) then you > >> add LSM hooks so that security modules (e.g. SELinux) can apply > >> their own policies in addition. In support of this, the LSM blob > >> mechanism allows security modules to maintain their own information > >> about the system components (e.g. file, inode, cred, task) they > >> care about. The LSM infrastructure does not itself provide or > >> support security data or policy. That's strictly for the modules > >> to do. > > Agreed! > > > > EMA doesn't dictate policies for sure. Is it considered "security data"? I'm not sure the definition of "security data" here. It does store some "data", something that multiple LSM modules would need to duplicate if not pulled into a common place. It is meant to be a "helper" data structure, just like the auditing code. > > Good example. You'll see that there is no audit code in the > LSM infrastructure. None. No audit data, either. It's all taken > care of in the audit system. > >