On Mon, 21 May 2012, Deng-Cheng Zhu wrote: > > What's so Malta-specific in the VPE loader anyway? It's a CPU feature, > > not a board-specific one. > > Well, first off, for VPE loader itself, when it comes to CPS we have > vpe_run() that derives from amon_cpu_start() in arch/mips/mti-malta/malta- > amon.c. There is no implementation of amon_cpu_start() on other platforms. Hmm, there's nothing platform-specific there, the file is pretty generic, it could be moved to arch/mips/kernel/ or thereabouts. That applies to <asm/mips-boards/launch.h> too, before you ask (you may want to use alloc_bootmem or suchlike instead of hardcoding the trampoline page, though it's probably pretty safe to assume the end of the exception handler page is available everywhere). > Secondly, I suppose VPE loader works uniquely for APRP, and part of APRP > (such as IRQ related stuff) depends on platform code. So it makes sense > (IMO) to impose the dependency of APRP on the root (VPE loader). Hmm, does it really? It sounds wrong to me, it shouldn't use any hardware interrupts, and software interrupts again are available everywhere, at least on the MT processors now in existence. There's nothing platform-specific referred to from arch/mips/kernel/vpe.c AFAICT (and I trust in Beth having got this piece right). I reckon it used to work with CONFIG_MIPS_SIM too, though I could imagine the configuration got neglected a bit as it is somewhat unusual. Maciej