Commit 18223a99 authored by Kamalesh Babulal's avatar Kamalesh Babulal Committed by Greg Kroah-Hartman

Staging: meilhaus: fix __symbol_get problems

next-20081120 kernel randconfig on x86_64 box fails, while !CONFIG_MODULES

drivers/staging/meilhaus/memain.c: In function 'me_probe_pci':
drivers/staging/meilhaus/memain.c:425: error: implicit declaration of function '__symbol_get'
drivers/staging/meilhaus/memain.c:425: warning: cast to pointer from integer of different size
drivers/staging/meilhaus/memain.c:433: warning: cast to pointer from integer of different size
drivers/staging/meilhaus/memain.c:453: error: implicit declaration of function '__symbol_put'
make[3]: *** [drivers/staging/meilhaus/memain.o] Error 1

the driver uses __symbol_get and __symbol_put instead of marco's
symbol_get and symbol_put, I have only build tested the patch.
Signed-off-by: default avatarKamalesh Babulal <kamalesh@linux.vnet.ibm.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 3fedd148
...@@ -422,7 +422,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id) ...@@ -422,7 +422,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id)
PDEBUG("module_name: %s\n", module_name); PDEBUG("module_name: %s\n", module_name);
if ((constructor = if ((constructor =
(me_pci_constructor_t) __symbol_get(constructor_name)) == NULL) { (me_pci_constructor_t) symbol_get(constructor_name)) == NULL) {
if (request_module(module_name)) { if (request_module(module_name)) {
PERROR("Error while request for module %s.\n", PERROR("Error while request for module %s.\n",
module_name); module_name);
...@@ -430,7 +430,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id) ...@@ -430,7 +430,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id)
} }
if ((constructor = if ((constructor =
(me_pci_constructor_t) __symbol_get(constructor_name)) == (me_pci_constructor_t) symbol_get(constructor_name)) ==
NULL) { NULL) {
PERROR("Can't get %s driver module constructor.\n", PERROR("Can't get %s driver module constructor.\n",
module_name); module_name);
...@@ -441,7 +441,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id) ...@@ -441,7 +441,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id)
if ((device & 0xF000) == 0x4000) { // Bosch build has differnt constructor for me4600. if ((device & 0xF000) == 0x4000) { // Bosch build has differnt constructor for me4600.
if ((n_device = if ((n_device =
(*constructor_bosch) (dev, me_bosch_fw)) == NULL) { (*constructor_bosch) (dev, me_bosch_fw)) == NULL) {
__symbol_put(constructor_name); symbol_put(constructor_name);
PERROR PERROR
("Can't get device instance of %s driver module.\n", ("Can't get device instance of %s driver module.\n",
module_name); module_name);
...@@ -450,7 +450,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id) ...@@ -450,7 +450,7 @@ static int me_probe_pci(struct pci_dev *dev, const struct pci_device_id *id)
} else { } else {
#endif #endif
if ((n_device = (*constructor) (dev)) == NULL) { if ((n_device = (*constructor) (dev)) == NULL) {
__symbol_put(constructor_name); symbol_put(constructor_name);
PERROR PERROR
("Can't get device instance of %s driver module.\n", ("Can't get device instance of %s driver module.\n",
module_name); module_name);
...@@ -503,7 +503,7 @@ static void release_instance(me_device_t * device) ...@@ -503,7 +503,7 @@ static void release_instance(me_device_t * device)
if (plugged != ME_PLUGGED_IN) { if (plugged != ME_PLUGGED_IN) {
PDEBUG("release: medummy_constructor\n"); PDEBUG("release: medummy_constructor\n");
__symbol_put("medummy_constructor"); symbol_put("medummy_constructor");
} else { } else {
if ((dev_id & 0xF000) == 0x6000) { // Exceptions: me61xx, me62xx, me63xx are handled by one driver. if ((dev_id & 0xF000) == 0x6000) { // Exceptions: me61xx, me62xx, me63xx are handled by one driver.
dev_id &= 0xF0FF; dev_id &= 0xF0FF;
...@@ -513,7 +513,7 @@ static void release_instance(me_device_t * device) ...@@ -513,7 +513,7 @@ static void release_instance(me_device_t * device)
constructor_name[3] += (char)((dev_id >> 8) & 0x000F); constructor_name[3] += (char)((dev_id >> 8) & 0x000F);
PDEBUG("release: %s\n", constructor_name); PDEBUG("release: %s\n", constructor_name);
__symbol_put(constructor_name); symbol_put(constructor_name);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment