Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/evbarm/gumstix Apply patch from PR port-evbarm/52209



details:   https://anonhg.NetBSD.org/src/rev/17c1ffddba8b
branches:  trunk
changeset: 991045:17c1ffddba8b
user:      skrll <skrll%NetBSD.org@localhost>
date:      Fri Nov 05 07:39:22 2021 +0000

description:
Apply patch from PR port-evbarm/52209

Gumstix: KDASSERT in pxa2x0_gpio if no PCMCIA  bushead given but present

diffstat:

 sys/arch/evbarm/gumstix/gxpcic.c |  21 +++++++++++----------
 1 files changed, 11 insertions(+), 10 deletions(-)

diffs (54 lines):

diff -r 6a8d81ec0303 -r 17c1ffddba8b sys/arch/evbarm/gumstix/gxpcic.c
--- a/sys/arch/evbarm/gumstix/gxpcic.c  Fri Nov 05 06:15:42 2021 +0000
+++ b/sys/arch/evbarm/gumstix/gxpcic.c  Fri Nov 05 07:39:22 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: gxpcic.c,v 1.13 2013/02/02 20:06:48 christos Exp $ */
+/*     $NetBSD: gxpcic.c,v 1.14 2021/11/05 07:39:22 skrll Exp $ */
 /*
  * Copyright (C) 2005, 2006 WIDE Project and SOUM Corporation.
  * All rights reserved.
@@ -158,20 +158,22 @@
 {
        struct pxapcic_softc *sc = device_private(self);
        struct pxaip_attach_args *pxa = aux;
-       int nslot, i;
+       int nslot, i, j;
 
        sc->sc_dev = self;
        sc->sc_iot = pxa->pxa_iot;
 
        nslot = gxpcic_count_slot(sc);
 
-       for (i = 0; i < nslot; i++) {
-               if (!gxpcic_slot_irqs[i].valid) 
+       for (i = 0, j = 0; i < nslot; i++) {
+               if (!gxpcic_slot_irqs[i].valid) {
+                       j++;
                        continue;
-               sc->sc_irqpin[i] = gxpcic_slot_irqs[i].prdy;
-               sc->sc_irqcfpin[i] = gxpcic_slot_irqs[i].cd;
+               }
+               sc->sc_irqpin[i - j] = gxpcic_slot_irqs[i].prdy;
+               sc->sc_irqcfpin[i - j] = gxpcic_slot_irqs[i].cd;
        }
-       sc->sc_nslots = nslot;
+       sc->sc_nslots = i - j;
 
        pxapcic_attach_common(sc, &gxpcic_socket_setup);
 }
@@ -205,13 +207,12 @@
 
        switch (which) {
        case PXAPCIC_CARD_STATUS:
-               reg = pxa2x0_gpio_get_function(gxpcic_slot_irqs[so->socket].cd);
+               reg = pxa2x0_gpio_get_function(so->sc->sc_irqcfpin[so->socket]);
                return (HAVE_CARD(reg) ?
                    PXAPCIC_CARD_VALID : PXAPCIC_CARD_INVALID);
 
        case PXAPCIC_CARD_READY:
-               reg = pxa2x0_gpio_get_function(
-                   gxpcic_slot_irqs[so->socket].prdy);
+               reg = pxa2x0_gpio_get_function(so->sc->sc_irqpin[so->socket]);
                return (reg & GPIO_SET ? 1 : 0);
 
        default:



Home | Main Index | Thread Index | Old Index