On Wed, Mar 19, 2014 at 05:07:50PM +1030, Rusty Russell wrote: > Joe Perches <j...@perches.com> writes: > > On Sun, 2014-03-16 at 22:00 -0700, Joe Perches wrote: > >> On Mon, 2014-03-17 at 14:25 +1030, Rusty Russell wrote: > >> > >> > Erk, our tests are insufficient. Testbuilding an allmodconfig with this > >> > now: > >> > >> Good idea. > >> > >> > diff --git a/include/linux/moduleparam.h b/include/linux/moduleparam.h > >> [] > >> > @@ -188,6 +188,9 @@ struct kparam_array > >> > /* Default value instead of permissions? */ > >> > \ > >> > static int __param_perm_check_##name __attribute__((unused)) = > >> > \ > >> > BUILD_BUG_ON_ZERO((perm) < 0 || (perm) > 0777 || ((perm) & 2)) > >> > \ > >> > + /* User perms >= group perms >= other perms. */ > >> > \ > >> > + + BUILD_BUG_ON_ZERO(((perm) >> 6) < (((perm) >> 3) & 7)) > >> > \ > >> > + + BUILD_BUG_ON_ZERO((((perm) >> 3) & 7) < ((perm) & 7)) > >> > \ > >> > + BUILD_BUG_ON_ZERO(sizeof(""prefix) > MAX_PARAM_PREFIX_LEN); > >> > \ > >> > static const char __param_str_##name[] = prefix #name; > >> > \ > >> > static struct kernel_param __moduleparam_const __param_##name > >> > \ > >> > >> It might make sense to separate this octal permissions > >> test into a new macro for other checks in macros like > >> CLASS_ATTR, DEVICE_ATTR, SENSOR_ATTR and SENSOR_ATTR_2. > > OK, I took your bikeshed and re-painted it below. > > > #define VERIFY_OCTAL_PERMISSIONS(perms) > > \ > > ({ \ > > if (__builtin_constant_p(perms)) { \ > > BUILD_BUG_ON((perms) < 0); \ > > BUILD_BUG_ON((perms) > 0777); \ > > /* User perms >= group perms >= other perms */ \ > > BUILD_BUG_ON(((perms) >> 6) < (((perms) >> 3) & 7)); \ > > BUILD_BUG_ON((((perms) >> 3) & 7) < ((perms) & 7)); \ > > } \ > > ; \ > > }) > > Subject: VERIFY_OCTAL_PERMISSIONS: stricter checking for sysfs perms. > > Summary of http://lkml.org/lkml/2014/3/14/363 : > > Ted: module_param(queue_depth, int, 444) > Joe: 0444! > Rusty: User perms >= group perms >= other perms? > Joe: CLASS_ATTR, DEVICE_ATTR, SENSOR_ATTR and SENSOR_ATTR_2? > > Side effect of stricter permissions means removing the unnecessary > S_IFREG from drivers/pci/slot.c. > > Suggested-by: Joe Perches <j...@perches.com> > Cc: Bjorn Helgaas <bhelg...@google.com> > Cc: Greg Kroah-Hartman <gre...@linuxfoundation.org> > Signed-off-by: Rusty Russell <ru...@rustcorp.com.au>
Acked-by: Greg Kroah-Hartman <gre...@linuxfoundation.org> -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/