• A
    [PATCH] Compile-time check re world-writeable module params · 9774a1f5
    Alexey Dobriyan 提交于
    One of the mistakes a module_param() user can make is to supply default
    value of module parameter as the last argument.  module_param() accepts
    permissions instead.  If default value is, say, 3 (-------wx), parameter
    becomes world-writeable.
    
    So far, the only remedy was to apply grep(1) and read drivers submitted
    to -mm. BTDT.
    
    With this patch applied, compiler will finally do some job.
    
    *) bounds checking on permissions
    *) world-writeable bit checking on permissions
    *) compile breakage if checks trigger
    
    First version of this check (only "& 2" part) directly caught 4 out of 7
    places during my last grep.
    
        Subject: Neverending module_param() bugs
        [X] drivers/acpi/sbs.c:101:module_param(capacity_mode, int, CAPACITY_UNIT);
        [X] drivers/acpi/sbs.c:102:module_param(update_mode, int, UPDATE_MODE);
        [ ] drivers/acpi/sbs.c:103:module_param(update_info_mode, int, UPDATE_INFO_MODE);
        [ ] drivers/acpi/sbs.c:104:module_param(update_time, int, UPDATE_TIME);
        [ ] drivers/acpi/sbs.c:105:module_param(update_time2, int, UPDATE_TIME2);
        [X] drivers/char/watchdog/sbc8360.c:203:module_param(timeout, int, 27);
        [X] drivers/media/video/tuner-simple.c:13:module_param(offset, int, 0666);
    Signed-off-by: NAlexey Dobriyan <adobriyan@gmail.com>
    Signed-off-by: NAndrew Morton <akpm@osdl.org>
    Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
    9774a1f5
moduleparam.h 6.8 KB