diff --git a/common/console.c b/common/console.c index beb37bd..a0a06f6 100644 --- a/common/console.c +++ b/common/console.c @@ -99,33 +99,22 @@ return 0; } -static int console_baudrate_set(struct device_d *dev, struct param_d *param, - const char *val) +static int console_baudrate_set(struct param_d *param, void *priv) { - struct console_device *cdev = to_console_dev(dev); - int baudrate; - char baudstr[16]; + struct console_device *cdev = priv; unsigned char c; - if (!val) - dev_param_set_generic(dev, param, NULL); - - baudrate = simple_strtoul(val, NULL, 10); - if (cdev->f_active) { printf("## Switch baudrate to %d bps and press ENTER ...\n", - baudrate); + cdev->baudrate); mdelay(50); - cdev->setbrg(cdev, baudrate); + cdev->setbrg(cdev, cdev->baudrate); mdelay(50); do { c = getc(); } while (c != '\r' && c != '\n'); } else - cdev->setbrg(cdev, baudrate); - - sprintf(baudstr, "%d", baudrate); - dev_param_set_generic(dev, param, baudstr); + cdev->setbrg(cdev, cdev->baudrate); return 0; } @@ -155,8 +144,9 @@ platform_device_register(dev); if (newcdev->setbrg) { - dev_add_param(dev, "baudrate", console_baudrate_set, NULL, 0); - dev_set_param(dev, "baudrate", __stringify(CONFIG_BAUDRATE)); + newcdev->baudrate = CONFIG_BAUDRATE; + dev_add_param_int(dev, "baudrate", console_baudrate_set, + NULL, &newcdev->baudrate, "%u", newcdev); } dev_add_param(dev, "active", console_std_set, NULL, 0); diff --git a/drivers/mci/mci-core.c b/drivers/mci/mci-core.c index 059e635..86e8d5d 100644 --- a/drivers/mci/mci-core.c +++ b/drivers/mci/mci-core.c @@ -1461,15 +1461,16 @@ struct mci *mci = priv; int rc; + if (!mci->probe) + return 0; + rc = mci_check_if_already_initialized(mci); if (rc != 0) return 0; - if (mci->probe) { - rc = mci_card_probe(mci); - if (rc != 0) - return rc; - } + rc = mci_card_probe(mci); + if (rc != 0) + return rc; return 0; } @@ -1494,8 +1495,8 @@ dev_info(mci->host->hw_dev, "registered as %s\n", dev_name(mci_dev)); - mci->param_probe = dev_add_param_int(mci_dev, "probe", - mci_set_probe, NULL, &mci->probe, "%d", mci); + mci->param_probe = dev_add_param_bool(mci_dev, "probe", + mci_set_probe, NULL, &mci->probe, mci); if (IS_ERR(mci->param_probe)) { dev_dbg(mci->mci_dev, "Failed to add 'probe' parameter to the MCI device\n"); diff --git a/include/console.h b/include/console.h index c45feb4..72cf99f 100644 --- a/include/console.h +++ b/include/console.h @@ -42,6 +42,8 @@ unsigned char f_caps; unsigned char f_active; + + unsigned int baudrate; }; int console_register(struct console_device *cdev);