<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">
From: Dominik Brodowski &lt;linux@dominikbrodowski.net&gt;

Properly wait for the class refcount to reach zero.

Signed-off-by: Dominik Brodowski &lt;linux@dominikbrodowski.net&gt;
Signed-off-by: Andrew Morton &lt;akpm@osdl.org&gt;
---

 25-akpm/drivers/pcmcia/cs.c |   16 +++++++++++++++-
 1 files changed, 15 insertions(+), 1 deletion(-)

diff -puN drivers/pcmcia/cs.c~pcmcia-release_class drivers/pcmcia/cs.c
--- 25/drivers/pcmcia/cs.c~pcmcia-release_class	2005-03-20 16:56:56.000000000 -0800
+++ 25-akpm/drivers/pcmcia/cs.c	2005-03-20 16:56:56.000000000 -0800
@@ -894,17 +894,29 @@ static int pcmcia_socket_hotplug(struct 
 }
 
 
+static struct completion pcmcia_unload;
+
+static void pcmcia_release_socket_class(struct class *data)
+{
+	complete(&amp;pcmcia_unload);
+}
+
+
 struct class pcmcia_socket_class = {
 	.name = "pcmcia_socket",
         .hotplug = pcmcia_socket_hotplug,
 	.release = pcmcia_release_socket,
+	.class_release = pcmcia_release_socket_class,
 };
 EXPORT_SYMBOL(pcmcia_socket_class);
 
 
 static int __init init_pcmcia_cs(void)
 {
-	int ret = class_register(&amp;pcmcia_socket_class);
+	int ret;
+
+	init_completion(&amp;pcmcia_unload);
+	ret = class_register(&amp;pcmcia_socket_class);
 	if (ret)
 		return (ret);
 	return class_interface_register(&amp;pccard_sysfs_interface);
@@ -914,6 +926,8 @@ static void __exit exit_pcmcia_cs(void)
 {
 	class_interface_unregister(&amp;pccard_sysfs_interface);
 	class_unregister(&amp;pcmcia_socket_class);
+
+	wait_for_completion(&amp;pcmcia_unload);
 }
 
 subsys_initcall(init_pcmcia_cs);
_
</pre></body></html>