From bf3a970220a4609b6f23e045b1b612550a26c81d Mon Sep 17 00:00:00 2001 From: Geert Uytterhoeven Date: Sun, 18 Nov 2007 11:10:04 +0100 Subject: [PATCH] --- yaml --- r: 74033 b: refs/heads/master c: 2f9b0b5e46f0381fd41af8cb9ed4daffee59d4f3 h: refs/heads/master i: 74031: f88b5aeb8623a4912289d91e6743f74283e51edc v: v3 --- [refs] | 2 +- trunk/drivers/zorro/zorro-driver.c | 15 +++++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index e899d24d6b94..40e35560fcd0 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 9e893bb8530d9c09b1eb8da8734eebf4182bb8b7 +refs/heads/master: 2f9b0b5e46f0381fd41af8cb9ed4daffee59d4f3 diff --git a/trunk/drivers/zorro/zorro-driver.c b/trunk/drivers/zorro/zorro-driver.c index 067c07be928c..e6c4390d8bd6 100644 --- a/trunk/drivers/zorro/zorro-driver.c +++ b/trunk/drivers/zorro/zorro-driver.c @@ -60,6 +60,20 @@ static int zorro_device_probe(struct device *dev) } +static int zorro_device_remove(struct device *dev) +{ + struct zorro_dev *z = to_zorro_dev(dev); + struct zorro_driver *drv = to_zorro_driver(dev->driver); + + if (drv) { + if (drv->remove) + drv->remove(z); + z->driver = NULL; + } + return 0; +} + + /** * zorro_register_driver - register a new Zorro driver * @drv: the driver structure to register @@ -128,6 +142,7 @@ struct bus_type zorro_bus_type = { .name = "zorro", .match = zorro_bus_match, .probe = zorro_device_probe, + .remove = zorro_device_remove, };