From 08fa7ec452a119ee6fddbc0194bb6fb92d8c56db Mon Sep 17 00:00:00 2001 From: Bjorn Helgaas Date: Mon, 27 Mar 2006 01:17:08 -0800 Subject: [PATCH] --- yaml --- r: 24351 b: refs/heads/master c: 982c609448b9d724e1c3a0d5aeee388c064479f0 h: refs/heads/master i: 24349: 3f3e6e0ddb075dbaaf100351558283de46645afc 24347: ace20a926070cbd55238c9703c5677ee47a74ad0 24343: c36c2df56999e8ff4152a41142a01626388bd195 24335: 863975e50d9f7cfe5d1d1a9b95b37b4eeb6a976e 24319: 41d7a060eebaa89e18b38d53ba0e069f71c1fa43 v: v3 --- [refs] | 2 +- trunk/Documentation/pnp.txt | 3 +++ trunk/drivers/pnp/card.c | 16 +++++++--------- trunk/drivers/pnp/driver.c | 19 +------------------ 4 files changed, 12 insertions(+), 28 deletions(-) diff --git a/[refs] b/[refs] index 7eee31e561b5..bf0114562186 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 070c6999831dc4cfd9b07c74c2fea1964d7adfec +refs/heads/master: 982c609448b9d724e1c3a0d5aeee388c064479f0 diff --git a/trunk/Documentation/pnp.txt b/trunk/Documentation/pnp.txt index af0f6eabfa1c..9529c9c9fd59 100644 --- a/trunk/Documentation/pnp.txt +++ b/trunk/Documentation/pnp.txt @@ -115,6 +115,9 @@ pnp_unregister_protocol pnp_register_driver - adds a PnP driver to the Plug and Play Layer - this includes driver model integration +- returns zero for success or a negative error number for failure; count + calls to the .add() method if you need to know how many devices bind to + the driver pnp_unregister_driver - removes a PnP driver from the Plug and Play Layer diff --git a/trunk/drivers/pnp/card.c b/trunk/drivers/pnp/card.c index b68eef251614..bb19c64073c6 100644 --- a/trunk/drivers/pnp/card.c +++ b/trunk/drivers/pnp/card.c @@ -47,7 +47,7 @@ static void card_remove(struct pnp_dev * dev) { dev->card_link = NULL; } - + static void card_remove_first(struct pnp_dev * dev) { struct pnp_card_driver * drv = to_pnp_card_driver(dev->driver); @@ -361,7 +361,7 @@ static int card_resume(struct pnp_dev *dev) int pnp_register_card_driver(struct pnp_card_driver * drv) { - int count; + int error; struct list_head *pos, *temp; drv->link.name = drv->name; @@ -372,21 +372,19 @@ int pnp_register_card_driver(struct pnp_card_driver * drv) drv->link.suspend = drv->suspend ? card_suspend : NULL; drv->link.resume = drv->resume ? card_resume : NULL; - count = pnp_register_driver(&drv->link); - if (count < 0) - return count; + error = pnp_register_driver(&drv->link); + if (error < 0) + return error; spin_lock(&pnp_lock); list_add_tail(&drv->global_list, &pnp_card_drivers); spin_unlock(&pnp_lock); - count = 0; - list_for_each_safe(pos,temp,&pnp_cards){ struct pnp_card *card = list_entry(pos, struct pnp_card, global_list); - count += card_probe(card,drv); + card_probe(card,drv); } - return count; + return 0; } /** diff --git a/trunk/drivers/pnp/driver.c b/trunk/drivers/pnp/driver.c index 7cafacdd12b0..e54c15383193 100644 --- a/trunk/drivers/pnp/driver.c +++ b/trunk/drivers/pnp/driver.c @@ -201,31 +201,14 @@ struct bus_type pnp_bus_type = { .resume = pnp_bus_resume, }; - -static int count_devices(struct device * dev, void * c) -{ - int * count = c; - (*count)++; - return 0; -} - int pnp_register_driver(struct pnp_driver *drv) { - int count; - pnp_dbg("the driver '%s' has been registered", drv->name); drv->driver.name = drv->name; drv->driver.bus = &pnp_bus_type; - count = driver_register(&drv->driver); - - /* get the number of initial matches */ - if (count >= 0){ - count = 0; - driver_for_each_device(&drv->driver, NULL, &count, count_devices); - } - return count; + return driver_register(&drv->driver); } void pnp_unregister_driver(struct pnp_driver *drv)