Source-Changes-HG archive

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

[src/netbsd-1-6]: src/sys/arch/sparc64/dev Pull up revision 1.51 (requested b...



details:   https://anonhg.NetBSD.org/src/rev/25071dd523b2
branches:  netbsd-1-6
changeset: 528043:25071dd523b2
user:      lukem <lukem%NetBSD.org@localhost>
date:      Fri Jun 21 06:33:11 2002 +0000

description:
Pull up revision 1.51 (requested by eeh in ticket #338):
The FFB interrupt mapping registers need to compare IGN as well as INO since
they are totally programmable.

diffstat:

 sys/arch/sparc64/dev/psycho.c |  15 +++++++++++++--
 1 files changed, 13 insertions(+), 2 deletions(-)

diffs (43 lines):

diff -r 3334302157cf -r 25071dd523b2 sys/arch/sparc64/dev/psycho.c
--- a/sys/arch/sparc64/dev/psycho.c     Fri Jun 21 06:26:55 2002 +0000
+++ b/sys/arch/sparc64/dev/psycho.c     Fri Jun 21 06:33:11 2002 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: psycho.c,v 1.48.2.2 2002/06/21 06:26:12 lukem Exp $    */
+/*     $NetBSD: psycho.c,v 1.48.2.3 2002/06/21 06:33:11 lukem Exp $    */
 
 /*
  * Copyright (c) 2001, 2002 Eduardo E. Horvath
@@ -490,6 +490,7 @@
                /* Point the strbuf_ctl at the iommu_state */
                pp->pp_sb.sb_is = sc->sc_is;
 
+               sc->sc_is->is_sb[0] = sc->sc_is->is_sb[1] = NULL;
                if (PROM_getproplen(sc->sc_node, "no-streaming-cache") < 0) {
                        struct strbuf_ctl *sb = &pp->pp_sb;
                        vaddr_t va = (vaddr_t)&pp->pp_flush[0x40];
@@ -1050,7 +1051,7 @@
                /* Hunt thru obio first */
                for (intrmapptr = &sc->sc_regs->scsi_int_map,
                             intrclrptr = &sc->sc_regs->scsi_clr_int;
-                    intrmapptr <= &sc->sc_regs->ffb1_int_map;
+                    intrmapptr < &sc->sc_regs->ffb0_int_map;
                     intrmapptr++, intrclrptr++) {
                        if (INTINO(*intrmapptr) == ino)
                                goto found;
@@ -1066,6 +1067,16 @@
                                goto found;
                        }
                }
+
+               /* Finally check the two FFB slots */
+               intrclrptr = NULL; /* XXX? */
+               for (intrmapptr = &sc->sc_regs->ffb0_int_map;
+                    intrmapptr <= &sc->sc_regs->ffb1_int_map;
+                    intrmapptr++) {
+                       if (INTVEC(*intrmapptr) == ino)
+                               goto found;
+               }
+
                printf("Cannot find interrupt vector %lx\n", vec);
                return (NULL);
 



Home | Main Index | Thread Index | Old Index