diff options
author | Dominik Brodowski <linux@dominikbrodowski.net> | 2009-10-18 12:22:32 -0400 |
---|---|---|
committer | Dominik Brodowski <linux@dominikbrodowski.net> | 2009-11-08 12:06:32 -0500 |
commit | 7d2e8d00b47b973c92db4df7444d5e6d3bb945f9 (patch) | |
tree | 22286fa095d0340245e83ca9c7695f42f65c141a /drivers/net/pcmcia/xirc2ps_cs.c | |
parent | 6ae3b84d979308671bf6f6a2123c258a8603d61c (diff) |
pcmcia: use pre-determined values
A few PCMCIA network drivers can make use of values provided by the pcmcia
core, instead of tedious, independent CIS parsing.
xirc32ps_cs.c: manf_id
hostap_cs.c: multifunction count
b43/pcmcia.c: ConfigBase address and "Present"
smc91c92_cs.c: By default, mhz_setup() can use VERS_1 as it is stored
in struct pcmcia_device. Only some cards require workarounds, such as
reading out VERS_1 twice.
CC: David S. Miller <davem@davemloft.net>
CC: netdev@vger.kernel.org
CC: linux-wireless@vger.kernel.org
Acked-by: John W. Linville <linville@tuxdriver.com>
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'drivers/net/pcmcia/xirc2ps_cs.c')
-rw-r--r-- | drivers/net/pcmcia/xirc2ps_cs.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/drivers/net/pcmcia/xirc2ps_cs.c b/drivers/net/pcmcia/xirc2ps_cs.c index cf8423102538..5e203230144f 100644 --- a/drivers/net/pcmcia/xirc2ps_cs.c +++ b/drivers/net/pcmcia/xirc2ps_cs.c | |||
@@ -792,13 +792,12 @@ xirc2ps_config(struct pcmcia_device * link) | |||
792 | tuple.TupleOffset = 0; | 792 | tuple.TupleOffset = 0; |
793 | 793 | ||
794 | /* Is this a valid card */ | 794 | /* Is this a valid card */ |
795 | tuple.DesiredTuple = CISTPL_MANFID; | 795 | if (link->has_manf_id == 0) { |
796 | if ((err=first_tuple(link, &tuple, &parse))) { | ||
797 | printk(KNOT_XIRC "manfid not found in CIS\n"); | 796 | printk(KNOT_XIRC "manfid not found in CIS\n"); |
798 | goto failure; | 797 | goto failure; |
799 | } | 798 | } |
800 | 799 | ||
801 | switch(parse.manfid.manf) { | 800 | switch (link->manf_id) { |
802 | case MANFID_XIRCOM: | 801 | case MANFID_XIRCOM: |
803 | local->manf_str = "Xircom"; | 802 | local->manf_str = "Xircom"; |
804 | break; | 803 | break; |
@@ -822,6 +821,13 @@ xirc2ps_config(struct pcmcia_device * link) | |||
822 | } | 821 | } |
823 | DEBUG(0, "found %s card\n", local->manf_str); | 822 | DEBUG(0, "found %s card\n", local->manf_str); |
824 | 823 | ||
824 | /* needed for the additional fields to be parsed by set_card_type() */ | ||
825 | tuple.DesiredTuple = CISTPL_MANFID; | ||
826 | err = first_tuple(link, &tuple, &parse) | ||
827 | if (err) { | ||
828 | printk(KNOT_XIRC "manfid not found in CIS\n"); | ||
829 | goto failure; | ||
830 | } | ||
825 | if (!set_card_type(link, buf)) { | 831 | if (!set_card_type(link, buf)) { |
826 | printk(KNOT_XIRC "this card is not supported\n"); | 832 | printk(KNOT_XIRC "this card is not supported\n"); |
827 | goto failure; | 833 | goto failure; |