]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
treewide: Fix function prototypes for module_param_call()
authorKees Cook <keescook@chromium.org>
Wed, 18 Oct 2017 02:04:42 +0000 (19:04 -0700)
committerJessica Yu <jeyu@kernel.org>
Tue, 31 Oct 2017 14:30:37 +0000 (15:30 +0100)
Several function prototypes for the set/get functions defined by
module_param_call() have a slightly wrong argument types. This fixes
those in an effort to clean up the calls when running under type-enforced
compiler instrumentation for CFI. This is the result of running the
following semantic patch:

@match_module_param_call_function@
declarer name module_param_call;
identifier _name, _set_func, _get_func;
expression _arg, _mode;
@@

 module_param_call(_name, _set_func, _get_func, _arg, _mode);

@fix_set_prototype
 depends on match_module_param_call_function@
identifier match_module_param_call_function._set_func;
identifier _val, _param;
type _val_type, _param_type;
@@

 int _set_func(
-_val_type _val
+const char * _val
 ,
-_param_type _param
+const struct kernel_param * _param
 ) { ... }

@fix_get_prototype
 depends on match_module_param_call_function@
identifier match_module_param_call_function._get_func;
identifier _val, _param;
type _val_type, _param_type;
@@

 int _get_func(
-_val_type _val
+char * _val
 ,
-_param_type _param
+const struct kernel_param * _param
 ) { ... }

Two additional by-hand changes are included for places where the above
Coccinelle script didn't notice them:

drivers/platform/x86/thinkpad_acpi.c
fs/lockd/svc.c

Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Jessica Yu <jeyu@kernel.org>
42 files changed:
arch/powerpc/platforms/pseries/cmm.c
arch/x86/oprofile/nmi_int.c
drivers/acpi/button.c
drivers/acpi/ec.c
drivers/acpi/sysfs.c
drivers/android/binder.c
drivers/char/ipmi/ipmi_poweroff.c
drivers/char/ipmi/ipmi_si_intf.c
drivers/edac/edac_mc_sysfs.c
drivers/edac/edac_module.c
drivers/hid/hid-magicmouse.c
drivers/ide/ide.c
drivers/infiniband/hw/qib/qib_iba7322.c
drivers/infiniband/ulp/srpt/ib_srpt.c
drivers/isdn/hardware/mISDN/avmfritz.c
drivers/isdn/hardware/mISDN/mISDNinfineon.c
drivers/isdn/hardware/mISDN/netjet.c
drivers/isdn/hardware/mISDN/speedfax.c
drivers/isdn/hardware/mISDN/w6692.c
drivers/md/md.c
drivers/media/pci/tw686x/tw686x-core.c
drivers/media/usb/uvc/uvc_driver.c
drivers/message/fusion/mptbase.c
drivers/misc/kgdbts.c
drivers/mtd/devices/block2mtd.c
drivers/mtd/devices/phram.c
drivers/mtd/ubi/build.c
drivers/pci/pcie/aspm.c
drivers/platform/x86/thinkpad_acpi.c
drivers/scsi/fcoe/fcoe_transport.c
drivers/scsi/mpt3sas/mpt3sas_base.c
drivers/scsi/mpt3sas/mpt3sas_scsih.c
drivers/tty/serial/kgdboc.c
fs/fuse/inode.c
fs/lockd/svc.c
fs/ocfs2/dlmfs/dlmfs.c
include/net/netfilter/nf_conntrack.h
net/netfilter/nf_conntrack_core.c
net/netfilter/nf_nat_ftp.c
net/netfilter/nf_nat_irc.c
net/sunrpc/svc.c
security/apparmor/lsm.c

index 4ac419c7eb4c9891a8cd71fffe5ce107cce0c6f8..560aefde06c0240a8c6071e3a92ff062337afc1d 100644 (file)
@@ -742,7 +742,7 @@ static void cmm_exit(void)
  * Return value:
  *     0 on success / other on failure
  **/
