Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f3990715 authored by Dominik Brodowski's avatar Dominik Brodowski
Browse files

[PATCH] pcmcia: remove old detach mechanism



Remove the old "detach" mechanism as it is unused now.

Signed-off-by: default avatarDominik Brodowski <linux@dominikbrodowski.net>
parent cc3b4866
Loading
Loading
Loading
Loading
+17 −60
Original line number Diff line number Diff line
@@ -402,9 +402,10 @@ static int pcmcia_device_remove(struct device * dev)
	/* detach the "instance" */
	p_dev = to_pcmcia_dev(dev);
	p_drv = to_pcmcia_drv(dev->driver);
	if (!p_drv)
		return 0;

	/* the likely, new path */
	if (p_drv && p_drv->remove) {
	if (p_drv->remove)
	       	p_drv->remove(p_dev);

	/* check for proper unloading */
@@ -428,21 +429,6 @@ static int pcmcia_device_remove(struct device * dev)
	return 0;
}

	/* old path */
	if (p_drv) {
		if ((p_drv->detach) && (p_dev->instance)) {
			printk(KERN_INFO "pcmcia: using deprecated detach mechanism. Fix the driver!\n");

			p_drv->detach(p_dev->instance);
			/* from pcmcia_probe_device */
			put_device(&p_dev->dev);
		}
		module_put(p_drv->owner);
	}

	return 0;
}


/*
 * Removes a PCMCIA card from the device tree and socket list.
@@ -1234,35 +1220,6 @@ int pcmcia_register_client(struct pcmcia_device **handle, client_reg_t *req)
EXPORT_SYMBOL(pcmcia_register_client);


int pcmcia_deregister_client(struct pcmcia_device *p_dev)
{
	struct pcmcia_socket *s;
	int i;

	s = p_dev->socket;
	ds_dbg(1, "deregister_client(%p)\n", p_dev);

	if (p_dev->state & (CLIENT_IRQ_REQ|CLIENT_IO_REQ|CLIENT_CONFIG_LOCKED))
		goto warn_out;
	for (i = 0; i < MAX_WIN; i++)
		if (p_dev->state & CLIENT_WIN_REQ(i))
			goto warn_out;

	if (p_dev->state & CLIENT_STALE) {
		p_dev->state &= ~CLIENT_STALE;
		pcmcia_put_dev(p_dev);
	} else {
		p_dev->state = CLIENT_UNBOUND;
	}

	return CS_SUCCESS;
 warn_out:
	printk(KERN_WARNING "ds: deregister_client was called too early.\n");
	return CS_IN_USE;
} /* deregister_client */
EXPORT_SYMBOL(pcmcia_deregister_client);


static struct pcmcia_callback pcmcia_bus_callback = {
	.owner = THIS_MODULE,
	.event = ds_event,
+0 −1
Original line number Diff line number Diff line
@@ -382,7 +382,6 @@ enum service {
struct pcmcia_socket;

int pcmcia_access_configuration_register(struct pcmcia_device *p_dev, conf_reg_t *reg);
int pcmcia_deregister_client(struct pcmcia_device *p_dev);
int pcmcia_get_configuration_info(struct pcmcia_device *p_dev, config_info_t *config);
int pcmcia_get_first_window(window_handle_t *win, win_req_t *req);
int pcmcia_get_next_window(window_handle_t *win, win_req_t *req);
+0 −1
Original line number Diff line number Diff line
@@ -136,7 +136,6 @@ struct pcmcia_driver {
	dev_link_t		*(*attach)(void);
	int (*event)		(event_t event, int priority,
				 event_callback_args_t *);
	void			(*detach)(dev_link_t *);

	void (*remove)		(struct pcmcia_device *dev);