kernel mode EXC_DSE handling depends on td->td_pcb-> not slb faulting in setting up its slbmte use?

Mark Millard marklmi at yahoo.com
Thu May 2 21:51:05 UTC 2019


/usr/src/sys/powerpc/powerpc/trap.c has:

        } else {
                /* Kernel Mode Traps */

                KASSERT(cold || td->td_ucred != NULL,
                    ("kernel trap doesn't have ucred"));
                switch (type) {
. . .
#if defined(__powerpc64__) && defined(AIM)
                case EXC_DSE:
                        if (td->td_pcb->pcb_cpu.aim.usr_vsid != 0 &&
                            (frame->dar & SEGMENT_MASK) == USER_ADDR) {
                                __asm __volatile ("slbmte %0, %1" ::
                                        "r"(td->td_pcb->pcb_cpu.aim.usr_vsid),
                                        "r"(USER_SLB_SLBE));
                                return;
                        }
                        break;
#endif

in trap(...).

If the kernel mode EXC_DSE code got a slb fault from
td->td_pcb-> would things still be okay? (Nested trap
handling.)

If not, does something need to be done to guarantee
that td->td_pcb-> will not have an slb fault in the
above code?


===
Mark Millard
marklmi at yahoo.com
( dsl-only.net went
away in early 2018-Mar)



More information about the freebsd-ppc mailing list