|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen staging] xen/arm: extend fdt_property_interrupts to support DomU
commit f94e42b2ea67dedb01d4a9d122b61d7d8b20a393
Author: Viktor Mitin <viktor.mitin.19@xxxxxxxxx>
AuthorDate: Wed Aug 7 13:10:27 2019 +0300
Commit: Julien Grall <julien.grall@xxxxxxx>
CommitDate: Wed Aug 14 11:05:09 2019 +0100
xen/arm: extend fdt_property_interrupts to support DomU
The domain and fdt can be found in the structure kinfo.
Rather than adding a an extra argument for the domain, pass directly
kinfo.
This also requires to adapt fdt_property_interrupts() prototype.
A follow-up patch will need to create the interrupts for either Dom0 or
DomU.
Suggested-by: Julien Grall <julien.grall@xxxxxxx>
Signed-off-by: Viktor Mitin <viktor_mitin@xxxxxxxx>
Reviewed-by: Volodymyr Babchuk <volodymyr_babchuk@xxxxxxxx>
Acked-by: Julien Grall <julien.grall@xxxxxxx>
---
xen/arch/arm/domain_build.c | 20 ++++++++++++--------
1 file changed, 12 insertions(+), 8 deletions(-)
diff --git a/xen/arch/arm/domain_build.c b/xen/arch/arm/domain_build.c
index 4c8404155a..26cd0ae12c 100644
--- a/xen/arch/arm/domain_build.c
+++ b/xen/arch/arm/domain_build.c
@@ -621,17 +621,20 @@ static void __init set_interrupt(gic_interrupt_t
interrupt,
* "interrupts": contains the list of interrupts
* "interrupt-parent": link to the GIC
*/
-static int __init fdt_property_interrupts(void *fdt, gic_interrupt_t *intr,
+static int __init fdt_property_interrupts(const struct kernel_info *kinfo,
+ gic_interrupt_t *intr,
unsigned num_irq)
{
int res;
+ uint32_t phandle = is_hardware_domain(kinfo->d) ?
+ dt_interrupt_controller->phandle : GUEST_PHANDLE_GIC;
- res = fdt_property(fdt, "interrupts", intr, sizeof (intr[0]) * num_irq);
+ res = fdt_property(kinfo->fdt, "interrupts",
+ intr, sizeof(intr[0]) * num_irq);
if ( res )
return res;
- res = fdt_property_cell(fdt, "interrupt-parent",
- dt_interrupt_controller->phandle);
+ res = fdt_property_cell(kinfo->fdt, "interrupt-parent", phandle);
return res;
}
@@ -733,7 +736,7 @@ static int __init make_hypervisor_node(struct domain *d,
* TODO: Handle properly the cpumask;
*/
set_interrupt(intr, d->arch.evtchn_irq, 0xf, DT_IRQ_TYPE_LEVEL_LOW);
- res = fdt_property_interrupts(fdt, &intr, 1);
+ res = fdt_property_interrupts(kinfo, &intr, 1);
if ( res )
return res;
@@ -960,8 +963,9 @@ static int __init make_gic_node(const struct domain *d,
void *fdt,
return res;
}
-static int __init make_timer_node(const struct domain *d, void *fdt)
+static int __init make_timer_node(const struct kernel_info *kinfo)
{
+ void *fdt = kinfo->fdt;
static const struct dt_device_match timer_ids[] __initconst =
{
DT_MATCH_COMPATIBLE("arm,armv7-timer"),
@@ -1016,7 +1020,7 @@ static int __init make_timer_node(const struct domain *d,
void *fdt)
dt_dprintk(" Virt interrupt %u\n", irq);
set_interrupt(intrs[2], irq, 0xf, DT_IRQ_TYPE_LEVEL_LOW);
- res = fdt_property_interrupts(fdt, intrs, 3);
+ res = fdt_property_interrupts(kinfo, intrs, 3);
if ( res )
return res;
@@ -1377,7 +1381,7 @@ static int __init handle_node(struct domain *d, struct
kernel_info *kinfo,
if ( device_get_class(node) == DEVICE_GIC )
return make_gic_node(d, kinfo->fdt, node);
if ( dt_match_node(timer_matches, node) )
- return make_timer_node(d, kinfo->fdt);
+ return make_timer_node(kinfo);
/* Skip nodes used by Xen */
if ( dt_device_used_by(node) == DOMID_XEN )
--
generated by git-patchbot for /home/xen/git/xen.git#staging
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |