pcmcia: avoid pccard_validate_cis failure in resume callpath
authorDominik Brodowski <linux@dominikbrodowski.net>
Thu, 29 Apr 2010 13:56:25 +0000 (15:56 +0200)
committerDominik Brodowski <linux@dominikbrodowski.net>
Mon, 3 May 2010 12:34:44 +0000 (14:34 +0200)
If the PCMCIA CIS changed before a resume event (e.g. due to
a card exchange while being suspended, possibly also during
a call to "pccardctl reset"), also set the function count to
zero so that the subsequent call to pccard_validate_cis() does
not fail.

Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
drivers/pcmcia/ds.c

index 508f94a2a78db429962d5d05604adeda7796b193..041eee43fd8d67b03a690abe0341039949e43cfc 100644 (file)
@@ -1283,6 +1283,7 @@ static int ds_event(struct pcmcia_socket *skt, event_t event, int priority)
                        destroy_cis_cache(skt);
                        kfree(skt->fake_cis);
                        skt->fake_cis = NULL;
+                       s->functions = 0;
                        mutex_unlock(&s->ops_mutex);
                        /* now, add the new card */
                        ds_event(skt, CS_EVENT_CARD_INSERTION,