commit 80e9255328f9f1c2a6aa7422be1f0a87a4a9cb7b
Author: Chuck Ebbert <[EMAIL PROTECTED]>
Date:   Thu Feb 21 19:33:00 2008 -0500

    PCMCIA: Fix station address detection in smc
    
    Commit: a1a98b72dbd17e53cd92b8e78f404525ebcfd981
    
    Fix station address detection in smc
    
    Megahertz EM1144 PCMCIA ethernet adapter needs special handling
    because it has two VERS_1 tuples and the station address is in
    the second one. Conversion to generic handling of these fields
    broke it. Reverting that fixes the device.
    
      https://bugzilla.redhat.com/show_bug.cgi?id=233255
    
    Thanks go to Jon Stanley for not giving up on this one until the
    problem was found.
    
    Signed-off-by: Chuck Ebbert <[EMAIL PROTECTED]>
    Signed-off-by: Jeff Garzik <[EMAIL PROTECTED]>
    Signed-off-by: Greg Kroah-Hartman <[EMAIL PROTECTED]>

diff --git a/drivers/net/pcmcia/smc91c92_cs.c b/drivers/net/pcmcia/smc91c92_cs.c
index c9868e9..e94434f 100644
--- a/drivers/net/pcmcia/smc91c92_cs.c
+++ b/drivers/net/pcmcia/smc91c92_cs.c
@@ -559,8 +559,16 @@ static int mhz_setup(struct pcmcia_device *link)
 
     /* 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]) {
-       station_addr = link->prod_id[3];
+    tuple->DesiredTuple = CISTPL_VERS_1;
+    if (first_tuple(link, tuple, parse) != CS_SUCCESS) {
+       rc = -1;
+       goto free_cfg_mem;
+    }
+    /* Ugh -- the EM1144 card has two VERS_1 tuples!?! */
+    if (next_tuple(link, tuple, parse) != CS_SUCCESS)
+       first_tuple(link, tuple, parse);
+    if (parse->version_1.ns > 3) {
+       station_addr = parse->version_1.str + parse->version_1.ofs[3];
        if (cvt_ascii_address(dev, station_addr) == 0) {
                rc = 0;
                goto free_cfg_mem;
_______________________________________________
unionfs-cvs mailing list: http://unionfs.filesystems.org/
[email protected]
http://www.fsl.cs.sunysb.edu/mailman/listinfo/unionfs-cvs

Reply via email to