VFP handling in multiplatform feroceon kernels

Catalin Marinas catalin.marinas at arm.com
Tue Jun 24 07:10:56 PDT 2014


On Tue, Jun 24, 2014 at 03:04:14PM +0100, Nicolas Pitre wrote:
> On Tue, 24 Jun 2014, Catalin Marinas wrote:
> 
> > On Tue, Jun 24, 2014 at 02:17:06PM +0100, Arnd Bergmann wrote:
> > > Since 3.16, we have the ability to build a multiplatform kernel
> > > that includes both kirkwood (feroceon) and some other ARMv5 CPU.
> > > 
> > > I accidentally stumbled over a bug in the VFP code that looks
> > > like it will break at least ARM9 VFP support if CPU_FEROCEON
> > > is also enabled, introduced by this (old) commit:
> > 
> > I would argue that the bug is in the CPU (feroceon). See the end of this
> > email:
> > 
> > http://www.spinics.net/lists/arm-kernel/msg41460.html
> > 
> > and my follow-up. Basically you can't avoid the conditional compilation
> > as Feroceon doesn't follow the VFP sub-architecture spec and doesn't
> > present itself as a different CPU from an _ARM_ 9. Unless things have
> > changed with Marvell's hardware implementation and they got a new id, I
> > suggest you don't enable this for multi-platform.
> 
> Only the early revision did hijack the ARM9 ID but still. We certainly 
> can determine at run time if the platform being booted is equiped with a 
> Feroceon before user space is started.  In that case I'd suggest some 
> runtime code patching to branch to some out-of-line assembly code for 
> Feroceon.

You don't even need to branch to out of line assembly, just branch over
the imprecise VFP abort handling in arch/arm/vfp/vfphw.S.

-- 
Catalin



More information about the linux-arm-kernel mailing list