提交 7d2e8d00 编写于 作者: D Dominik Brodowski

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: NJohn W. Linville <linville@tuxdriver.com>
Signed-off-by: NDominik Brodowski <linux@dominikbrodowski.net>
上级 6ae3b84d
...@@ -545,6 +545,14 @@ static int mhz_setup(struct pcmcia_device *link) ...@@ -545,6 +545,14 @@ static int mhz_setup(struct pcmcia_device *link)
u_char *buf, *station_addr; u_char *buf, *station_addr;
int rc; int rc;
/* Read the station address from the CIS. It is stored as the last
(fourth) string in the Version 1 Version/ID tuple. */
if ((link->prod_id[3]) &&
(cvt_ascii_address(dev, link->prod_id[3]) == 0))
return 0;
/* Workarounds for broken cards start here. */
cfg_mem = kmalloc(sizeof(struct smc_cfg_mem), GFP_KERNEL); cfg_mem = kmalloc(sizeof(struct smc_cfg_mem), GFP_KERNEL);
if (!cfg_mem) if (!cfg_mem)
return -1; return -1;
...@@ -557,8 +565,7 @@ static int mhz_setup(struct pcmcia_device *link) ...@@ -557,8 +565,7 @@ static int mhz_setup(struct pcmcia_device *link)
tuple->TupleData = (cisdata_t *)buf; tuple->TupleData = (cisdata_t *)buf;
tuple->TupleDataMax = 255; tuple->TupleDataMax = 255;
/* Read the station address from the CIS. It is stored as the last /* Ugh -- the EM1144 card has two VERS_1 tuples!?! */
(fourth) string in the Version 1 Version/ID tuple. */
tuple->DesiredTuple = CISTPL_VERS_1; tuple->DesiredTuple = CISTPL_VERS_1;
if (first_tuple(link, tuple, parse) != 0) { if (first_tuple(link, tuple, parse) != 0) {
rc = -1; rc = -1;
......
...@@ -792,13 +792,12 @@ xirc2ps_config(struct pcmcia_device * link) ...@@ -792,13 +792,12 @@ xirc2ps_config(struct pcmcia_device * link)
tuple.TupleOffset = 0; tuple.TupleOffset = 0;
/* Is this a valid card */ /* Is this a valid card */
tuple.DesiredTuple = CISTPL_MANFID; if (link->has_manf_id == 0) {
if ((err=first_tuple(link, &tuple, &parse))) {
printk(KNOT_XIRC "manfid not found in CIS\n"); printk(KNOT_XIRC "manfid not found in CIS\n");
goto failure; goto failure;
} }
switch(parse.manfid.manf) { switch (link->manf_id) {
case MANFID_XIRCOM: case MANFID_XIRCOM:
local->manf_str = "Xircom"; local->manf_str = "Xircom";
break; break;
...@@ -822,6 +821,13 @@ xirc2ps_config(struct pcmcia_device * link) ...@@ -822,6 +821,13 @@ xirc2ps_config(struct pcmcia_device * link)
} }
DEBUG(0, "found %s card\n", local->manf_str); DEBUG(0, "found %s card\n", local->manf_str);
/* needed for the additional fields to be parsed by set_card_type() */
tuple.DesiredTuple = CISTPL_MANFID;
err = first_tuple(link, &tuple, &parse)
if (err) {
printk(KNOT_XIRC "manfid not found in CIS\n");
goto failure;
}
if (!set_card_type(link, buf)) { if (!set_card_type(link, buf)) {
printk(KNOT_XIRC "this card is not supported\n"); printk(KNOT_XIRC "this card is not supported\n");
goto failure; goto failure;
......
...@@ -65,35 +65,15 @@ static int __devinit b43_pcmcia_probe(struct pcmcia_device *dev) ...@@ -65,35 +65,15 @@ static int __devinit b43_pcmcia_probe(struct pcmcia_device *dev)
struct ssb_bus *ssb; struct ssb_bus *ssb;
win_req_t win; win_req_t win;
memreq_t mem; memreq_t mem;
tuple_t tuple;
cisparse_t parse;
int err = -ENOMEM; int err = -ENOMEM;
int res = 0; int res = 0;
unsigned char buf[64];
ssb = kzalloc(sizeof(*ssb), GFP_KERNEL); ssb = kzalloc(sizeof(*ssb), GFP_KERNEL);
if (!ssb) if (!ssb)
goto out_error; goto out_error;
err = -ENODEV; err = -ENODEV;
tuple.DesiredTuple = CISTPL_CONFIG;
tuple.Attributes = 0;
tuple.TupleData = buf;
tuple.TupleDataMax = sizeof(buf);
tuple.TupleOffset = 0;
res = pcmcia_get_first_tuple(dev, &tuple);
if (res != 0)
goto err_kfree_ssb;
res = pcmcia_get_tuple_data(dev, &tuple);
if (res != 0)
goto err_kfree_ssb;
res = pcmcia_parse_tuple(&tuple, &parse);
if (res != 0)
goto err_kfree_ssb;
dev->conf.ConfigBase = parse.config.base;
dev->conf.Present = parse.config.rmask[0];
dev->conf.Attributes = CONF_ENABLE_IRQ; dev->conf.Attributes = CONF_ENABLE_IRQ;
dev->conf.IntType = INT_MEMORY_AND_IO; dev->conf.IntType = INT_MEMORY_AND_IO;
......
...@@ -274,9 +274,6 @@ static int sandisk_enable_wireless(struct net_device *dev) ...@@ -274,9 +274,6 @@ static int sandisk_enable_wireless(struct net_device *dev)
conf_reg_t reg; conf_reg_t reg;
struct hostap_interface *iface = netdev_priv(dev); struct hostap_interface *iface = netdev_priv(dev);
local_info_t *local = iface->local; local_info_t *local = iface->local;
tuple_t tuple;
cisparse_t *parse = NULL;
u_char buf[64];
struct hostap_cs_priv *hw_priv = local->hw_priv; struct hostap_cs_priv *hw_priv = local->hw_priv;
if (hw_priv->link->io.NumPorts1 < 0x42) { if (hw_priv->link->io.NumPorts1 < 0x42) {
...@@ -285,28 +282,13 @@ static int sandisk_enable_wireless(struct net_device *dev) ...@@ -285,28 +282,13 @@ static int sandisk_enable_wireless(struct net_device *dev)
goto done; goto done;
} }
parse = kmalloc(sizeof(cisparse_t), GFP_KERNEL);
if (parse == NULL) {
ret = -ENOMEM;
goto done;
}
tuple.Attributes = TUPLE_RETURN_COMMON;
tuple.TupleData = buf;
tuple.TupleDataMax = sizeof(buf);
tuple.TupleOffset = 0;
if (hw_priv->link->manf_id != 0xd601 || hw_priv->link->card_id != 0x0101) { if (hw_priv->link->manf_id != 0xd601 || hw_priv->link->card_id != 0x0101) {
/* No SanDisk manfid found */ /* No SanDisk manfid found */
ret = -ENODEV; ret = -ENODEV;
goto done; goto done;
} }
tuple.DesiredTuple = CISTPL_LONGLINK_MFC; if (hw_priv->link->socket->functions < 2) {
if (pcmcia_get_first_tuple(hw_priv->link, &tuple) ||
pcmcia_get_tuple_data(hw_priv->link, &tuple) ||
pcmcia_parse_tuple(&tuple, parse) ||
parse->longlink_mfc.nfn < 2) {
/* No multi-function links found */ /* No multi-function links found */
ret = -ENODEV; ret = -ENODEV;
goto done; goto done;
...@@ -354,7 +336,6 @@ static int sandisk_enable_wireless(struct net_device *dev) ...@@ -354,7 +336,6 @@ static int sandisk_enable_wireless(struct net_device *dev)
udelay(10); udelay(10);
done: done:
kfree(parse);
return ret; return ret;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册