From: "Matthew Dharm" <mdharm@momenco.com> > I'm basically done with my task of porting linux to our SR71000-based > board. I'm getting ready to start feeding patches to Ralf, and > something occured to me.... > > Sometimes, in some places, we use CONFIG_ options to select the > apropriate CPU. Other places, we probe for the CPU based on the PRID > register. > > In some places, the reason for the choice is clear -- it's just much > easier to select the cache library based on a CONFIG_ option in a > Makefile than trying to do run-time assignment of many function > pointers. > > However, is some places, the choice is not clear. In cpu-probe.c, for > example, several of the CPU identification routines are wrapped in > #ifdef's -- odd, since the wrong 'case' of the switch statements > should never get executed, even if compiled in.... There is a big discontinuity between the R3000 privileged resource model and that of the R4000 and later CPUs. So it would not surprise me if the MIPS/Linux kernel retained some R3000/non-R3000 conditional code for a while longer. Much of rest of what you're seeing, particularly in cpu-probe.c, is just slop - expedient hacks that somehow became permanent. But the ambivalence between run-time and build-time binding to CPUs probably also reflects the two poles of use of MIPS/Linux. The folks who use it on old SGI and DEC workstations have platforms like the SGI Indy where the same relatively RAM-rich platform configuration can support a number of different CPUs . That tends to lead to run-time binding of the CPU-specific routines and parameters. The folks who use it for embedded apps tend to have system and peripheral setups that are anyway pretty application-specific, and since memory isn't entirely free, there's no advantage, and some slight disadvantage, in including code to support other CPUs in the OS image. And there are, alas, cases where the designers screwed up and failed to provide a correctly unique PrID register value, such as is apparently the case with the NEC Vr4111 and VR4181. I'd be willing to bet that there is *some* way to distinguish those two parts at run-time if one really wanted to, though. > So, what's the rule here? When do I used #ifdef and when do I just > let the PRID stuff work it's magic? I don't know that there's a rule as such, but I would strongly recommend using the PrID and Config registers to generate a kernel CPU ID and a set of mips_cpu.options bits, and that information abstracted into the mips_cpu structure should be used in preference to comparing against CPU ID's. It may require a little more thought up-front, but it leaves the rest of the code a lot easier to maintain. You should have seen what the kernel looked like before we introduced the mips_cpu structure! > I mean, heck... it might be nice to put a check to see if the detected > CPU matches what the kernel was compiled for... If it doesn't, that's a bug. Kevin K.