Subject: Re: ARM port organisation (was: Re: NetBSD/hpcarm snap code)
To: Ben Harris <bjh21@netbsd.org>
From: Richard Earnshaw <rearnsha@arm.com>
List: port-arm32
Date: 02/17/2001 13:47:49
> On Fri, 16 Feb 2001, Jason R Thorpe wrote:
>
> Having said that I think your proposed directory layout is sane in
> general, here are the few things I'm not sure about:
>
> > arch/arm/arm <- contains stuff that works on all ARM CPUs
> > arch/arm/arm2 <- contains e.g. the ARM2 pmap module
> > arch/arm/arm6 <- contains e.g. the ARM6 pmap module,
> > cache routines, TLB routines, etc.
> > arch/arm/arm7 <- contains all the ARM7-specific goo.
> > arch/arm/arm8 <- contains all the ARM8-specific goo.
> > arch/arm/sa110 <- contains e.g. the SA110 cache routines,
> > TLB routines, etc.
>
> I'm not sure that the differences among ARM6, ARM7, ARM8, ARM9, ARM10, SA1
> and Xscale really warrant a separate directory for each one. ARMs seem to
> have fairly orthogonal sets of features, and arbitrarily filing code under
> the name of the first CPU to contain the relevant feature seems wrong to
> me.
ARM 6 & 7 are identical from the programmers perspective. ARM8 I would
ignore, I personally doubt we will ever see a serious use of that with
NetBSD. SA1 is sufficiently different from ARM6 to warrant potentially
separate support (mainly that the CPU uses write-back caching instead of
write-through). This impacts the way the pmap is structured, and could
justify a different implementation for machines where it is know to be
only SA (or later) vs earlier chips. Chips like ARM9/10 SA11x0 have a FCS
(fast context switch) extension in the MMU. If you are prepared to
restrict (all?) processes to 32M of VM, then you can avoid cache flushes
on a context switch; this also warrants a separate configuration.
Maybe a more sensible arrangement would be by CPU architecture. Eg armv3
(for arm6, 7), armv4 (SA1, ARM8), armv4fcs (sa11x0 etc), armv5 (arm9E,
arm10) ...
R.