-static int cmm_set_disable(const char *val, struct kernel_param *kp)
+static int cmm_set_disable(const char *val, const struct kernel_param *kp)
 {
        int disable = simple_strtoul(val, NULL, 10);
 
index ffdbc4836b4f532512e00d6fcdc32c5bcd656684..174c59774cc935430583160c6c158d5de363c7ef 100644 (file)
@@ -592,7 +592,7 @@ enum __force_cpu_type {
 
 static int force_cpu_type;
 
-static int set_cpu_type(const char *str, struct kernel_param *kp)
+static int set_cpu_type(const char *str, const struct kernel_param *kp)
 {
        if (!strcmp(str, "timer")) {
                force_cpu_type = timer;
index ef1856b15488be10cf81f8abfa20c630f461768d..891b0921a3077aefebd0014a848608f2ba26cfdb 100644 (file)
@@ -557,7 +557,8 @@ static int acpi_button_remove(struct acpi_device *device)
        return 0;
 }
 
-static int param_set_lid_init_state(const char *val, struct kernel_param *kp)
+static int param_set_lid_init_state(const char *val,
+                                   const struct kernel_param *kp)
 {
        int result = 0;
 
@@ -575,7 +576,8 @@ static int param_set_lid_init_state(const char *val, struct kernel_param *kp)
        return result;
 }
 
-static int param_get_lid_init_state(char *buffer, struct kernel_param *kp)
+static int param_get_lid_init_state(char *buffer,
+                                   const struct kernel_param *kp)
 {
        switch (lid_init_state) {
        case ACPI_BUTTON_LID_INIT_OPEN:
index 236b14324780a1c1c416c852957cfa732144b8fc..ba2cebf1bb2f98d3467b99b41f2360fcea1e1673 100644 (file)
@@ -1939,7 +1939,8 @@ static const struct dev_pm_ops acpi_ec_pm = {
        SET_SYSTEM_SLEEP_PM_OPS(acpi_ec_suspend, acpi_ec_resume)
 };
 
-static int param_set_event_clearing(const char *val, struct kernel_param *kp)
+static int param_set_event_clearing(const char *val,
+                                   const struct kernel_param *kp)
 {
        int result = 0;
 
@@ -1957,7 +1958,8 @@ static int param_set_event_clearing(const char *val, struct kernel_param *kp)
        return result;
 }
 
-static int param_get_event_clearing(char *buffer, struct kernel_param *kp)
+static int param_get_event_clearing(char *buffer,
+                                   const struct kernel_param *kp)
 {
        switch (ec_event_clearing) {
        case ACPI_EC_EVT_TIMING_STATUS:
index 78a5a23010ab4522923ccae5709d4100458cfbbb..cf2c1b2b2d6487305ac8f061cbd10e1465fff5da 100644 (file)
@@ -229,7 +229,8 @@ module_param_cb(trace_method_name, &param_ops_trace_method, &trace_method_name,
 module_param_cb(trace_debug_layer, &param_ops_trace_attrib, &acpi_gbl_trace_dbg_layer, 0644);
 module_param_cb(trace_debug_level, &param_ops_trace_attrib, &acpi_gbl_trace_dbg_level, 0644);
 
-static int param_set_trace_state(const char *val, struct kernel_param *kp)
+static int param_set_trace_state(const char *val,
+                                const struct kernel_param *kp)
 {
        acpi_status status;
        const char *method = trace_method_name;
@@ -265,7 +266,7 @@ static int param_set_trace_state(const char *val, struct kernel_param *kp)
        return 0;
 }
 
-static int param_get_trace_state(char *buffer, struct kernel_param *kp)
+static int param_get_trace_state(char *buffer, const struct kernel_param *kp)
 {
        if (!(acpi_gbl_trace_flags & ACPI_TRACE_ENABLED))
                return sprintf(buffer, "disable");
@@ -294,7 +295,8 @@ MODULE_PARM_DESC(aml_debug_output,
                 "To enable/disable the ACPI Debug Object output.");
 
 /* /sys/module/acpi/parameters/acpica_version */
-static int param_get_acpica_version(char *buffer, struct kernel_param *kp)
+static int param_get_acpica_version(char *buffer,
+                                   const struct kernel_param *kp)
 {
        int result;
 
index 0621a95b8597a986801a70ed874d203be68e8c51..c45157d71b33a48fd08cb872f6f085f8fe40e067 100644 (file)
@@ -150,7 +150,7 @@ static DECLARE_WAIT_QUEUE_HEAD(binder_user_error_wait);
 static int binder_stop_on_user_error;
 
 static int binder_set_stop_on_user_error(const char *val,
-                                        struct kernel_param *kp)
+                                        const struct kernel_param *kp)
 {
        int ret;
 
index 9f2e3be2c5b8b37d059d9aca5d2f4677753ce034..676c910e990fb753218f91aebb699d6fff577438 100644 (file)
@@ -66,7 +66,7 @@ static void (*specific_poweroff_func)(ipmi_user_t user);
 /* Holds the old poweroff function so we can restore it on removal. */
 static void (*old_poweroff_func)(void);
 
-static int set_param_ifnum(const char *val, struct kernel_param *kp)
+static int set_param_ifnum(const char *val, const struct kernel_param *kp)
 {
        int rv = param_set_int(val, kp);
        if (rv)
index 36f47e8d06a3b90918a5ecb8433a04122bb0c0e8..d2ac66fe0645ae5972abcba99ec0925727e58423 100644 (file)
@@ -1345,7 +1345,7 @@ static unsigned int num_slave_addrs;
 #define IPMI_MEM_ADDR_SPACE 1
 static const char * const addr_space_to_str[] = { "i/o", "mem" };
 
-static int hotmod_handler(const char *val, struct kernel_param *kp);
+static int hotmod_handler(const char *val, const struct kernel_param *kp);
 
 module_param_call(hotmod, hotmod_handler, NULL, NULL, 0200);
 MODULE_PARM_DESC(hotmod, "Add and remove interfaces.  See"
@@ -1811,7 +1811,7 @@ static struct smi_info *smi_info_alloc(void)
        return info;
 }
 
-static int hotmod_handler(const char *val, struct kernel_param *kp)
+static int hotmod_handler(const char *val, const struct kernel_param *kp)
 {
        char *str = kstrdup(val, GFP_KERNEL);
        int  rv;
index e4fcfa84fbd3503246d144bcbcbb36747ed9171c..c70ea82c815c90966e1cf22c3781d16f5eed6ce6 100644 (file)
@@ -50,7 +50,7 @@ int edac_mc_get_poll_msec(void)
        return edac_mc_poll_msec;
 }
 
-static int edac_set_poll_msec(const char *val, struct kernel_param *kp)
+static int edac_set_poll_msec(const char *val, const struct kernel_param *kp)
 {
        unsigned long l;
        int ret;
index 172598a27d7d9df8f83dcd37ae6bf0706df8d53a..32a931d0cb71ff1c262c97eb323c8894768ee423 100644 (file)
@@ -19,7 +19,8 @@
 
 #ifdef CONFIG_EDAC_DEBUG
 
-static int edac_set_debug_level(const char *buf, struct kernel_param *kp)
+static int edac_set_debug_level(const char *buf,
+                               const struct kernel_param *kp)
 {
        unsigned long val;
        int ret;
index 20b40ad2632503754685b84cc07d8787a4a44515..42ed887ba0be5d79d67738bcc1520eb8fb8a0190 100644 (file)
@@ -34,7 +34,8 @@ module_param(emulate_scroll_wheel, bool, 0644);
 MODULE_PARM_DESC(emulate_scroll_wheel, "Emulate a scroll wheel");
 
 static unsigned int scroll_speed = 32;
-static int param_set_scroll_speed(const char *val, struct kernel_param *kp) {
+static int param_set_scroll_speed(const char *val,
+                                 const struct kernel_param *kp) {
        unsigned long speed;
        if (!val || kstrtoul(val, 0, &speed) || speed > 63)
                return -EINVAL;
index d127ace6aa5757a2e91a67d74b7c18353e1dd689..6ee866fcc5dd035655cc8649101e8b3df1e578ea 100644 (file)
@@ -244,7 +244,7 @@ struct chs_geom {
 static unsigned int ide_disks;
 static struct chs_geom ide_disks_chs[MAX_HWIFS * MAX_DRIVES];
 
-static int ide_set_disk_chs(const char *str, struct kernel_param *kp)
+static int ide_set_disk_chs(const char *str, const struct kernel_param *kp)
 {
        unsigned int a, b, c = 0, h = 0, s = 0, i, j = 1;
 
@@ -328,7 +328,7 @@ static void ide_dev_apply_params(ide_drive_t *drive, u8 unit)
 
 static unsigned int ide_ignore_cable;
 
-static int ide_set_ignore_cable(const char *s, struct kernel_param *kp)
+static int ide_set_ignore_cable(const char *s, const struct kernel_param *kp)
 {
        int i, j = 1;
 
index 14cadf6d621463e07a98e9e598982648729afacc..a45e460989149db00406fb2573112fe24cb9c6fd 100644 (file)
@@ -150,7 +150,7 @@ static struct kparam_string kp_txselect = {
        .string = txselect_list,
        .maxlen = MAX_ATTEN_LEN
 };
-static int  setup_txselect(const char *, struct kernel_param *);
+static int  setup_txselect(const char *, const struct kernel_param *);
 module_param_call(txselect, setup_txselect, param_get_string,
                  &kp_txselect, S_IWUSR | S_IRUGO);
 MODULE_PARM_DESC(txselect,
@@ -6169,7 +6169,7 @@ static void set_no_qsfp_atten(struct qib_devdata *dd, int change)
 }
 
 /* handle the txselect parameter changing */
-static int setup_txselect(const char *str, struct kernel_param *kp)
+static int setup_txselect(const char *str, const struct kernel_param *kp)
 {
        struct qib_devdata *dd;
        unsigned long val;
index 9e8e9220f816793630794e2da75cda342923a574..9612e5bdfb00f3fac566c6caafa054029c32cd17 100644 (file)
@@ -80,7 +80,7 @@ module_param(srpt_srq_size, int, 0444);
 MODULE_PARM_DESC(srpt_srq_size,
                 "Shared receive queue (SRQ) size.");
 
-static int srpt_get_u64_x(char *buffer, struct kernel_param *kp)
+static int srpt_get_u64_x(char *buffer, const struct kernel_param *kp)
 {
        return sprintf(buffer, "0x%016llx", *(u64 *)kp->arg);
 }
index dce6632daae1c4b5a0f43be11d80b99d995c5011..ae2b2669af1bc44667e49e60148c9591b7fa4e85 100644 (file)
@@ -156,7 +156,7 @@ _set_debug(struct fritzcard *card)
 }
 
 static int
-set_debug(const char *val, struct kernel_param *kp)
+set_debug(const char *val, const struct kernel_param *kp)
 {
        int ret;
        struct fritzcard *card;
index d5bdbaf93a1afe2d905a21ecad5cca09d637a731..1fc290659e945a5ffdf2efcda8cf687c4bedd42d 100644 (file)
@@ -244,7 +244,7 @@ _set_debug(struct inf_hw *card)
 }
 
 static int
-set_debug(const char *val, struct kernel_param *kp)
+set_debug(const char *val, const struct kernel_param *kp)
 {
        int ret;
        struct inf_hw *card;
index 6a6d848bd18eefc1d7400a49f64c02960a6b4592..89d9ba8ed535e2bf25ad807add639b0240942e3a 100644 (file)
@@ -111,7 +111,7 @@ _set_debug(struct tiger_hw *card)
 }
 
 static int
-set_debug(const char *val, struct kernel_param *kp)
+set_debug(const char *val, const struct kernel_param *kp)
 {
        int ret;
        struct tiger_hw *card;
index 9815bb4eec9c747a6f285377622ca004b2ea0373..1f1446ed8d5f328506e71bce312862a8473c15c9 100644 (file)
@@ -94,7 +94,7 @@ _set_debug(struct sfax_hw *card)
 }
 
 static int
-set_debug(const char *val, struct kernel_param *kp)
+set_debug(const char *val, const struct kernel_param *kp)
 {
        int ret;
        struct sfax_hw *card;
index d80072fef43415f2812169b2111391b3a6b5281e..209036a4af3a28c23498c9fdbc6c333bac0e33a8 100644 (file)
@@ -101,7 +101,7 @@ _set_debug(struct w6692_hw *card)
 }
 
 static int
-set_debug(const char *val, struct kernel_param *kp)
+set_debug(const char *val, const struct kernel_param *kp)
 {
        int ret;
        struct w6692_hw *card;
index 0ff1bbf6c90e5cebc782268313ce39f8c66f7270..276c7ecedf107b7757e238ec5bdb40d9f2336629 100644 (file)
@@ -5357,7 +5357,7 @@ static struct kobject *md_probe(dev_t dev, int *part, void *data)
        return NULL;
 }
 
-static int add_named_array(const char *val, struct kernel_param *kp)
+static int add_named_array(const char *val, const struct kernel_param *kp)
 {
        /*
         * val must be "md_*" or "mdNNN".
@@ -9274,11 +9274,11 @@ static __exit void md_exit(void)
 subsys_initcall(md_init);
 module_exit(md_exit)
 
-static int get_ro(char *buffer, struct kernel_param *kp)
+static int get_ro(char *buffer, const struct kernel_param *kp)
 {
        return sprintf(buffer, "%d", start_readonly);
 }
-static int set_ro(const char *val, struct kernel_param *kp)
+static int set_ro(const char *val, const struct kernel_param *kp)
 {
        return kstrtouint(val, 10, (unsigned int *)&start_readonly);
 }
index 336e2f9bc1b6363045f4890c662299d8009f5e30..b762e5f0ba1d55c5916b43c9f9e070689151f61b 100644 (file)
@@ -72,12 +72,12 @@ static const char *dma_mode_name(unsigned int mode)
        }
 }
 
-static int tw686x_dma_mode_get(char *buffer, struct kernel_param *kp)
+static int tw686x_dma_mode_get(char *buffer, const struct kernel_param *kp)
 {
        return sprintf(buffer, "%s", dma_mode_name(dma_mode));
 }
 
-static int tw686x_dma_mode_set(const char *val, struct kernel_param *kp)
+static int tw686x_dma_mode_set(const char *val, const struct kernel_param *kp)
 {
        if (!strcasecmp(val, dma_mode_name(TW686X_DMA_MODE_MEMCPY)))
                dma_mode = TW686X_DMA_MODE_MEMCPY;
index 6d22b22cb35b64e4e1ee4993c8010372c307443b..28b91b7d756f5f42968da0e6322a740242eb0d54 100644 (file)
@@ -2230,7 +2230,7 @@ static int uvc_reset_resume(struct usb_interface *intf)
  * Module parameters
  */
 
-static int uvc_clock_param_get(char *buffer, struct kernel_param *kp)
+static int uvc_clock_param_get(char *buffer, const struct kernel_param *kp)
 {
        if (uvc_clock_param == CLOCK_MONOTONIC)
                return sprintf(buffer, "CLOCK_MONOTONIC");
@@ -2238,7 +2238,7 @@ static int uvc_clock_param_get(char *buffer, struct kernel_param *kp)
                return sprintf(buffer, "CLOCK_REALTIME");
 }
 
-static int uvc_clock_param_set(const char *val, struct kernel_param *kp)
+static int uvc_clock_param_set(const char *val, const struct kernel_param *kp)
 {
        if (strncasecmp(val, "clock_", strlen("clock_")) == 0)
                val += strlen("clock_");
index 84eab28665f37c148407a9bdeb99adccac5f788c..7a93400eea2a7c36dcd4f462f2cdff461151988c 100644 (file)
@@ -99,7 +99,7 @@ module_param(mpt_channel_mapping, int, 0);
 MODULE_PARM_DESC(mpt_channel_mapping, " Mapping id's to channels (default=0)");
 
 static int mpt_debug_level;
-static int mpt_set_debug_level(const char *val, struct kernel_param *kp);
+static int mpt_set_debug_level(const char *val, const struct kernel_param *kp);
 module_param_call(mpt_debug_level, mpt_set_debug_level, param_get_int,
                  &mpt_debug_level, 0600);
 MODULE_PARM_DESC(mpt_debug_level,
@@ -242,7 +242,7 @@ pci_enable_io_access(struct pci_dev *pdev)
        pci_write_config_word(pdev, PCI_COMMAND, command_reg);
 }
 
-static int mpt_set_debug_level(const char *val, struct kernel_param *kp)
+static int mpt_set_debug_level(const char *val, const struct kernel_param *kp)
 {
        int ret = param_set_int(val, kp);
        MPT_ADAPTER *ioc;
index fc7efedbc4be2513b2137bea45e48407308f0902..24108bfad88982c0688de8d4bcef17def3750587 100644 (file)
@@ -1132,7 +1132,8 @@ static void kgdbts_put_char(u8 chr)
                ts.run_test(0, chr);
 }
 
-static int param_set_kgdbts_var(const char *kmessage, struct kernel_param *kp)
+static int param_set_kgdbts_var(const char *kmessage,
+                               const struct kernel_param *kp)
 {
        int len = strlen(kmessage);
 
index 7c887f111a7d03eaeb41dd4bdb6bce67bf81609b..62fd6905c648c6eb5ef167e019831729bb294a85 100644 (file)
@@ -431,7 +431,7 @@ static int block2mtd_setup2(const char *val)
 }
 
 
-static int block2mtd_setup(const char *val, struct kernel_param *kp)
+static int block2mtd_setup(const char *val, const struct kernel_param *kp)
 {
 #ifdef MODULE
        return block2mtd_setup2(val);
index 8b66e52ca3ccb811e818dce496ca6e0fcc7c9ecb..7287696a21f91df6a875dc32a112e6206c855de1 100644 (file)
@@ -266,7 +266,7 @@ static int phram_setup(const char *val)
        return ret;
 }
 
-static int phram_param_call(const char *val, struct kernel_param *kp)
+static int phram_param_call(const char *val, const struct kernel_param *kp)
 {
 #ifdef MODULE
        return phram_setup(val);
index 842550b5712ae48a18e24c2c4945095b0c596ccf..136ce05d23283217563d6a9287cd8651c590050e 100644 (file)
@@ -1334,7 +1334,7 @@ static int bytes_str_to_int(const char *str)
  * This function returns zero in case of success and a negative error code in
  * case of error.
  */
-static int ubi_mtd_param_parse(const char *val, struct kernel_param *kp)
+static int ubi_mtd_param_parse(const char *val, const struct kernel_param *kp)
 {
        int i, len;
        struct mtd_dev_param *p;
index 1dfa10cc566bebed005c2fe11a72c85a37036c32..ca3ee0f7e61dec82f2f7dceac963ecf45b93c62c 100644 (file)
@@ -1060,7 +1060,8 @@ void pci_disable_link_state(struct pci_dev *pdev, int state)
 }
 EXPORT_SYMBOL(pci_disable_link_state);
 
-static int pcie_aspm_set_policy(const char *val, struct kernel_param *kp)
+static int pcie_aspm_set_policy(const char *val,
+                               const struct kernel_param *kp)
 {
        int i;
        struct pcie_link_state *link;
@@ -1087,7 +1088,7 @@ static int pcie_aspm_set_policy(const char *val, struct kernel_param *kp)
        return 0;
 }
 
-static int pcie_aspm_get_policy(char *buffer, struct kernel_param *kp)
+static int pcie_aspm_get_policy(char *buffer, const struct kernel_param *kp)
 {
        int i, cnt = 0;
        for (i = 0; i < ARRAY_SIZE(policy_str); i++)
index 2242d6035d9e7e1f8d042855973a2349c6d7eb9f..3887dfeafc964522e43c077534bf62e0747f7dcf 100644 (file)
@@ -9543,7 +9543,7 @@ static struct ibm_init_struct ibms_init[] __initdata = {
        },
 };
 
-static int __init set_ibm_param(const char *val, struct kernel_param *kp)
+static int __init set_ibm_param(const char *val, const struct kernel_param *kp)
 {
        unsigned int i;
        struct ibm_struct *ibm;
index 375c536cbc688f0e5b9467ca65e9885b96ea130d..c5eb0c468f0b9c5f2004f02f6f87939756105bd7 100644 (file)
@@ -32,13 +32,13 @@ MODULE_AUTHOR("Open-FCoE.org");
 MODULE_DESCRIPTION("FIP discovery protocol and FCoE transport for FCoE HBAs");
 MODULE_LICENSE("GPL v2");
 
-static int fcoe_transport_create(const char *, struct kernel_param *);
-static int fcoe_transport_destroy(const char *, struct kernel_param *);
+static int fcoe_transport_create(const char *, const struct kernel_param *);
+static int fcoe_transport_destroy(const char *, const struct kernel_param *);
 static int fcoe_transport_show(char *buffer, const struct kernel_param *kp);
 static struct fcoe_transport *fcoe_transport_lookup(struct net_device *device);
 static struct fcoe_transport *fcoe_netdev_map_lookup(struct net_device *device);
-static int fcoe_transport_enable(const char *, struct kernel_param *);
-static int fcoe_transport_disable(const char *, struct kernel_param *);
+static int fcoe_transport_enable(const char *, const struct kernel_param *);
+static int fcoe_transport_disable(const char *, const struct kernel_param *);
 static int libfcoe_device_notification(struct notifier_block *notifier,
                                    ulong event, void *ptr);
 
@@ -865,7 +865,8 @@ EXPORT_SYMBOL(fcoe_ctlr_destroy_store);
  *
  * Returns: 0 for success
  */
-static int fcoe_transport_create(const char *buffer, struct kernel_param *kp)
+static int fcoe_transport_create(const char *buffer,
+                                const struct kernel_param *kp)
 {
        int rc = -ENODEV;
        struct net_device *netdev = NULL;
@@ -930,7 +931,8 @@ static int fcoe_transport_create(const char *buffer, struct kernel_param *kp)
  *
  * Returns: 0 for success
  */
-static int fcoe_transport_destroy(const char *buffer, struct kernel_param *kp)
+static int fcoe_transport_destroy(const char *buffer,
+                                 const struct kernel_param *kp)
 {
        int rc = -ENODEV;
        struct net_device *netdev = NULL;
@@ -974,7 +976,8 @@ static int fcoe_transport_destroy(const char *buffer, struct kernel_param *kp)
  *
  * Returns: 0 for success
  */
-static int fcoe_transport_disable(const char *buffer, struct kernel_param *kp)
+static int fcoe_transport_disable(const char *buffer,
+                                 const struct kernel_param *kp)
 {
        int rc = -ENODEV;
        struct net_device *netdev = NULL;
@@ -1008,7 +1011,8 @@ static int fcoe_transport_disable(const char *buffer, struct kernel_param *kp)
  *
  * Returns: 0 for success
  */
-static int fcoe_transport_enable(const char *buffer, struct kernel_param *kp)
+static int fcoe_transport_enable(const char *buffer,
+                                const struct kernel_param *kp)
 {
        int rc = -ENODEV;
        struct net_device *netdev = NULL;
index 87999905bca347c191e957c6ab3c94510a0ca945..3d36deee82857e67596e7cd4c094ff02c510f4e9 100644 (file)
@@ -105,7 +105,7 @@ _base_get_ioc_facts(struct MPT3SAS_ADAPTER *ioc);
  *
  */
 static int
-_scsih_set_fwfault_debug(const char *val, struct kernel_param *kp)
+_scsih_set_fwfault_debug(const char *val, const struct kernel_param *kp)
 {
        int ret = param_set_int(val, kp);
        struct MPT3SAS_ADAPTER *ioc;
index 22998cbd538f9cb56fe1fa41cf5b4db7e15067c8..07719da7ae4aa76586a4184028b7484af05d769a 100644 (file)
@@ -281,7 +281,7 @@ struct _scsi_io_transfer {
  * Note: The logging levels are defined in mpt3sas_debug.h.
  */
 static int
-_scsih_set_debug_level(const char *val, struct kernel_param *kp)
+_scsih_set_debug_level(const char *val, const struct kernel_param *kp)
 {
        int ret = param_set_int(val, kp);
        struct MPT3SAS_ADAPTER *ioc;
index a260cde743e272657673474d9612c0bf663d3995..5532c440bf61be00193101ecc2e15e5e63e17400 100644 (file)
@@ -245,7 +245,8 @@ static void kgdboc_put_char(u8 chr)
                                        kgdb_tty_line, chr);
 }
 
-static int param_set_kgdboc_var(const char *kmessage, struct kernel_param *kp)
+static int param_set_kgdboc_var(const char *kmessage,
+                               const struct kernel_param *kp)
 {
        int len = strlen(kmessage);
 
index 65c88379a3a14311cca68b8750d6bb0b9f107444..7d67fc150edcf7d9614f512b851dd6481e45fa86 100644 (file)
@@ -31,7 +31,7 @@ static struct kmem_cache *fuse_inode_cachep;
 struct list_head fuse_conn_list;
 DEFINE_MUTEX(fuse_mutex);
 
-static int set_global_limit(const char *val, struct kernel_param *kp);
+static int set_global_limit(const char *val, const struct kernel_param *kp);
 
 unsigned max_user_bgreq;
 module_param_call(max_user_bgreq, set_global_limit, param_get_uint,
@@ -823,7 +823,7 @@ static void sanitize_global_limit(unsigned *limit)
                *limit = (1 << 16) - 1;
 }
 
-static int set_global_limit(const char *val, struct kernel_param *kp)
+static int set_global_limit(const char *val, const struct kernel_param *kp)
 {
        int rv;
 
index b995bdc139768492fcc9faf4696aefb7850b63de..b837fb7e290a6a63346f1ad7f00e63f2db8a5382 100644 (file)
@@ -602,7 +602,7 @@ static struct ctl_table nlm_sysctl_root[] = {
  */
 
 #define param_set_min_max(name, type, which_strtol, min, max)          \
-static int param_set_##name(const char *val, struct kernel_param *kp)  \
+static int param_set_##name(const char *val, const struct kernel_param *kp) \
 {                                                                      \
        char *endp;                                                     \
        __typeof__(type) num = which_strtol(val, &endp, 0);             \
index 9ab9e1892b5fc1ff88f1103d8391c337eca2607a..988137de08f510ba8c3c98d4f7ed4b6b53c76f17 100644 (file)
@@ -88,13 +88,13 @@ struct workqueue_struct *user_dlm_worker;
  */
 #define DLMFS_CAPABILITIES "bast stackglue"
 static int param_set_dlmfs_capabilities(const char *val,
-                                       struct kernel_param *kp)
+                                       const struct kernel_param *kp)
 {
        printk(KERN_ERR "%s: readonly parameter\n", kp->name);
        return -EINVAL;
 }
 static int param_get_dlmfs_capabilities(char *buffer,
-                                       struct kernel_param *kp)
+                                       const struct kernel_param *kp)
 {
        return strlcpy(buffer, DLMFS_CAPABILITIES,
                       strlen(DLMFS_CAPABILITIES) + 1);
index 8f3bd30511def05c91870b2f73bba03e4dc1b04a..fd5241ce1fc930c77daa1c082ed2011f68a501bf 100644 (file)
@@ -284,7 +284,7 @@ static inline bool nf_ct_should_gc(const struct nf_conn *ct)
 
 struct kernel_param;
 
-int nf_conntrack_set_hashsize(const char *val, struct kernel_param *kp);
+int nf_conntrack_set_hashsize(const char *val, const struct kernel_param *kp);
 int nf_conntrack_hash_resize(unsigned int hashsize);
 
 extern struct hlist_nulls_head *nf_conntrack_hash;
index 01130392b7c0f536dc5afb74ff24d5b49cbd9f8a..5e50c54e1318e554284eb09bb12269c8d5c6a5f8 100644 (file)
@@ -1940,7 +1940,7 @@ int nf_conntrack_hash_resize(unsigned int hashsize)
        return 0;
 }
 
-int nf_conntrack_set_hashsize(const char *val, struct kernel_param *kp)
+int nf_conntrack_set_hashsize(const char *val, const struct kernel_param *kp)
 {
        unsigned int hashsize;
        int rc;
index e84a578dbe351da3122732cd2581a0e9322931a3..d76afafdc6993ba2f8e4a03f377b8cad3a34c145 100644 (file)
@@ -134,7 +134,7 @@ static int __init nf_nat_ftp_init(void)
 }
 
 /* Prior to 2.6.11, we had a ports param.  No longer, but don't break users. */
-static int warn_set(const char *val, struct kernel_param *kp)
+static int warn_set(const char *val, const struct kernel_param *kp)
 {
        printk(KERN_INFO KBUILD_MODNAME
               ": kernel >= 2.6.10 only uses 'ports' for conntrack modules\n");
index 0648cb096bd87b2df3b84db5da8ff8fdbffc7018..dcb5f6375d9df9966b5f2c5b2b4eb13cc78873c8 100644 (file)
@@ -106,7 +106,7 @@ static int __init nf_nat_irc_init(void)
 }
 
 /* Prior to 2.6.11, we had a ports param.  No longer, but don't break users. */
-static int warn_set(const char *val, struct kernel_param *kp)
+static int warn_set(const char *val, const struct kernel_param *kp)
 {
        printk(KERN_INFO KBUILD_MODNAME
               ": kernel >= 2.6.10 only uses 'ports' for conntrack modules\n");
index aa04666f929db314b6daa46d206e1d405170e2b6..e5e4e18699c8b02ffe5600e451b59eb6d78588a1 100644 (file)
@@ -50,7 +50,7 @@ EXPORT_SYMBOL_GPL(svc_pool_map);
 static DEFINE_MUTEX(svc_pool_map_mutex);/* protects svc_pool_map.count only */
 
 static int
-param_set_pool_mode(const char *val, struct kernel_param *kp)
+param_set_pool_mode(const char *val, const struct kernel_param *kp)
 {
        int *ip = (int *)kp->arg;
        struct svc_pool_map *m = &svc_pool_map;
@@ -80,7 +80,7 @@ param_set_pool_mode(const char *val, struct kernel_param *kp)
 }
 
 static int
-param_get_pool_mode(char *buf, struct kernel_param *kp)
+param_get_pool_mode(char *buf, const struct kernel_param *kp)
 {
        int *ip = (int *)kp->arg;
 
index 72b915dfcaf7eeeed1a2d428777878c81e5f4f80..f46a12b339bc408325f4cce510355d9cd640ff72 100644 (file)
@@ -1200,11 +1200,11 @@ static const struct kernel_param_ops param_ops_aalockpolicy = {
        .get = param_get_aalockpolicy
 };
 
-static int param_set_audit(const char *val, struct kernel_param *kp);
-static int param_get_audit(char *buffer, struct kernel_param *kp);
+static int param_set_audit(const char *val, const struct kernel_param *kp);
+static int param_get_audit(char *buffer, const struct kernel_param *kp);
 
-static int param_set_mode(const char *val, struct kernel_param *kp);
-static int param_get_mode(char *buffer, struct kernel_param *kp);
+static int param_set_mode(const char *val, const struct kernel_param *kp);
+static int param_get_mode(char *buffer, const struct kernel_param *kp);
 
 /* Flag values, also controllable via /sys/module/apparmor/parameters
  * We define special types as we want to do additional mediation.
@@ -1338,7 +1338,7 @@ static int param_get_aauint(char *buffer, const struct kernel_param *kp)
        return param_get_uint(buffer, kp);
 }
 
-static int param_get_audit(char *buffer, struct kernel_param *kp)
+static int param_get_audit(char *buffer, const struct kernel_param *kp)
 {
        if (!apparmor_enabled)
                return -EINVAL;
@@ -1347,7 +1347,7 @@ static int param_get_audit(char *buffer, struct kernel_param *kp)
        return sprintf(buffer, "%s", audit_mode_names[aa_g_audit]);
 }
 
-static int param_set_audit(const char *val, struct kernel_param *kp)
+static int param_set_audit(const char *val, const struct kernel_param *kp)
 {
        int i;
 
@@ -1368,7 +1368,7 @@ static int param_set_audit(const char *val, struct kernel_param *kp)
        return -EINVAL;
 }
 
-static int param_get_mode(char *buffer, struct kernel_param *kp)
+static int param_get_mode(char *buffer, const struct kernel_param *kp)
 {
        if (!apparmor_enabled)
                return -EINVAL;
@@ -1378,7 +1378,7 @@ static int param_get_mode(char *buffer, struct kernel_param *kp)
        return sprintf(buffer, "%s", aa_profile_mode_names[aa_g_profile_mode]);
 }
 
-static int param_set_mode(const char *val, struct kernel_param *kp)
+static int param_set_mode(const char *val, const struct kernel_param *kp)
 {
        int i;