On 09/11/14 10:43, Marc Zyngier wrote: >>> If I was suicidal, I'd suggest you could pass a parameter to the command >>> line, interpreted by the timer code... But I since I'm not, let's >>> pretend I haven't said anything... ;-) >> I did this in the past (again, see Sonny's thread), but didn't >> consider myself knowledgeable to know if that was truly a good test: >> >> asm volatile("mrc p15, 0, %0, c1, c1, 0" : "=r" (val)); >> pr_info("DOUG: val is %#010x", val); >> val |= (1 << 2); >> asm volatile("mcr p15, 0, %0, c1, c1, 0" : : "r" (val)); >> val = 0xffffffff; >> asm volatile("mrc p15, 0, %0, c1, c1, 0" : "=r" (val)); >> pr_info("DOUG: val is %#010x", val); >> >> The idea being that if you can make modifications to the SCR register >> (and see your changes take effect) then you must be in secure mode. >> In my case the first printout was 0x0 and the second was 0x4. > The main issue is when you're *not* in secure mode. It is likely that > this will explode badly. This is why I suggested something that is set > by the bootloader (after all. it knows which mode it is booted in), and > that the timer driver can use when the CPU comes up. Where does this platform jump to when a CPU comes up? Is it rockchip_secondary_startup()? I wonder if that path could have this little bit of assembly to poke the cntvoff in monitor mode and then jump to secondary_startup()? Before we boot any secondary CPUs we could also read the cntvoff for CPU0 in the platform specific layer (where we know we're running in secure mode) and then use that value as the "reset" value for the secondaries. Or does this platform boot up in secure mode some times and non-secure mode other times? -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html