From mboxrd@z Thu Jan 1 00:00:00 1970 From: daniel@iogearbox.net (Daniel Borkmann) Date: Thu, 05 Oct 2017 01:52:59 +0200 Subject: [PATCH net-next 4/4] selinux: bpf: Add addtional check for bpf object file receive In-Reply-To: <59D57263.3080601@iogearbox.net> References: <20171004182932.140028-1-chenbofeng.kernel@gmail.com> <20171004182932.140028-5-chenbofeng.kernel@gmail.com> <59D57263.3080601@iogearbox.net> Message-ID: <59D5745B.5010604@iogearbox.net> To: linux-security-module@vger.kernel.org List-Id: linux-security-module.vger.kernel.org On 10/05/2017 01:44 AM, Daniel Borkmann wrote: > On 10/04/2017 08:29 PM, Chenbo Feng wrote: >> From: Chenbo Feng >> >> Introduce a bpf object related check when sending and receiving files >> through unix domain socket as well as binder. It checks if the receiving >> process have privilege to read/write the bpf map or use the bpf program. >> This check is necessary because the bpf maps and programs are using a >> anonymous inode as their shared inode so the normal way of checking the >> files and sockets when passing between processes cannot work properly on >> eBPF object. This check only works when the BPF_SYSCALL is configured. > > [...] >> +/* This function will check the file pass through unix socket or binder to see >> + * if it is a bpf related object. And apply correspinding checks on the bpf >> + * object based on the type. The bpf maps and programs, not like other files and >> + * socket, are using a shared anonymous inode inside the kernel as their inode. >> + * So checking that inode cannot identify if the process have privilege to >> + * access the bpf object and that's why we have to add this additional check in >> + * selinux_file_receive and selinux_binder_transfer_files. >> + */ > [...] > > If selinux/lsm folks have some input on this one in particular, would > be great. The issue is not really tied to bpf specifically, but to the > use of anon-inodes wrt fd passing. Maybe some generic resolution can > be found to tackle this ... Perhaps even just a generic callback in struct file_operations might be better in order to just retrieve the secctx from the underlying object in case of anon-inodes and then have a generic check in selinux_file_receive() for the case when such callback is set, such that we don't need to put specific bpf logic there. -- To unsubscribe from this list: send the line "unsubscribe linux-security-module" in the body of a message to majordomo at vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html