aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pcmcia/ds.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/pcmcia/ds.c')
-rw-r--r--drivers/pcmcia/ds.c38
1 files changed, 27 insertions, 11 deletions
diff --git a/drivers/pcmcia/ds.c b/drivers/pcmcia/ds.c
index 4c40db8889d9..83b51ddd3da3 100644
--- a/drivers/pcmcia/ds.c
+++ b/drivers/pcmcia/ds.c
@@ -835,6 +835,8 @@ static inline int pcmcia_devmatch(struct pcmcia_device *dev,
835 } 835 }
836 836
837 if (did->match_flags & PCMCIA_DEV_ID_MATCH_FUNC_ID) { 837 if (did->match_flags & PCMCIA_DEV_ID_MATCH_FUNC_ID) {
838 int ret;
839
838 if ((!dev->has_func_id) || (dev->func_id != did->func_id)) 840 if ((!dev->has_func_id) || (dev->func_id != did->func_id))
839 return 0; 841 return 0;
840 842
@@ -849,10 +851,15 @@ static inline int pcmcia_devmatch(struct pcmcia_device *dev,
849 * after it has re-checked that there is no possible module 851 * after it has re-checked that there is no possible module
850 * with a prod_id/manf_id/card_id match. 852 * with a prod_id/manf_id/card_id match.
851 */ 853 */
852 dev_dbg(&dev->dev, 854 mutex_lock(&dev->socket->ops_mutex);
853 "skipping FUNC_ID match until userspace interaction\n"); 855 ret = dev->allow_func_id_match;
854 if (!dev->allow_func_id_match) 856 mutex_unlock(&dev->socket->ops_mutex);
857
858 if (!ret) {
859 dev_dbg(&dev->dev,
860 "skipping FUNC_ID match until userspace ACK\n");
855 return 0; 861 return 0;
862 }
856 } 863 }
857 864
858 if (did->match_flags & PCMCIA_DEV_ID_MATCH_FAKE_CIS) { 865 if (did->match_flags & PCMCIA_DEV_ID_MATCH_FAKE_CIS) {
@@ -1079,9 +1086,9 @@ static ssize_t pcmcia_store_allow_func_id_match(struct device *dev,
1079 if (!count) 1086 if (!count)
1080 return -EINVAL; 1087 return -EINVAL;
1081 1088
1082 mutex_lock(&p_dev->socket->skt_mutex); 1089 mutex_lock(&p_dev->socket->ops_mutex);
1083 p_dev->allow_func_id_match = 1; 1090 p_dev->allow_func_id_match = 1;
1084 mutex_unlock(&p_dev->socket->skt_mutex); 1091 mutex_unlock(&p_dev->socket->ops_mutex);
1085 1092
1086 ret = bus_rescan_devices(&pcmcia_bus_type); 1093 ret = bus_rescan_devices(&pcmcia_bus_type);
1087 if (ret) 1094 if (ret)
@@ -1114,8 +1121,13 @@ static int pcmcia_dev_suspend(struct device *dev, pm_message_t state)
1114 struct pcmcia_driver *p_drv = NULL; 1121 struct pcmcia_driver *p_drv = NULL;
1115 int ret = 0; 1122 int ret = 0;
1116 1123
1117 if (p_dev->suspended) 1124 mutex_lock(&p_dev->socket->ops_mutex);
1125 if (p_dev->suspended) {
1126 mutex_unlock(&p_dev->socket->ops_mutex);
1118 return 0; 1127 return 0;
1128 }
1129 p_dev->suspended = 1;
1130 mutex_unlock(&p_dev->socket->ops_mutex);
1119 1131
1120 dev_dbg(dev, "suspending\n"); 1132 dev_dbg(dev, "suspending\n");
1121 1133
@@ -1132,6 +1144,9 @@ static int pcmcia_dev_suspend(struct device *dev, pm_message_t state)
1132 "pcmcia: device %s (driver %s) did " 1144 "pcmcia: device %s (driver %s) did "
1133 "not want to go to sleep (%d)\n", 1145 "not want to go to sleep (%d)\n",
1134 p_dev->devname, p_drv->drv.name, ret); 1146 p_dev->devname, p_drv->drv.name, ret);
1147 mutex_lock(&p_dev->socket->ops_mutex);
1148 p_dev->suspended = 0;
1149 mutex_unlock(&p_dev->socket->ops_mutex);
1135 goto out; 1150 goto out;
1136 } 1151 }
1137 } 1152 }
@@ -1142,8 +1157,6 @@ static int pcmcia_dev_suspend(struct device *dev, pm_message_t state)
1142 } 1157 }
1143 1158
1144 out: 1159 out:
1145 if (!ret)
1146 p_dev->suspended = 1;
1147 return ret; 1160 return ret;
1148} 1161}
1149 1162
@@ -1154,8 +1167,13 @@ static int pcmcia_dev_resume(struct device *dev)
1154 struct pcmcia_driver *p_drv = NULL; 1167 struct pcmcia_driver *p_drv = NULL;
1155 int ret = 0; 1168 int ret = 0;
1156 1169
1157 if (!p_dev->suspended) 1170 mutex_lock(&p_dev->socket->ops_mutex);
1171 if (!p_dev->suspended) {
1172 mutex_unlock(&p_dev->socket->ops_mutex);
1158 return 0; 1173 return 0;
1174 }
1175 p_dev->suspended = 0;
1176 mutex_unlock(&p_dev->socket->ops_mutex);
1159 1177
1160 dev_dbg(dev, "resuming\n"); 1178 dev_dbg(dev, "resuming\n");
1161 1179
@@ -1176,8 +1194,6 @@ static int pcmcia_dev_resume(struct device *dev)
1176 ret = p_drv->resume(p_dev); 1194 ret = p_drv->resume(p_dev);
1177 1195
1178 out: 1196 out:
1179 if (!ret)
1180 p_dev->suspended = 0;
1181 return ret; 1197 return ret;
1182} 1198}
1183 1199