[Bugs] [Bug 1402661] Samba crash when mounting a distributed dispersed volume over CIFS
bugzilla at redhat.com
bugzilla at redhat.com
Thu Jan 19 12:39:00 UTC 2017
https://bugzilla.redhat.com/show_bug.cgi?id=1402661
--- Comment #31 from Anoop C S <anoopcs at redhat.com> ---
(In reply to Xavier Hernandez from comment #25)
> I'm trying to reproduce the problem to see if the issue can be avoided
> playing with the mmap() protection flags. However I'm unable to get the
> error.
>
> I've used a CentOS 7.3.1611 with latest patches and default configuration,
> but it doesn't fail (selinux is enabled by default). Have you used any
> custom setup ?
>
> I use this small program to try to reproduce the issue:
>
> #include <stdio.h>
> #include <sys/mman.h>
> #include <errno.h>
>
> #define MMAP_SIZE 4096
>
> int main(void)
> {
> void *ptr;
>
> ptr = mmap(NULL, MMAP_SIZE, PROT_READ | PROT_WRITE | PROT_EXEC,
> MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
> if (ptr == MAP_FAILED) {
> printf("mmap() error: %d\n", errno);
> return 1;
> }
>
> printf("mmap succeeded\n");
>
> munmap(ptr, MMAP_SIZE);
>
> return 0;
To reproduce the AVC, please run the above program as below:
# > /var/log/audit/audit.log
# gcc mmap-selinux-test.c
# chcon -t glusterd_exec_t a.out
# runcon "system_u:system_r:glusterd_t:s0" ./a.out
# cat /var/log/audit/audit/log
type=AVC msg=audit(1484828797.810:996): avc: denied { execmem } for
pid=26592 comm="a.out" scontext=system_u:system_r:glusterd_t:s0
tcontext=system_u:system_r:glusterd_t:s0 tclass=process
type=SYSCALL msg=audit(1484828797.810:996): arch=c000003e syscall=9 success=no
exit=-13 a0=0 a1=1000 a2=7 a3=22 items=0 ppid=26437 pid=26592 auid=0 uid=0
gid=0 euid=0 suid=0 fsuid=0 egid=0 sgid=0 fsgid=0 tty=(none) ses=16
comm="a.out" exe="/root/a.out" subj=system_u:system_r:glusterd_t:s0 key=(null)
Now remove either PROT_EXEC or PROT_WRITE from mmap call and repeat the above
steps. AVCs must not be present.
Why we need to do all this?
===========================
Because gluster binaries are run with the following selinux context:
# ps auxZ | grep /usr/sbin/glusterd | grep -v grep
system_u:system_r:glusterd_t:s0 root 7216 0.0 1.8 602096 18748 ?
Ssl 12:55 0:01 /usr/sbin/glusterd -p /var/run/glusterd.pid --log-level INFO
So we need to test our sample programs too in the same selinux context and thus
we can be sure about it.
Why you couldn't reproduce it?
==============================
Run `ps auxZ | grep /usr/sbin/glusterd | grep -v grep` and check under which
context it is running. The behaviour changes based on what context gluster
daemon is running.
--
You are receiving this mail because:
You are on the CC list for the bug.
Unsubscribe from this bug https://bugzilla.redhat.com/token.cgi?t=AcEPLnMpcR&a=cc_unsubscribe
More information about the Bugs
mailing list