]> granicus.if.org Git - zfs/commitdiff
Fix PAX Patch/Grsec SLAB_USERCOPY panic
authorBrian Behlendorf <behlendorf1@llnl.gov>
Mon, 28 Sep 2015 16:08:11 +0000 (09:08 -0700)
committerBrian Behlendorf <behlendorf1@llnl.gov>
Mon, 28 Sep 2015 16:18:29 +0000 (09:18 -0700)
Support grsecurity/PaX kernel configurations where
CONFIG_PAX_USERCOPY_SLABS are enabled.  When this kernel option
is enabled slabs which are used to copy between user and kernel
space must be created with SLAB_USERCOPY.

Stock Linux kernels do not have a SLAB_USERCOPY definition so
this causes no change in behavior for non-PAX-enabled kernels.

Verified-by: Wuffleton <null@wuffleton.com>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Issue #2977
Issue #3796

module/spl/spl-kmem-cache.c

index a83c9f3ae8c146ac19d9289f1dec5919266f484a..a7f9ca3a5d9931f171a440783dde9c441c4c1d20 100644 (file)
@@ -986,13 +986,23 @@ spl_kmem_cache_create(char *name, size_t size, size_t align,
                if (rc)
                        goto out;
        } else {
+               unsigned long slabflags = 0;
+
                if (size > (SPL_MAX_KMEM_ORDER_NR_PAGES * PAGE_SIZE)) {
                        rc = EINVAL;
                        goto out;
                }
 
+#if defined(SLAB_USERCOPY)
+               /*
+                * Required for PAX-enabled kernels if the slab is to be
+                * used for coping between user and kernel space.
+                */
+               slabflags |= SLAB_USERCOPY;
+#endif
+
                skc->skc_linux_cache = kmem_cache_create(
-                   skc->skc_name, size, align, 0, NULL);
+                   skc->skc_name, size, align, slabflags, NULL);
                if (skc->skc_linux_cache == NULL) {
                        rc = ENOMEM;
                        goto out;