[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [RFC v1 3/5] xen/arm: introduce SCMI-SMC mediator driver
On Tue, Jan 25, 2022 at 01:19:46PM -0800, Stefano Stabellini wrote: > On Tue, 25 Jan 2022, Oleksii Moisieiev wrote: > > On Mon, Jan 24, 2022 at 02:14:43PM -0800, Stefano Stabellini wrote: > > > On Mon, 24 Jan 2022, Julien Grall wrote: > > > > On 24/01/2022 19:06, Stefano Stabellini wrote: > > > > > It looks like XEN_DOMCTL_host_node_by_path and > > > > > XEN_DOMCTL_find_host_compatible_node would also solve the problem but > > > > > I > > > > > think that a single hypercall that retrieves the entire host DTB would > > > > > be easier to implement > > > > > > > > DOMCTL should only be used to handle per-domain information. If we want > > > > to > > > > create a new sub-hypercall of either __HYPERVISOR_platform_op or > > > > __HYPERVISOR_sysctl_op (not sure which one). > > > > > > > > AFAICT, both are versioned. > > > > > > > > > and more robust in the long term. > > > > > > hypfs has the advantage that it would create an interface more similar > > > > > to the one people are already used to on Linux systems > > > > > (/proc/device-tree). xl/libxl would have to scan the whole hypfs tree, > > > > > which intuitively I think it would be slower. > > > > > > > > Even if you have the binary blob, you would still have to scan the > > > > device-tree. That said, it is probably going to be potentially a bit > > > > faster > > > > because you have less hypercall. > > > > > > > > However, here this is a trade-off between memory use and speed. If you > > > > want > > > > speed, then you may have to transfer up to 2MB every time. So the > > > > question is > > > > do we care more about speed or memory usage? > > > > > > > > > Also the feature might be > > > > > harder to implement but I am not sure. > > > > > > > > > > I don't have a strong preference and this is not a stable interface > > > > > (we > > > > > don't have to be extra paranoid about forward and backward > > > > > compatibility). So I am fine either way. Let's see what the others > > > > > think > > > > > as well. > > > > > > > > My preference would be to use hypfs as this is cleaner than exposing a > > > > blob. > > > > > > That's also fine by me. Probably the hypfs implementation shouldn't be > > > much more difficult than something like > > > XEN_DOMCTL_host_node_by_path/XEN_DOMCTL_find_host_compatible_node. > > > > > > > > > > However, are we sure we can simply copy the content of the host > > > > Device-Tree to > > > > the guest Device-Tree for SCMI? For instance, I know that for device > > > > passthrough there are some property that needs to be altered for some > > > > devices. > > > > Hence, why it is not present. Although, I vaguely recalled to have > > > > written a > > > > PoC, not sure if it was posted on the ML. > > > > > > The SCMI node cannot be copied "as is" from host to guest. It needs a > > > couple of changes but they seem feasible as they are limited to the > > > channels exposed to the guest. (The generic device passthrough case is a > > > lot more difficult.) > > > > > > Hi Stefano, > > > > What I'm thinking about is do we actually need to create SCMI node in DomU > > device-tree? > > I have this question is because we don't need SCMI node to be present in > > DomU > > device-tree if it has no passed-through devices, which are using scmi. > > So if we don't have passed-through devices or do not provide DomU partial > > device-tree > > in config, then there is no need to create SCMI node. > > > > For now I see the following possible domu configurations: > > 1) If DomU has a lot of passed-through devices and it's easier to inherit > > host device-tree and disable not passed-through devices. > > Partial device tree will looks like this: > > > > #include "r8a77961-salvator-xs.dts" //include host device tree > > > > / > > { > > soc { > > ... > > } > > > > }; > > > > // Disable non passed-through devices > > &hscif { > > status = "disabled"; > > }; > > > > In this case DomU partial device-tree will inherit arm,scmi-smc and > > arm,scmi-shmem nodes and all clock/reset/power-domains which are using > > scmi. > > All this nodes can be copied to DomU device-tree from partial device-tree. > > This is an almost dom0 configuration. For this kind of use-cases, I > think it is enough to handle dom0 automatically correctly. I wouldn't > ask for anything more than that. > > > > 2) DomU has few passed-through devices, so it's easier to add the device > > nodes > > to the passthrough node of DomU partial device-tree. > > DomU partial device-tree will look like this: > > { > > scmi_shmem: scp-shmem@0x53FF0000 { > > compatible = "arm,scmi-shmem"; > > reg = <0x0 0x53FF0000 0x0 0x10000>; > > }; > > scmi { > > arm,smc-id = <....>; > > compatible = "arm,scmi-smc"; > > shmem = <&scmi_shmem>; > > scmi_clock: protocol@14 { > > ... > > }; > > scmi_reset: protocol@16 { > > ... > > }; > > }; > > passthrough { > > hscif0: serial@e6540000 { > > compatible = "renesas,hscif-r8a77961"; > > scmi_devid = <5>; > > clocks = <&scmi_clock 5>; > > resets = <&scmi_reset 5>; > > ... > > }; > > }; > > }; > > > > As you can see in this case we have to manually copy arm,scmi-shmem and > > arm,scmi-smc nodes with hscif0 node or the device-tree compilation will > > fail. > > We can use 0x53FF0000, provided in arm,scmi-shmem node and map domain > > channel > > to this address and copy scmi related nodes to the DomU device-tree. > > This is useful when we need to expose only certain protocols to the DomU. > > Also it's easy to modify DomU scmi node, as we need for stm32mp1 for > > example > > when different smc-id should be set for DomU. > > I think this is the most interesting case that should be automated and > not require manual intervention. Let me explain why. > > Currently we require partial device trees to be manually written because > there is no easy way to automatically generate them. (I have some ideas > on how to automatically generate partial device trees but that is a > separate discussion.) > > Unfortunately, it has become increasingly clear that it is too difficult > for users (even advanced users!) to come up with the appropriate partial > device trees. Thus, I am reluctant to introduce more things that rely on > the user having to manually specify partial device tree information. > This is why I would like the SCMI nodes to be automatically added for > domUs. > > Of course, if a user provides the scmi and scmi_shmem nodes in the > partial device tree we could just use them. But ideally we should also > be able to automatically generated them based on the host device tree > nodes, so that the user only needs to provide serial@e6540000 (in your > example, scmi_devid would need to be populated too) and the rest would > be done automatically as we do today for the gic and vuart nodes. > > At the same time I don't want to scope-creep this patch series too much > and I don't mean to ask you to add a huge new infrastructure to Xen and > the Xen tools just to get SCMI support in. I would rather have a > not-great automatic generation of the domU SCMI nodes than nothing (e.g. > using your suggested XEN_DOMCTL_host_node_by_path and > XEN_DOMCTL_find_host_compatible_node hypercalls althought they would > need to be platform_op as Julien suggested). > > It looks like the generation of scmi_shmem and scmi should be easy > enough that could be handled without difficulty in xl/libxl. But if that > turns out to be too difficult, we could have a small independent > bash/python script that from the host device tree generates the partial > device tree with the SCMI nodes. From Xen point of view we are would > still be using the partial device tree, but the partial device tree > itself would be generated instead of manually written. As this workflow > requires a separate tool I think it is a worse option than the one > above. Still better than nothing though. > Hi Stefano, Thank you for the detail answer. I went through hypfs and will try to export host device_tree. Then xl will be able to use hypfs data to generate arm,scmi-smc node if arm,scmi-smc node was not provided in DomU partial device-tree. Unfortunately, some changes should be done to hypfs because it seems not ready to handle nested dynamic dirs. I'll see if I can update hypfs without breaking the original functionality. If not, I will have to create all hypfs dir structure on start. For now I'm working on making dynamically created hypfs tree structure, based on host device-tree. Best regards, Oleksii. > > > 3) DomU doesn't have any passthrough nodes, which are using scmi. > > In this case we don't want SCMI nodes to be in the DomU device-tree. > > > > I see only one use-case when we may need scmi nodes to be generated by xl > > in > > DomU device-tree: > > Xen generates psci node to handle cpu_on and cpu_off. > > According to the Section 4.3.2.5 of the DEN0056C [1]: > > > For these power domains, this protocol can be used to implement PSCI > > > CPU_SUSPEND, CPU_ON, CPU_FREEZE, CPU_DEFAULT_SUSPEND and CPU_OFF > > > functions. > > > > So in theory psci node can use scmi to control cpu state. But this is not > > our > > use-case because we don't want to give DomU ability to stop physical CPU. > > Xen can't intercept and handle CPU_ON and CPU_OFF requests when mailbox > > transport > > is used for SCMI communication. > > > > [1] "SCMI Specification DEN0056C," [Online]. Available: > > https://urldefense.com/v3/__https://developer.arm.com/documentation/den0056/latest__;!!GF_29dbcQIUBPA!k5oB4BpbIN-hU5jrWvNy9FLXi3Kavu3qTr5lESjK8NnlS261E0Nuqg2_pUQWxb2hDdLa$ > > [developer[.]arm[.]com] > > I agree with you on this one; I am not worried about this case.
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |