ARMv8-64 Cache management in a PSCI functions

Hi everyone,

I'm currently working on type-1 hypervisor and would like to provide support of the ARM Power State Coordination Interface. http://infocenter.arm.com/help/topic/com.arm.doc.den0022d/Power_State_Coordination_Interface_PDD_v1_1_DEN0022D.pdf

In order to achieve this, some functionality should be implemented in EL2 mode in response to the hypercalls performed by the guest OSes. According with the Platform Design Document (above) some functions are mandatory such as CPU_OFF, CPU_SUSPEND and CPU_ON. However, in both of them it is required cache and coherency management.

My question is the following, in a scenario that there are multiples vCPUs running on top of physical core0 and one of them wants to perform a hypercall to the hypervisor (CPU_ON), is there any portable way to invalidate the respective cache lines related to the specific vcpu, the one which performs the hypercall?

Thanks in advance,

Cheers.

Jorge

Parents
  • I'm not sure I do get it.

    so vCPU0 of Guest 0 on CPU0 is running. vCPU0 of Guest 1 on CPU 1 does a vPSCI call to "power down" but the hypervisor will not power down this core via PSCI.

    You want to clean all the lines out of CPU 1 for Guest 1 even though it will stay in a physical running state.

    Unless your guests are sharing data there's no need - are you attempting to make sure vCPU 0 for "Guest 2" has an empty cache?

    The reason PSCI requires cache maintenance is not only to ensure consistency of the data used by the OS but to cover Secure data which cannot be actively maintained by the Non-Secure world (this is why PSCI lives at EL3 or EL3+EL1S.) It also makes sure that if a core is in a state that cannot respond to coherency traffic that the interconnect (or SCU) does not send snoops that will never be acked.

    For two Non-Secure guests under virtualization unless you are going to actually place either physical CPU in a low power state (I.e. Call PSCI at EL3) then natural processes will ensure things stay coherent and consistent. Active cache maintenance at the point of a Virtual powerdown is a waste of power and bandwidth, and if it does power down via PSCI then it will do that for you anyway.

    So, again, I'm not sure I understand the intent you have.. but I still don't think you need to do anything at all. If you still think you need to then DC CVACxx over the range will do it (clean by VA, to point of coherency).

    When the vCPU powers up again if you need to be sure you didn't prefetch anything in the meantime then you'll need a DC IVACxx on that side, no different from any other Shareable memory location (there's fundamentally no difference between two cores and one core and a DMA engine in the memory model or AMBA architecture, consistency between two masters is /just/ consistency between two masters, and it's managed for you by the cache coherency protocol).

Reply
  • I'm not sure I do get it.

    so vCPU0 of Guest 0 on CPU0 is running. vCPU0 of Guest 1 on CPU 1 does a vPSCI call to "power down" but the hypervisor will not power down this core via PSCI.

    You want to clean all the lines out of CPU 1 for Guest 1 even though it will stay in a physical running state.

    Unless your guests are sharing data there's no need - are you attempting to make sure vCPU 0 for "Guest 2" has an empty cache?

    The reason PSCI requires cache maintenance is not only to ensure consistency of the data used by the OS but to cover Secure data which cannot be actively maintained by the Non-Secure world (this is why PSCI lives at EL3 or EL3+EL1S.) It also makes sure that if a core is in a state that cannot respond to coherency traffic that the interconnect (or SCU) does not send snoops that will never be acked.

    For two Non-Secure guests under virtualization unless you are going to actually place either physical CPU in a low power state (I.e. Call PSCI at EL3) then natural processes will ensure things stay coherent and consistent. Active cache maintenance at the point of a Virtual powerdown is a waste of power and bandwidth, and if it does power down via PSCI then it will do that for you anyway.

    So, again, I'm not sure I understand the intent you have.. but I still don't think you need to do anything at all. If you still think you need to then DC CVACxx over the range will do it (clean by VA, to point of coherency).

    When the vCPU powers up again if you need to be sure you didn't prefetch anything in the meantime then you'll need a DC IVACxx on that side, no different from any other Shareable memory location (there's fundamentally no difference between two cores and one core and a DMA engine in the memory model or AMBA architecture, consistency between two masters is /just/ consistency between two masters, and it's managed for you by the cache coherency protocol).

Children
  • Hi Matt,

    Thank you so much.

    That's what I wanted to know -

    "The reason PSCI requires cache maintenance is not only to ensure consistency of the data used by the OS but to cover Secure data which cannot be actively maintained by the Non-Secure world (this is why PSCI lives at EL3 or EL3+EL1S.) It also makes sure that if a core is in a state that cannot respond to coherency traffic that the interconnect (or SCU) does not send snoops that will never be acked.

    For two Non-Secure guests under virtualization unless you are going to actually place either physical CPU in a low power state (I.e. Call PSCI at EL3) then natural processes will ensure things stay coherent and consistent. Active cache maintenance at the point of a Virtual powerdown is a waste of power and bandwidth, and if it does power down via PSCI then it will do that for you anyway."

    thank you once again.

    Jorge