You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
[PATCH] pcmcia: unify detach, REMOVAL_EVENT handlers into one remove callback
Unify the "detach" and REMOVAL_EVENT handlers to one "remove" function. Old functionality is preserved, for the moment. Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
This commit is contained in:
@@ -1,5 +1,8 @@
|
|||||||
This file details changes in 2.6 which affect PCMCIA card driver authors:
|
This file details changes in 2.6 which affect PCMCIA card driver authors:
|
||||||
|
|
||||||
|
* Unify detach and REMOVAL event code (as of 2.6.16)
|
||||||
|
void (*remove) (struct pcmcia_device *dev);
|
||||||
|
|
||||||
* Move suspend, resume and reset out of event handler (as of 2.6.16)
|
* Move suspend, resume and reset out of event handler (as of 2.6.16)
|
||||||
int (*suspend) (struct pcmcia_device *dev);
|
int (*suspend) (struct pcmcia_device *dev);
|
||||||
int (*resume) (struct pcmcia_device *dev);
|
int (*resume) (struct pcmcia_device *dev);
|
||||||
|
|||||||
@@ -92,7 +92,7 @@ static int bluecard_event(event_t event, int priority, event_callback_args_t *ar
|
|||||||
static dev_info_t dev_info = "bluecard_cs";
|
static dev_info_t dev_info = "bluecard_cs";
|
||||||
|
|
||||||
static dev_link_t *bluecard_attach(void);
|
static dev_link_t *bluecard_attach(void);
|
||||||
static void bluecard_detach(dev_link_t *);
|
static void bluecard_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list = NULL;
|
static dev_link_t *dev_list = NULL;
|
||||||
|
|
||||||
@@ -899,7 +899,7 @@ static dev_link_t *bluecard_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
bluecard_detach(link);
|
bluecard_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -907,11 +907,11 @@ static dev_link_t *bluecard_attach(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void bluecard_detach(dev_link_t *link)
|
static void bluecard_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
bluecard_info_t *info = link->priv;
|
bluecard_info_t *info = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
int ret;
|
|
||||||
|
|
||||||
/* Locate device structure */
|
/* Locate device structure */
|
||||||
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
||||||
@@ -924,12 +924,6 @@ static void bluecard_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
bluecard_release(link);
|
bluecard_release(link);
|
||||||
|
|
||||||
if (link->handle) {
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
|
|
||||||
@@ -1070,16 +1064,8 @@ static int bluecard_resume(struct pcmcia_device *dev)
|
|||||||
static int bluecard_event(event_t event, int priority, event_callback_args_t *args)
|
static int bluecard_event(event_t event, int priority, event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
bluecard_info_t *info = link->priv;
|
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
bluecard_close(info);
|
|
||||||
bluecard_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
bluecard_config(link);
|
bluecard_config(link);
|
||||||
@@ -1104,7 +1090,7 @@ static struct pcmcia_driver bluecard_driver = {
|
|||||||
},
|
},
|
||||||
.attach = bluecard_attach,
|
.attach = bluecard_attach,
|
||||||
.event = bluecard_event,
|
.event = bluecard_event,
|
||||||
.detach = bluecard_detach,
|
.remove = bluecard_detach,
|
||||||
.id_table = bluecard_ids,
|
.id_table = bluecard_ids,
|
||||||
.suspend = bluecard_suspend,
|
.suspend = bluecard_suspend,
|
||||||
.resume = bluecard_resume,
|
.resume = bluecard_resume,
|
||||||
|
|||||||
@@ -95,7 +95,7 @@ static int bt3c_event(event_t event, int priority, event_callback_args_t *args);
|
|||||||
static dev_info_t dev_info = "bt3c_cs";
|
static dev_info_t dev_info = "bt3c_cs";
|
||||||
|
|
||||||
static dev_link_t *bt3c_attach(void);
|
static dev_link_t *bt3c_attach(void);
|
||||||
static void bt3c_detach(dev_link_t *);
|
static void bt3c_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list = NULL;
|
static dev_link_t *dev_list = NULL;
|
||||||
|
|
||||||
@@ -700,7 +700,7 @@ static dev_link_t *bt3c_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
bt3c_detach(link);
|
bt3c_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -708,11 +708,11 @@ static dev_link_t *bt3c_attach(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void bt3c_detach(dev_link_t *link)
|
static void bt3c_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
bt3c_info_t *info = link->priv;
|
bt3c_info_t *info = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
int ret;
|
|
||||||
|
|
||||||
/* Locate device structure */
|
/* Locate device structure */
|
||||||
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
||||||
@@ -725,12 +725,6 @@ static void bt3c_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
bt3c_release(link);
|
bt3c_release(link);
|
||||||
|
|
||||||
if (link->handle) {
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
|
|
||||||
@@ -916,16 +910,8 @@ static int bt3c_resume(struct pcmcia_device *dev)
|
|||||||
static int bt3c_event(event_t event, int priority, event_callback_args_t *args)
|
static int bt3c_event(event_t event, int priority, event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
bt3c_info_t *info = link->priv;
|
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
bt3c_close(info);
|
|
||||||
bt3c_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
bt3c_config(link);
|
bt3c_config(link);
|
||||||
@@ -948,7 +934,7 @@ static struct pcmcia_driver bt3c_driver = {
|
|||||||
},
|
},
|
||||||
.attach = bt3c_attach,
|
.attach = bt3c_attach,
|
||||||
.event = bt3c_event,
|
.event = bt3c_event,
|
||||||
.detach = bt3c_detach,
|
.remove = bt3c_detach,
|
||||||
.id_table = bt3c_ids,
|
.id_table = bt3c_ids,
|
||||||
.suspend = bt3c_suspend,
|
.suspend = bt3c_suspend,
|
||||||
.resume = bt3c_resume,
|
.resume = bt3c_resume,
|
||||||
|
|||||||
@@ -91,7 +91,7 @@ static int btuart_event(event_t event, int priority, event_callback_args_t *args
|
|||||||
static dev_info_t dev_info = "btuart_cs";
|
static dev_info_t dev_info = "btuart_cs";
|
||||||
|
|
||||||
static dev_link_t *btuart_attach(void);
|
static dev_link_t *btuart_attach(void);
|
||||||
static void btuart_detach(dev_link_t *);
|
static void btuart_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list = NULL;
|
static dev_link_t *dev_list = NULL;
|
||||||
|
|
||||||
@@ -619,7 +619,7 @@ static dev_link_t *btuart_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
btuart_detach(link);
|
btuart_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -627,11 +627,11 @@ static dev_link_t *btuart_attach(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void btuart_detach(dev_link_t *link)
|
static void btuart_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
btuart_info_t *info = link->priv;
|
btuart_info_t *info = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
int ret;
|
|
||||||
|
|
||||||
/* Locate device structure */
|
/* Locate device structure */
|
||||||
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
||||||
@@ -644,12 +644,6 @@ static void btuart_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
btuart_release(link);
|
btuart_release(link);
|
||||||
|
|
||||||
if (link->handle) {
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
|
|
||||||
@@ -837,16 +831,8 @@ static int btuart_resume(struct pcmcia_device *dev)
|
|||||||
static int btuart_event(event_t event, int priority, event_callback_args_t *args)
|
static int btuart_event(event_t event, int priority, event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
btuart_info_t *info = link->priv;
|
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
btuart_close(info);
|
|
||||||
btuart_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
btuart_config(link);
|
btuart_config(link);
|
||||||
@@ -869,7 +855,7 @@ static struct pcmcia_driver btuart_driver = {
|
|||||||
},
|
},
|
||||||
.attach = btuart_attach,
|
.attach = btuart_attach,
|
||||||
.event = btuart_event,
|
.event = btuart_event,
|
||||||
.detach = btuart_detach,
|
.remove = btuart_detach,
|
||||||
.id_table = btuart_ids,
|
.id_table = btuart_ids,
|
||||||
.suspend = btuart_suspend,
|
.suspend = btuart_suspend,
|
||||||
.resume = btuart_resume,
|
.resume = btuart_resume,
|
||||||
|
|||||||
@@ -94,7 +94,7 @@ static int dtl1_event(event_t event, int priority, event_callback_args_t *args);
|
|||||||
static dev_info_t dev_info = "dtl1_cs";
|
static dev_info_t dev_info = "dtl1_cs";
|
||||||
|
|
||||||
static dev_link_t *dtl1_attach(void);
|
static dev_link_t *dtl1_attach(void);
|
||||||
static void dtl1_detach(dev_link_t *);
|
static void dtl1_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list = NULL;
|
static dev_link_t *dev_list = NULL;
|
||||||
|
|
||||||
@@ -598,7 +598,7 @@ static dev_link_t *dtl1_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
dtl1_detach(link);
|
dtl1_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -606,11 +606,11 @@ static dev_link_t *dtl1_attach(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void dtl1_detach(dev_link_t *link)
|
static void dtl1_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dtl1_info_t *info = link->priv;
|
dtl1_info_t *info = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
int ret;
|
|
||||||
|
|
||||||
/* Locate device structure */
|
/* Locate device structure */
|
||||||
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
||||||
@@ -623,12 +623,6 @@ static void dtl1_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
dtl1_release(link);
|
dtl1_release(link);
|
||||||
|
|
||||||
if (link->handle) {
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
|
|
||||||
@@ -788,16 +782,8 @@ static int dtl1_resume(struct pcmcia_device *dev)
|
|||||||
static int dtl1_event(event_t event, int priority, event_callback_args_t *args)
|
static int dtl1_event(event_t event, int priority, event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
dtl1_info_t *info = link->priv;
|
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
dtl1_close(info);
|
|
||||||
dtl1_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
dtl1_config(link);
|
dtl1_config(link);
|
||||||
@@ -821,7 +807,7 @@ static struct pcmcia_driver dtl1_driver = {
|
|||||||
},
|
},
|
||||||
.attach = dtl1_attach,
|
.attach = dtl1_attach,
|
||||||
.event = dtl1_event,
|
.event = dtl1_event,
|
||||||
.detach = dtl1_detach,
|
.remove = dtl1_detach,
|
||||||
.id_table = dtl1_ids,
|
.id_table = dtl1_ids,
|
||||||
.suspend = dtl1_suspend,
|
.suspend = dtl1_suspend,
|
||||||
.resume = dtl1_resume,
|
.resume = dtl1_resume,
|
||||||
|
|||||||
@@ -66,7 +66,7 @@ static char *version = "cm4000_cs.c v2.4.0gm5 - All bugs added by Harald Welte";
|
|||||||
#define T_100MSEC msecs_to_jiffies(100)
|
#define T_100MSEC msecs_to_jiffies(100)
|
||||||
#define T_500MSEC msecs_to_jiffies(500)
|
#define T_500MSEC msecs_to_jiffies(500)
|
||||||
|
|
||||||
static void cm4000_detach(dev_link_t *link);
|
static void cm4000_detach(struct pcmcia_device *p_dev);
|
||||||
static void cm4000_release(dev_link_t *link);
|
static void cm4000_release(dev_link_t *link);
|
||||||
|
|
||||||
static int major; /* major number we get from the kernel */
|
static int major; /* major number we get from the kernel */
|
||||||
@@ -1888,11 +1888,6 @@ static int cm4000_event(event_t event, int priority,
|
|||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
cm4000_config(link, devno);
|
cm4000_config(link, devno);
|
||||||
break;
|
break;
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
DEBUGP(5, dev, "CS_EVENT_CARD_REMOVAL\n");
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
stop_monitor(dev);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
DEBUGP(5, dev, "unknown event %.2x\n", event);
|
DEBUGP(5, dev, "unknown event %.2x\n", event);
|
||||||
break;
|
break;
|
||||||
@@ -1978,7 +1973,7 @@ static dev_link_t *cm4000_attach(void)
|
|||||||
i = pcmcia_register_client(&link->handle, &client_reg);
|
i = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (i) {
|
if (i) {
|
||||||
cs_error(link->handle, RegisterClient, i);
|
cs_error(link->handle, RegisterClient, i);
|
||||||
cm4000_detach(link);
|
cm4000_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1990,39 +1985,28 @@ static dev_link_t *cm4000_attach(void)
|
|||||||
return link;
|
return link;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cm4000_detach_by_devno(int devno, dev_link_t * link)
|
static void cm4000_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
struct cm4000_dev *dev = link->priv;
|
struct cm4000_dev *dev = link->priv;
|
||||||
|
int devno;
|
||||||
DEBUGP(3, dev, "-> detach_by_devno(devno=%d)\n", devno);
|
|
||||||
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
DEBUGP(5, dev, "device still configured (try to release it)\n");
|
|
||||||
cm4000_release(link);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (link->handle) {
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
dev_table[devno] = NULL;
|
|
||||||
kfree(dev);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void cm4000_detach(dev_link_t * link)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
/* find device */
|
/* find device */
|
||||||
for (i = 0; i < CM4000_MAX_DEV; i++)
|
for (devno = 0; devno < CM4000_MAX_DEV; devno++)
|
||||||
if (dev_table[i] == link)
|
if (dev_table[devno] == link)
|
||||||
break;
|
break;
|
||||||
|
if (devno == CM4000_MAX_DEV)
|
||||||
if (i == CM4000_MAX_DEV)
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
cm4000_detach_by_devno(i, link);
|
link->state &= ~DEV_PRESENT;
|
||||||
|
stop_monitor(dev);
|
||||||
|
|
||||||
|
if (link->state & DEV_CONFIG)
|
||||||
|
cm4000_release(link);
|
||||||
|
|
||||||
|
dev_table[devno] = NULL;
|
||||||
|
kfree(dev);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2048,7 +2032,7 @@ static struct pcmcia_driver cm4000_driver = {
|
|||||||
.name = "cm4000_cs",
|
.name = "cm4000_cs",
|
||||||
},
|
},
|
||||||
.attach = cm4000_attach,
|
.attach = cm4000_attach,
|
||||||
.detach = cm4000_detach,
|
.remove = cm4000_detach,
|
||||||
.suspend = cm4000_suspend,
|
.suspend = cm4000_suspend,
|
||||||
.resume = cm4000_resume,
|
.resume = cm4000_resume,
|
||||||
.event = cm4000_event,
|
.event = cm4000_event,
|
||||||
@@ -2071,13 +2055,8 @@ static int __init cmm_init(void)
|
|||||||
|
|
||||||
static void __exit cmm_exit(void)
|
static void __exit cmm_exit(void)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
|
|
||||||
printk(KERN_INFO MODULE_NAME ": unloading\n");
|
printk(KERN_INFO MODULE_NAME ": unloading\n");
|
||||||
pcmcia_unregister_driver(&cm4000_driver);
|
pcmcia_unregister_driver(&cm4000_driver);
|
||||||
for (i = 0; i < CM4000_MAX_DEV; i++)
|
|
||||||
if (dev_table[i])
|
|
||||||
cm4000_detach_by_devno(i, dev_table[i]);
|
|
||||||
unregister_chrdev(major, DEVICE_NAME);
|
unregister_chrdev(major, DEVICE_NAME);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -65,7 +65,7 @@ static char *version =
|
|||||||
#define POLL_PERIOD msecs_to_jiffies(10)
|
#define POLL_PERIOD msecs_to_jiffies(10)
|
||||||
|
|
||||||
static void reader_release(dev_link_t *link);
|
static void reader_release(dev_link_t *link);
|
||||||
static void reader_detach(dev_link_t *link);
|
static void reader_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static int major;
|
static int major;
|
||||||
|
|
||||||
@@ -652,10 +652,6 @@ static int reader_event(event_t event, int priority,
|
|||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
reader_config(link, devno);
|
reader_config(link, devno);
|
||||||
break;
|
break;
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
DEBUGP(5, dev, "CS_EVENT_CARD_REMOVAL\n");
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
DEBUGP(5, dev, "reader_event: unknown event %.2x\n",
|
DEBUGP(5, dev, "reader_event: unknown event %.2x\n",
|
||||||
@@ -734,7 +730,7 @@ static dev_link_t *reader_attach(void)
|
|||||||
i = pcmcia_register_client(&link->handle, &client_reg);
|
i = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (i) {
|
if (i) {
|
||||||
cs_error(link->handle, RegisterClient, i);
|
cs_error(link->handle, RegisterClient, i);
|
||||||
reader_detach(link);
|
reader_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
init_waitqueue_head(&dev->devq);
|
init_waitqueue_head(&dev->devq);
|
||||||
@@ -747,36 +743,28 @@ static dev_link_t *reader_attach(void)
|
|||||||
return link;
|
return link;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void reader_detach_by_devno(int devno, dev_link_t *link)
|
static void reader_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
struct reader_dev *dev = link->priv;
|
struct reader_dev *dev = link->priv;
|
||||||
|
int devno;
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
DEBUGP(5, dev, "device still configured (try to release it)\n");
|
|
||||||
reader_release(link);
|
|
||||||
}
|
|
||||||
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
dev_table[devno] = NULL;
|
|
||||||
DEBUGP(5, dev, "freeing dev=%p\n", dev);
|
|
||||||
cm4040_stop_poll(dev);
|
|
||||||
kfree(dev);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void reader_detach(dev_link_t *link)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
/* find device */
|
/* find device */
|
||||||
for (i = 0; i < CM_MAX_DEV; i++) {
|
for (devno = 0; devno < CM_MAX_DEV; devno++) {
|
||||||
if (dev_table[i] == link)
|
if (dev_table[devno] == link)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (i == CM_MAX_DEV)
|
if (devno == CM_MAX_DEV)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
reader_detach_by_devno(i, link);
|
link->state &= ~DEV_PRESENT;
|
||||||
|
|
||||||
|
if (link->state & DEV_CONFIG)
|
||||||
|
reader_release(link);
|
||||||
|
|
||||||
|
dev_table[devno] = NULL;
|
||||||
|
kfree(dev);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -803,7 +791,7 @@ static struct pcmcia_driver reader_driver = {
|
|||||||
.name = "cm4040_cs",
|
.name = "cm4040_cs",
|
||||||
},
|
},
|
||||||
.attach = reader_attach,
|
.attach = reader_attach,
|
||||||
.detach = reader_detach,
|
.remove = reader_detach,
|
||||||
.suspend = reader_suspend,
|
.suspend = reader_suspend,
|
||||||
.resume = reader_resume,
|
.resume = reader_resume,
|
||||||
.event = reader_event,
|
.event = reader_event,
|
||||||
@@ -825,14 +813,8 @@ static int __init cm4040_init(void)
|
|||||||
|
|
||||||
static void __exit cm4040_exit(void)
|
static void __exit cm4040_exit(void)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
|
|
||||||
printk(KERN_INFO MODULE_NAME ": unloading\n");
|
printk(KERN_INFO MODULE_NAME ": unloading\n");
|
||||||
pcmcia_unregister_driver(&reader_driver);
|
pcmcia_unregister_driver(&reader_driver);
|
||||||
for (i = 0; i < CM_MAX_DEV; i++) {
|
|
||||||
if (dev_table[i])
|
|
||||||
reader_detach_by_devno(i, dev_table[i]);
|
|
||||||
}
|
|
||||||
unregister_chrdev(major, DEVICE_NAME);
|
unregister_chrdev(major, DEVICE_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -489,7 +489,7 @@ static void mgslpc_release(u_long arg);
|
|||||||
static int mgslpc_event(event_t event, int priority,
|
static int mgslpc_event(event_t event, int priority,
|
||||||
event_callback_args_t *args);
|
event_callback_args_t *args);
|
||||||
static dev_link_t *mgslpc_attach(void);
|
static dev_link_t *mgslpc_attach(void);
|
||||||
static void mgslpc_detach(dev_link_t *);
|
static void mgslpc_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_info_t dev_info = "synclink_cs";
|
static dev_info_t dev_info = "synclink_cs";
|
||||||
static dev_link_t *dev_list = NULL;
|
static dev_link_t *dev_list = NULL;
|
||||||
@@ -598,7 +598,7 @@ static dev_link_t *mgslpc_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
mgslpc_detach(link);
|
mgslpc_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -736,17 +736,16 @@ static void mgslpc_release(u_long arg)
|
|||||||
pcmcia_release_io(link->handle, &link->io);
|
pcmcia_release_io(link->handle, &link->io);
|
||||||
if (link->irq.AssignedIRQ)
|
if (link->irq.AssignedIRQ)
|
||||||
pcmcia_release_irq(link->handle, &link->irq);
|
pcmcia_release_irq(link->handle, &link->irq);
|
||||||
if (link->state & DEV_STALE_LINK)
|
|
||||||
mgslpc_detach(link);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mgslpc_detach(dev_link_t *link)
|
static void mgslpc_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
if (debug_level >= DEBUG_LEVEL_INFO)
|
if (debug_level >= DEBUG_LEVEL_INFO)
|
||||||
printk("mgslpc_detach(0x%p)\n", link);
|
printk("mgslpc_detach(0x%p)\n", link);
|
||||||
|
|
||||||
/* find device */
|
/* find device */
|
||||||
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
||||||
if (*linkp == link) break;
|
if (*linkp == link) break;
|
||||||
@@ -754,20 +753,10 @@ static void mgslpc_detach(dev_link_t *link)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (link->state & DEV_CONFIG) {
|
if (link->state & DEV_CONFIG) {
|
||||||
/* device is configured/active, mark it so when
|
((MGSLPC_INFO *)link->priv)->stop = 1;
|
||||||
* release() is called a proper detach() occurs.
|
mgslpc_release((u_long)link);
|
||||||
*/
|
|
||||||
if (debug_level >= DEBUG_LEVEL_INFO)
|
|
||||||
printk(KERN_DEBUG "synclinkpc: detach postponed, '%s' "
|
|
||||||
"still locked\n", link->dev->dev_name);
|
|
||||||
link->state |= DEV_STALE_LINK;
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Break the link with Card Services */
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, and free it */
|
/* Unlink device structure, and free it */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
mgslpc_remove_device((MGSLPC_INFO *)link->priv);
|
mgslpc_remove_device((MGSLPC_INFO *)link->priv);
|
||||||
@@ -809,13 +798,6 @@ static int mgslpc_event(event_t event, int priority,
|
|||||||
printk("mgslpc_event(0x%06x)\n", event);
|
printk("mgslpc_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
((MGSLPC_INFO *)link->priv)->stop = 1;
|
|
||||||
mgslpc_release((u_long)link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
mgslpc_config(link);
|
mgslpc_config(link);
|
||||||
@@ -3102,7 +3084,7 @@ static struct pcmcia_driver mgslpc_driver = {
|
|||||||
},
|
},
|
||||||
.attach = mgslpc_attach,
|
.attach = mgslpc_attach,
|
||||||
.event = mgslpc_event,
|
.event = mgslpc_event,
|
||||||
.detach = mgslpc_detach,
|
.remove = mgslpc_detach,
|
||||||
.id_table = mgslpc_ids,
|
.id_table = mgslpc_ids,
|
||||||
.suspend = mgslpc_suspend,
|
.suspend = mgslpc_suspend,
|
||||||
.resume = mgslpc_resume,
|
.resume = mgslpc_resume,
|
||||||
|
|||||||
@@ -94,7 +94,7 @@ static int ide_event(event_t event, int priority,
|
|||||||
static dev_info_t dev_info = "ide-cs";
|
static dev_info_t dev_info = "ide-cs";
|
||||||
|
|
||||||
static dev_link_t *ide_attach(void);
|
static dev_link_t *ide_attach(void);
|
||||||
static void ide_detach(dev_link_t *);
|
static void ide_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list = NULL;
|
static dev_link_t *dev_list = NULL;
|
||||||
|
|
||||||
@@ -138,7 +138,7 @@ static dev_link_t *ide_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
ide_detach(link);
|
ide_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -154,10 +154,10 @@ static dev_link_t *ide_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void ide_detach(dev_link_t *link)
|
static void ide_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
int ret;
|
|
||||||
|
|
||||||
DEBUG(0, "ide_detach(0x%p)\n", link);
|
DEBUG(0, "ide_detach(0x%p)\n", link);
|
||||||
|
|
||||||
@@ -170,12 +170,6 @@ static void ide_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
ide_release(link);
|
ide_release(link);
|
||||||
|
|
||||||
if (link->handle) {
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Unlink, free device structure */
|
/* Unlink, free device structure */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
kfree(link->priv);
|
kfree(link->priv);
|
||||||
@@ -445,11 +439,6 @@ int ide_event(event_t event, int priority,
|
|||||||
DEBUG(1, "ide_event(0x%06x)\n", event);
|
DEBUG(1, "ide_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
ide_release(link);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
ide_config(link);
|
ide_config(link);
|
||||||
@@ -504,7 +493,7 @@ static struct pcmcia_driver ide_cs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = ide_attach,
|
.attach = ide_attach,
|
||||||
.event = ide_event,
|
.event = ide_event,
|
||||||
.detach = ide_detach,
|
.remove = ide_detach,
|
||||||
.id_table = ide_ids,
|
.id_table = ide_ids,
|
||||||
.suspend = ide_suspend,
|
.suspend = ide_suspend,
|
||||||
.resume = ide_resume,
|
.resume = ide_resume,
|
||||||
|
|||||||
@@ -63,7 +63,7 @@ static int avmcs_event(event_t event, int priority,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static dev_link_t *avmcs_attach(void);
|
static dev_link_t *avmcs_attach(void);
|
||||||
static void avmcs_detach(dev_link_t *);
|
static void avmcs_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
The dev_info variable is the "key" that is used to match up this
|
The dev_info variable is the "key" that is used to match up this
|
||||||
@@ -165,7 +165,7 @@ static dev_link_t *avmcs_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
avmcs_detach(link);
|
avmcs_detach(link->handle);
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
return link;
|
return link;
|
||||||
@@ -185,8 +185,9 @@ static dev_link_t *avmcs_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void avmcs_detach(dev_link_t *link)
|
static void avmcs_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
/* Locate device structure */
|
/* Locate device structure */
|
||||||
@@ -195,21 +196,9 @@ static void avmcs_detach(dev_link_t *link)
|
|||||||
if (*linkp == NULL)
|
if (*linkp == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/*
|
if (link->state & DEV_CONFIG)
|
||||||
If the device is currently configured and active, we won't
|
avmcs_release(link);
|
||||||
actually delete it yet. Instead, it is marked so that when
|
|
||||||
the release() function is called, that will trigger a proper
|
|
||||||
detach().
|
|
||||||
*/
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
link->state |= DEV_STALE_LINK;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Break the link with Card Services */
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, free pieces */
|
/* Unlink device structure, free pieces */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
kfree(link->priv);
|
kfree(link->priv);
|
||||||
@@ -424,10 +413,6 @@ static void avmcs_release(dev_link_t *link)
|
|||||||
pcmcia_release_io(link->handle, &link->io);
|
pcmcia_release_io(link->handle, &link->io);
|
||||||
pcmcia_release_irq(link->handle, &link->irq);
|
pcmcia_release_irq(link->handle, &link->irq);
|
||||||
link->state &= ~DEV_CONFIG;
|
link->state &= ~DEV_CONFIG;
|
||||||
|
|
||||||
if (link->state & DEV_STALE_LINK)
|
|
||||||
avmcs_detach(link);
|
|
||||||
|
|
||||||
} /* avmcs_release */
|
} /* avmcs_release */
|
||||||
|
|
||||||
static int avmcs_suspend(struct pcmcia_device *dev)
|
static int avmcs_suspend(struct pcmcia_device *dev)
|
||||||
@@ -472,11 +457,6 @@ static int avmcs_event(event_t event, int priority,
|
|||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
avmcs_release(link);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
avmcs_config(link);
|
avmcs_config(link);
|
||||||
@@ -500,7 +480,7 @@ static struct pcmcia_driver avmcs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = avmcs_attach,
|
.attach = avmcs_attach,
|
||||||
.event = avmcs_event,
|
.event = avmcs_event,
|
||||||
.detach = avmcs_detach,
|
.remove = avmcs_detach,
|
||||||
.id_table = avmcs_ids,
|
.id_table = avmcs_ids,
|
||||||
.suspend= avmcs_suspend,
|
.suspend= avmcs_suspend,
|
||||||
.resume = avmcs_resume,
|
.resume = avmcs_resume,
|
||||||
|
|||||||
@@ -79,7 +79,7 @@ static int avma1cs_event(event_t event, int priority,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static dev_link_t *avma1cs_attach(void);
|
static dev_link_t *avma1cs_attach(void);
|
||||||
static void avma1cs_detach(dev_link_t *);
|
static void avma1cs_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
The dev_info variable is the "key" that is used to match up this
|
The dev_info variable is the "key" that is used to match up this
|
||||||
@@ -187,7 +187,7 @@ static dev_link_t *avma1cs_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
avma1cs_detach(link);
|
avma1cs_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -203,42 +203,26 @@ static dev_link_t *avma1cs_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void avma1cs_detach(dev_link_t *link)
|
static void avma1cs_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
DEBUG(0, "avma1cs_detach(0x%p)\n", link);
|
DEBUG(0, "avma1cs_detach(0x%p)\n", link);
|
||||||
|
|
||||||
/* Locate device structure */
|
/* Locate device structure */
|
||||||
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
for (linkp = &dev_list; *linkp; linkp = &(*linkp)->next)
|
||||||
if (*linkp == link) break;
|
if (*linkp == link) break;
|
||||||
if (*linkp == NULL)
|
if (*linkp == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/*
|
if (link->state & DEV_CONFIG)
|
||||||
If the device is currently configured and active, we won't
|
avma1cs_release(link);
|
||||||
actually delete it yet. Instead, it is marked so that when
|
|
||||||
the release() function is called, that will trigger a proper
|
|
||||||
detach().
|
|
||||||
*/
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
#ifdef PCMCIA_DEBUG
|
|
||||||
printk(KERN_DEBUG "avma1_cs: detach postponed, '%s' "
|
|
||||||
"still locked\n", link->dev->dev_name);
|
|
||||||
#endif
|
|
||||||
link->state |= DEV_STALE_LINK;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Break the link with Card Services */
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, free pieces */
|
/* Unlink device structure, free pieces */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
kfree(link->priv);
|
kfree(link->priv);
|
||||||
kfree(link);
|
kfree(link);
|
||||||
|
|
||||||
} /* avma1cs_detach */
|
} /* avma1cs_detach */
|
||||||
|
|
||||||
/*======================================================================
|
/*======================================================================
|
||||||
@@ -440,9 +424,6 @@ static void avma1cs_release(dev_link_t *link)
|
|||||||
pcmcia_release_io(link->handle, &link->io);
|
pcmcia_release_io(link->handle, &link->io);
|
||||||
pcmcia_release_irq(link->handle, &link->irq);
|
pcmcia_release_irq(link->handle, &link->irq);
|
||||||
link->state &= ~DEV_CONFIG;
|
link->state &= ~DEV_CONFIG;
|
||||||
|
|
||||||
if (link->state & DEV_STALE_LINK)
|
|
||||||
avma1cs_detach(link);
|
|
||||||
} /* avma1cs_release */
|
} /* avma1cs_release */
|
||||||
|
|
||||||
static int avma1cs_suspend(struct pcmcia_device *dev)
|
static int avma1cs_suspend(struct pcmcia_device *dev)
|
||||||
@@ -489,10 +470,6 @@ static int avma1cs_event(event_t event, int priority,
|
|||||||
DEBUG(1, "avma1cs_event(0x%06x)\n", event);
|
DEBUG(1, "avma1cs_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
avma1cs_release(link);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
avma1cs_config(link);
|
avma1cs_config(link);
|
||||||
@@ -515,7 +492,7 @@ static struct pcmcia_driver avma1cs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = avma1cs_attach,
|
.attach = avma1cs_attach,
|
||||||
.event = avma1cs_event,
|
.event = avma1cs_event,
|
||||||
.detach = avma1cs_detach,
|
.remove = avma1cs_detach,
|
||||||
.id_table = avma1cs_ids,
|
.id_table = avma1cs_ids,
|
||||||
.suspend = avma1cs_suspend,
|
.suspend = avma1cs_suspend,
|
||||||
.resume = avma1cs_resume,
|
.resume = avma1cs_resume,
|
||||||
|
|||||||
@@ -106,7 +106,7 @@ static int elsa_cs_event(event_t event, int priority,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static dev_link_t *elsa_cs_attach(void);
|
static dev_link_t *elsa_cs_attach(void);
|
||||||
static void elsa_cs_detach(dev_link_t *);
|
static void elsa_cs_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
The dev_info variable is the "key" that is used to match up this
|
The dev_info variable is the "key" that is used to match up this
|
||||||
@@ -216,7 +216,7 @@ static dev_link_t *elsa_cs_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
elsa_cs_detach(link);
|
elsa_cs_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -232,11 +232,11 @@ static dev_link_t *elsa_cs_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void elsa_cs_detach(dev_link_t *link)
|
static void elsa_cs_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
local_info_t *info = link->priv;
|
local_info_t *info = link->priv;
|
||||||
int ret;
|
|
||||||
|
|
||||||
DEBUG(0, "elsa_cs_detach(0x%p)\n", link);
|
DEBUG(0, "elsa_cs_detach(0x%p)\n", link);
|
||||||
|
|
||||||
@@ -246,14 +246,9 @@ static void elsa_cs_detach(dev_link_t *link)
|
|||||||
if (*linkp == NULL)
|
if (*linkp == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG) {
|
||||||
|
((local_info_t*)link->priv)->busy = 1;
|
||||||
elsa_cs_release(link);
|
elsa_cs_release(link);
|
||||||
|
|
||||||
/* Break the link with Card Services */
|
|
||||||
if (link->handle) {
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Unlink device structure and free it */
|
/* Unlink device structure and free it */
|
||||||
@@ -495,13 +490,6 @@ static int elsa_cs_event(event_t event, int priority,
|
|||||||
DEBUG(1, "elsa_cs_event(%d)\n", event);
|
DEBUG(1, "elsa_cs_event(%d)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
((local_info_t*)link->priv)->busy = 1;
|
|
||||||
elsa_cs_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
elsa_cs_config(link);
|
elsa_cs_config(link);
|
||||||
@@ -524,7 +512,7 @@ static struct pcmcia_driver elsa_cs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = elsa_cs_attach,
|
.attach = elsa_cs_attach,
|
||||||
.event = elsa_cs_event,
|
.event = elsa_cs_event,
|
||||||
.detach = elsa_cs_detach,
|
.remove = elsa_cs_detach,
|
||||||
.id_table = elsa_ids,
|
.id_table = elsa_ids,
|
||||||
.suspend = elsa_suspend,
|
.suspend = elsa_suspend,
|
||||||
.resume = elsa_resume,
|
.resume = elsa_resume,
|
||||||
|
|||||||
@@ -107,7 +107,7 @@ static int sedlbauer_event(event_t event, int priority,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static dev_link_t *sedlbauer_attach(void);
|
static dev_link_t *sedlbauer_attach(void);
|
||||||
static void sedlbauer_detach(dev_link_t *);
|
static void sedlbauer_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
You'll also need to prototype all the functions that will actually
|
You'll also need to prototype all the functions that will actually
|
||||||
@@ -230,7 +230,7 @@ static dev_link_t *sedlbauer_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
sedlbauer_detach(link);
|
sedlbauer_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -246,8 +246,9 @@ static dev_link_t *sedlbauer_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void sedlbauer_detach(dev_link_t *link)
|
static void sedlbauer_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
DEBUG(0, "sedlbauer_detach(0x%p)\n", link);
|
DEBUG(0, "sedlbauer_detach(0x%p)\n", link);
|
||||||
@@ -258,25 +259,11 @@ static void sedlbauer_detach(dev_link_t *link)
|
|||||||
if (*linkp == NULL)
|
if (*linkp == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/*
|
|
||||||
If the device is currently configured and active, we won't
|
|
||||||
actually delete it yet. Instead, it is marked so that when
|
|
||||||
the release() function is called, that will trigger a proper
|
|
||||||
detach().
|
|
||||||
*/
|
|
||||||
if (link->state & DEV_CONFIG) {
|
if (link->state & DEV_CONFIG) {
|
||||||
#ifdef PCMCIA_DEBUG
|
((local_info_t *)link->priv)->stop = 1;
|
||||||
printk(KERN_DEBUG "sedlbauer_cs: detach postponed, '%s' "
|
sedlbauer_release(link);
|
||||||
"still locked\n", link->dev->dev_name);
|
|
||||||
#endif
|
|
||||||
link->state |= DEV_STALE_LINK;
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Break the link with Card Services */
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, and free it */
|
/* Unlink device structure, and free it */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
/* This points to the parent local_info_t struct */
|
/* This points to the parent local_info_t struct */
|
||||||
@@ -547,10 +534,6 @@ static void sedlbauer_release(dev_link_t *link)
|
|||||||
if (link->irq.AssignedIRQ)
|
if (link->irq.AssignedIRQ)
|
||||||
pcmcia_release_irq(link->handle, &link->irq);
|
pcmcia_release_irq(link->handle, &link->irq);
|
||||||
link->state &= ~DEV_CONFIG;
|
link->state &= ~DEV_CONFIG;
|
||||||
|
|
||||||
if (link->state & DEV_STALE_LINK)
|
|
||||||
sedlbauer_detach(link);
|
|
||||||
|
|
||||||
} /* sedlbauer_release */
|
} /* sedlbauer_release */
|
||||||
|
|
||||||
static int sedlbauer_suspend(struct pcmcia_device *p_dev)
|
static int sedlbauer_suspend(struct pcmcia_device *p_dev)
|
||||||
@@ -599,13 +582,6 @@ static int sedlbauer_event(event_t event, int priority,
|
|||||||
DEBUG(1, "sedlbauer_event(0x%06x)\n", event);
|
DEBUG(1, "sedlbauer_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
((local_info_t *)link->priv)->stop = 1;
|
|
||||||
sedlbauer_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
sedlbauer_config(link);
|
sedlbauer_config(link);
|
||||||
@@ -633,7 +609,7 @@ static struct pcmcia_driver sedlbauer_driver = {
|
|||||||
},
|
},
|
||||||
.attach = sedlbauer_attach,
|
.attach = sedlbauer_attach,
|
||||||
.event = sedlbauer_event,
|
.event = sedlbauer_event,
|
||||||
.detach = sedlbauer_detach,
|
.remove = sedlbauer_detach,
|
||||||
.id_table = sedlbauer_ids,
|
.id_table = sedlbauer_ids,
|
||||||
.suspend = sedlbauer_suspend,
|
.suspend = sedlbauer_suspend,
|
||||||
.resume = sedlbauer_resume,
|
.resume = sedlbauer_resume,
|
||||||
|
|||||||
@@ -87,7 +87,7 @@ static int teles_cs_event(event_t event, int priority,
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static dev_link_t *teles_attach(void);
|
static dev_link_t *teles_attach(void);
|
||||||
static void teles_detach(dev_link_t *);
|
static void teles_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
The dev_info variable is the "key" that is used to match up this
|
The dev_info variable is the "key" that is used to match up this
|
||||||
@@ -197,7 +197,7 @@ static dev_link_t *teles_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
teles_detach(link);
|
teles_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -213,11 +213,11 @@ static dev_link_t *teles_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void teles_detach(dev_link_t *link)
|
static void teles_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
local_info_t *info = link->priv;
|
local_info_t *info = link->priv;
|
||||||
int ret;
|
|
||||||
|
|
||||||
DEBUG(0, "teles_detach(0x%p)\n", link);
|
DEBUG(0, "teles_detach(0x%p)\n", link);
|
||||||
|
|
||||||
@@ -227,14 +227,9 @@ static void teles_detach(dev_link_t *link)
|
|||||||
if (*linkp == NULL)
|
if (*linkp == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG) {
|
||||||
|
info->busy = 1;
|
||||||
teles_cs_release(link);
|
teles_cs_release(link);
|
||||||
|
|
||||||
/* Break the link with Card Services */
|
|
||||||
if (link->handle) {
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Unlink device structure and free it */
|
/* Unlink device structure and free it */
|
||||||
@@ -476,13 +471,6 @@ static int teles_cs_event(event_t event, int priority,
|
|||||||
DEBUG(1, "teles_cs_event(%d)\n", event);
|
DEBUG(1, "teles_cs_event(%d)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
((local_info_t*)link->priv)->busy = 1;
|
|
||||||
teles_cs_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
teles_cs_config(link);
|
teles_cs_config(link);
|
||||||
@@ -504,7 +492,7 @@ static struct pcmcia_driver teles_cs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = teles_attach,
|
.attach = teles_attach,
|
||||||
.event = teles_cs_event,
|
.event = teles_cs_event,
|
||||||
.detach = teles_detach,
|
.remove = teles_detach,
|
||||||
.id_table = teles_ids,
|
.id_table = teles_ids,
|
||||||
.suspend = teles_suspend,
|
.suspend = teles_suspend,
|
||||||
.resume = teles_resume,
|
.resume = teles_resume,
|
||||||
|
|||||||
@@ -722,18 +722,6 @@ static int pcmciamtd_event(event_t event, int priority,
|
|||||||
|
|
||||||
DEBUG(1, "event=0x%06x", event);
|
DEBUG(1, "event=0x%06x", event);
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
DEBUG(2, "EVENT_CARD_REMOVAL");
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG) {
|
|
||||||
struct pcmciamtd_dev *dev = link->priv;
|
|
||||||
if(dev->mtd_info) {
|
|
||||||
del_mtd_device(dev->mtd_info);
|
|
||||||
info("mtd%d: Removed", dev->mtd_info->index);
|
|
||||||
}
|
|
||||||
pcmciamtd_release(link);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
DEBUG(2, "EVENT_CARD_INSERTION");
|
DEBUG(2, "EVENT_CARD_INSERTION");
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
@@ -752,23 +740,21 @@ static int pcmciamtd_event(event_t event, int priority,
|
|||||||
* when the device is released.
|
* when the device is released.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void pcmciamtd_detach(dev_link_t *link)
|
static void pcmciamtd_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
|
|
||||||
DEBUG(3, "link=0x%p", link);
|
DEBUG(3, "link=0x%p", link);
|
||||||
|
|
||||||
if(link->state & DEV_CONFIG) {
|
if(link->state & DEV_CONFIG) {
|
||||||
|
struct pcmciamtd_dev *dev = link->priv;
|
||||||
|
if(dev->mtd_info) {
|
||||||
|
del_mtd_device(dev->mtd_info);
|
||||||
|
info("mtd%d: Removed", dev->mtd_info->index);
|
||||||
|
}
|
||||||
|
|
||||||
pcmciamtd_release(link);
|
pcmciamtd_release(link);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (link->handle) {
|
|
||||||
int ret;
|
|
||||||
DEBUG(2, "Deregistering with card services");
|
|
||||||
ret = pcmcia_deregister_client(link->handle);
|
|
||||||
if (ret != CS_SUCCESS)
|
|
||||||
cs_error(link->handle, DeregisterClient, ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
link->state |= DEV_STALE_LINK;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -807,7 +793,7 @@ static dev_link_t *pcmciamtd_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
pcmciamtd_detach(link);
|
pcmciamtd_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
DEBUG(2, "link = %p", link);
|
DEBUG(2, "link = %p", link);
|
||||||
@@ -847,7 +833,7 @@ static struct pcmcia_driver pcmciamtd_driver = {
|
|||||||
},
|
},
|
||||||
.attach = pcmciamtd_attach,
|
.attach = pcmciamtd_attach,
|
||||||
.event = pcmciamtd_event,
|
.event = pcmciamtd_event,
|
||||||
.detach = pcmciamtd_detach,
|
.remove = pcmciamtd_detach,
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.id_table = pcmciamtd_ids,
|
.id_table = pcmciamtd_ids,
|
||||||
.suspend = pcmciamtd_suspend,
|
.suspend = pcmciamtd_suspend,
|
||||||
|
|||||||
@@ -253,7 +253,7 @@ static void set_rx_mode(struct net_device *dev);
|
|||||||
static dev_info_t dev_info = "3c574_cs";
|
static dev_info_t dev_info = "3c574_cs";
|
||||||
|
|
||||||
static dev_link_t *tc574_attach(void);
|
static dev_link_t *tc574_attach(void);
|
||||||
static void tc574_detach(dev_link_t *);
|
static void tc574_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list;
|
static dev_link_t *dev_list;
|
||||||
|
|
||||||
@@ -316,7 +316,7 @@ static dev_link_t *tc574_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
tc574_detach(link);
|
tc574_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -332,8 +332,9 @@ static dev_link_t *tc574_attach(void)
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void tc574_detach(dev_link_t *link)
|
static void tc574_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
struct net_device *dev = link->priv;
|
struct net_device *dev = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
@@ -351,9 +352,6 @@ static void tc574_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
tc574_release(link);
|
tc574_release(link);
|
||||||
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
free_netdev(dev);
|
free_netdev(dev);
|
||||||
@@ -590,16 +588,10 @@ static int tc574_event(event_t event, int priority,
|
|||||||
event_callback_args_t *args)
|
event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
struct net_device *dev = link->priv;
|
|
||||||
|
|
||||||
DEBUG(1, "3c574_event(0x%06x)\n", event);
|
DEBUG(1, "3c574_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
netif_device_detach(dev);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
tc574_config(link);
|
tc574_config(link);
|
||||||
@@ -1304,7 +1296,7 @@ static struct pcmcia_driver tc574_driver = {
|
|||||||
},
|
},
|
||||||
.attach = tc574_attach,
|
.attach = tc574_attach,
|
||||||
.event = tc574_event,
|
.event = tc574_event,
|
||||||
.detach = tc574_detach,
|
.remove = tc574_detach,
|
||||||
.id_table = tc574_ids,
|
.id_table = tc574_ids,
|
||||||
.suspend = tc574_suspend,
|
.suspend = tc574_suspend,
|
||||||
.resume = tc574_resume,
|
.resume = tc574_resume,
|
||||||
|
|||||||
@@ -164,7 +164,7 @@ static struct ethtool_ops netdev_ethtool_ops;
|
|||||||
static dev_info_t dev_info = "3c589_cs";
|
static dev_info_t dev_info = "3c589_cs";
|
||||||
|
|
||||||
static dev_link_t *tc589_attach(void);
|
static dev_link_t *tc589_attach(void);
|
||||||
static void tc589_detach(dev_link_t *);
|
static void tc589_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list;
|
static dev_link_t *dev_list;
|
||||||
|
|
||||||
@@ -230,7 +230,7 @@ static dev_link_t *tc589_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
tc589_detach(link);
|
tc589_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -246,8 +246,9 @@ static dev_link_t *tc589_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void tc589_detach(dev_link_t *link)
|
static void tc589_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
struct net_device *dev = link->priv;
|
struct net_device *dev = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
@@ -264,10 +265,7 @@ static void tc589_detach(dev_link_t *link)
|
|||||||
|
|
||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
tc589_release(link);
|
tc589_release(link);
|
||||||
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
free_netdev(dev);
|
free_netdev(dev);
|
||||||
@@ -466,16 +464,10 @@ static int tc589_event(event_t event, int priority,
|
|||||||
event_callback_args_t *args)
|
event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
struct net_device *dev = link->priv;
|
|
||||||
|
|
||||||
DEBUG(1, "3c589_event(0x%06x)\n", event);
|
DEBUG(1, "3c589_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
netif_device_detach(dev);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
tc589_config(link);
|
tc589_config(link);
|
||||||
@@ -1079,7 +1071,7 @@ static struct pcmcia_driver tc589_driver = {
|
|||||||
},
|
},
|
||||||
.attach = tc589_attach,
|
.attach = tc589_attach,
|
||||||
.event = tc589_event,
|
.event = tc589_event,
|
||||||
.detach = tc589_detach,
|
.remove = tc589_detach,
|
||||||
.id_table = tc589_ids,
|
.id_table = tc589_ids,
|
||||||
.suspend = tc589_suspend,
|
.suspend = tc589_suspend,
|
||||||
.resume = tc589_resume,
|
.resume = tc589_resume,
|
||||||
|
|||||||
@@ -108,7 +108,7 @@ static void block_output(struct net_device *dev, int count,
|
|||||||
const u_char *buf, const int start_page);
|
const u_char *buf, const int start_page);
|
||||||
|
|
||||||
static dev_link_t *axnet_attach(void);
|
static dev_link_t *axnet_attach(void);
|
||||||
static void axnet_detach(dev_link_t *);
|
static void axnet_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_info_t dev_info = "axnet_cs";
|
static dev_info_t dev_info = "axnet_cs";
|
||||||
static dev_link_t *dev_list;
|
static dev_link_t *dev_list;
|
||||||
@@ -185,7 +185,7 @@ static dev_link_t *axnet_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != CS_SUCCESS) {
|
if (ret != CS_SUCCESS) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
axnet_detach(link);
|
axnet_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -201,8 +201,9 @@ static dev_link_t *axnet_attach(void)
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void axnet_detach(dev_link_t *link)
|
static void axnet_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
struct net_device *dev = link->priv;
|
struct net_device *dev = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
@@ -220,9 +221,6 @@ static void axnet_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
axnet_release(link);
|
axnet_release(link);
|
||||||
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
free_netdev(dev);
|
free_netdev(dev);
|
||||||
@@ -537,16 +535,10 @@ static int axnet_event(event_t event, int priority,
|
|||||||
event_callback_args_t *args)
|
event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
struct net_device *dev = link->priv;
|
|
||||||
|
|
||||||
DEBUG(2, "axnet_event(0x%06x)\n", event);
|
DEBUG(2, "axnet_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
netif_device_detach(dev);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
axnet_config(link);
|
axnet_config(link);
|
||||||
@@ -890,7 +882,7 @@ static struct pcmcia_driver axnet_cs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = axnet_attach,
|
.attach = axnet_attach,
|
||||||
.event = axnet_event,
|
.event = axnet_event,
|
||||||
.detach = axnet_detach,
|
.remove = axnet_detach,
|
||||||
.id_table = axnet_ids,
|
.id_table = axnet_ids,
|
||||||
.suspend = axnet_suspend,
|
.suspend = axnet_suspend,
|
||||||
.resume = axnet_resume,
|
.resume = axnet_resume,
|
||||||
|
|||||||
@@ -126,7 +126,7 @@ static int com20020_event(event_t event, int priority,
|
|||||||
static dev_info_t dev_info = "com20020_cs";
|
static dev_info_t dev_info = "com20020_cs";
|
||||||
|
|
||||||
static dev_link_t *com20020_attach(void);
|
static dev_link_t *com20020_attach(void);
|
||||||
static void com20020_detach(dev_link_t *);
|
static void com20020_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
static dev_link_t *dev_list;
|
static dev_link_t *dev_list;
|
||||||
|
|
||||||
@@ -204,7 +204,7 @@ static dev_link_t *com20020_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
com20020_detach(link);
|
com20020_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -226,8 +226,9 @@ fail_alloc_info:
|
|||||||
|
|
||||||
======================================================================*/
|
======================================================================*/
|
||||||
|
|
||||||
static void com20020_detach(dev_link_t *link)
|
static void com20020_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
struct com20020_dev_t *info = link->priv;
|
struct com20020_dev_t *info = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
@@ -260,9 +261,6 @@ static void com20020_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
com20020_release(link);
|
com20020_release(link);
|
||||||
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, free bits */
|
/* Unlink device structure, free bits */
|
||||||
DEBUG(1,"unlinking...\n");
|
DEBUG(1,"unlinking...\n");
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
@@ -470,17 +468,10 @@ static int com20020_event(event_t event, int priority,
|
|||||||
event_callback_args_t *args)
|
event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
com20020_dev_t *info = link->priv;
|
|
||||||
struct net_device *dev = info->dev;
|
|
||||||
|
|
||||||
DEBUG(1, "com20020_event(0x%06x)\n", event);
|
DEBUG(1, "com20020_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
netif_device_detach(dev);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT;
|
link->state |= DEV_PRESENT;
|
||||||
com20020_config(link);
|
com20020_config(link);
|
||||||
@@ -502,7 +493,7 @@ static struct pcmcia_driver com20020_cs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = com20020_attach,
|
.attach = com20020_attach,
|
||||||
.event = com20020_event,
|
.event = com20020_event,
|
||||||
.detach = com20020_detach,
|
.remove = com20020_detach,
|
||||||
.id_table = com20020_ids,
|
.id_table = com20020_ids,
|
||||||
.suspend = com20020_suspend,
|
.suspend = com20020_suspend,
|
||||||
.resume = com20020_resume,
|
.resume = com20020_resume,
|
||||||
|
|||||||
@@ -91,7 +91,7 @@ static void fmvj18x_release(dev_link_t *link);
|
|||||||
static int fmvj18x_event(event_t event, int priority,
|
static int fmvj18x_event(event_t event, int priority,
|
||||||
event_callback_args_t *args);
|
event_callback_args_t *args);
|
||||||
static dev_link_t *fmvj18x_attach(void);
|
static dev_link_t *fmvj18x_attach(void);
|
||||||
static void fmvj18x_detach(dev_link_t *);
|
static void fmvj18x_detach(struct pcmcia_device *p_dev);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
LAN controller(MBH86960A) specific routines
|
LAN controller(MBH86960A) specific routines
|
||||||
@@ -291,7 +291,7 @@ static dev_link_t *fmvj18x_attach(void)
|
|||||||
ret = pcmcia_register_client(&link->handle, &client_reg);
|
ret = pcmcia_register_client(&link->handle, &client_reg);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
cs_error(link->handle, RegisterClient, ret);
|
cs_error(link->handle, RegisterClient, ret);
|
||||||
fmvj18x_detach(link);
|
fmvj18x_detach(link->handle);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -300,8 +300,9 @@ static dev_link_t *fmvj18x_attach(void)
|
|||||||
|
|
||||||
/*====================================================================*/
|
/*====================================================================*/
|
||||||
|
|
||||||
static void fmvj18x_detach(dev_link_t *link)
|
static void fmvj18x_detach(struct pcmcia_device *p_dev)
|
||||||
{
|
{
|
||||||
|
dev_link_t *link = dev_to_instance(p_dev);
|
||||||
struct net_device *dev = link->priv;
|
struct net_device *dev = link->priv;
|
||||||
dev_link_t **linkp;
|
dev_link_t **linkp;
|
||||||
|
|
||||||
@@ -319,10 +320,6 @@ static void fmvj18x_detach(dev_link_t *link)
|
|||||||
if (link->state & DEV_CONFIG)
|
if (link->state & DEV_CONFIG)
|
||||||
fmvj18x_release(link);
|
fmvj18x_release(link);
|
||||||
|
|
||||||
/* Break the link with Card Services */
|
|
||||||
if (link->handle)
|
|
||||||
pcmcia_deregister_client(link->handle);
|
|
||||||
|
|
||||||
/* Unlink device structure, free pieces */
|
/* Unlink device structure, free pieces */
|
||||||
*linkp = link->next;
|
*linkp = link->next;
|
||||||
free_netdev(dev);
|
free_netdev(dev);
|
||||||
@@ -752,16 +749,10 @@ static int fmvj18x_event(event_t event, int priority,
|
|||||||
event_callback_args_t *args)
|
event_callback_args_t *args)
|
||||||
{
|
{
|
||||||
dev_link_t *link = args->client_data;
|
dev_link_t *link = args->client_data;
|
||||||
struct net_device *dev = link->priv;
|
|
||||||
|
|
||||||
DEBUG(1, "fmvj18x_event(0x%06x)\n", event);
|
DEBUG(1, "fmvj18x_event(0x%06x)\n", event);
|
||||||
|
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case CS_EVENT_CARD_REMOVAL:
|
|
||||||
link->state &= ~DEV_PRESENT;
|
|
||||||
if (link->state & DEV_CONFIG)
|
|
||||||
netif_device_detach(dev);
|
|
||||||
break;
|
|
||||||
case CS_EVENT_CARD_INSERTION:
|
case CS_EVENT_CARD_INSERTION:
|
||||||
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
link->state |= DEV_PRESENT | DEV_CONFIG_PENDING;
|
||||||
fmvj18x_config(link);
|
fmvj18x_config(link);
|
||||||
@@ -802,7 +793,7 @@ static struct pcmcia_driver fmvj18x_cs_driver = {
|
|||||||
},
|
},
|
||||||
.attach = fmvj18x_attach,
|
.attach = fmvj18x_attach,
|
||||||
.event = fmvj18x_event,
|
.event = fmvj18x_event,
|
||||||
.detach = fmvj18x_detach,
|
.remove = fmvj18x_detach,
|
||||||
.id_table = fmvj18x_ids,
|
.id_table = fmvj18x_ids,
|
||||||
.suspend = fmvj18x_suspend,
|
.suspend = fmvj18x_suspend,
|
||||||
.resume = fmvj18x_resume,
|
.resume = fmvj18x_resume,
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user