Hi Michael, On Fri, 28 Jun 2013 00:16:31 +1000 Michael Ellerman <mich...@ellerman.id.au> wrote: > > On Thu, Jun 27, 2013 at 02:05:39PM +1000, Stephen Rothwell wrote: > > > > On Tue, 25 Jun 2013 17:47:56 +1000 Michael Ellerman > > <mich...@ellerman.id.au> wrote: > > > > > > -void tm_unavailable_exception(struct pt_regs *regs) > > > +void facility_unavailable_exception(struct pt_regs *regs) > > > { > > > + static char *facility_strings[] = { > > > + "FPU", > > > + "VMX/VSX", > > > + "DSCR", > > > + "PMU SPRs", > > > + "BHRB", > > > + "TM", > > > + "AT", > > > + "EBB", > > > + "TAR", > > > + }; > > > > Are the indexes into this array defined somewhere? If not, can we do > > that. Then, can we use explicit indexed initialisers for this array? > > I'm not sure I follow. > > The mapping is defined by the definition of the "Interruption Cause" > field of the FSCR, section 6.2.10 of PowerISA v2.07.
OK, so these numbers are externally defined: #define FSCR_INT_CAUSE_FPU 0 ... #define FSCR_INT_CAUSE_TAR 8 (or maybe an enum) static char *facility_strings[] = { [ FSCR_INT_CAUSE_FPU ] = "FPU", [ FSCR_INT_CAUSE_VMX_VSX ] = "VMX/VSX", [ FSCR_INT_CAUSE_DSCR ] = "DSCR", [ FSCR_INT_CAUSE_PMU_SPRs ] = "PMU SPRs", [ FSCR_INT_CAUSE_BHRB ] = "BHRB", [ FSCR_INT_CAUSE_TM ] = "TM", [ FSCR_INT_CAUSE_AT ] = "AT", [ FSCR_INT_CAUSE_EBB ] = "EBB", [ FSCR_INT_CAUSE_TAR ] = "TAR", }; Or something similar. Of course, then your code should cope with facility_strings[...] being NULL. This makes it very clear that these things are not just "made up" for your code. -- Cheers, Stephen Rothwell s...@canb.auug.org.au
pgp4H3GFMWoNK.pgp
Description: PGP signature
_______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev