xen-devel.lists.xenproject.org archive mirror
 help / color / mirror / Atom feed
From: Julien Grall <julien.grall@arm.com>
To: Oleksandr <olekstysh@gmail.com>,
	Stefano Stabellini <sstabellini@kernel.org>,
	xen-devel@lists.xenproject.org
Cc: Stefano Stabellini <stefanos@xilinx.com>, Volodymyr_Babchuk@epam.com
Subject: Re: [Xen-devel] [PATCH v7 8/8] xen/arm: add reserved-memory regions to the dom0 memory node
Date: Tue, 20 Aug 2019 18:49:21 +0100	[thread overview]
Message-ID: <366ed936-5316-84f3-93df-ad3671fff56b@arm.com> (raw)
In-Reply-To: <4be7e616-e36f-c14f-6ec3-7ef148cb98ca@gmail.com>

Hi Oleksandr,

On 20/08/2019 16:28, Oleksandr wrote:
> On 19.08.19 20:43, Stefano Stabellini wrote:
>> Reserved memory regions are automatically remapped to dom0. Their device
>> tree nodes are also added to dom0 device tree. However, the dom0 memory
>> node is not currently extended to cover the reserved memory regions
>> ranges as required by the spec.  This commit fixes it.
>>
>> Change make_memory_node to take a  struct meminfo * instead of a
>> kernel_info. Call it twice for dom0, once to create the first regular
>> memory node, and the second time to create a second memory node with the
>> ranges covering reserved-memory regions.
>>
>> Also, make a small code style fix in make_memory_node.
>>
>> Signed-off-by: Stefano Stabellini <stefanos@xilinx.com>
>> Acked-by: Julien Grall <julien.grall@arm.com>
>> ---
>> Changes in v5:
>> - add acked-by
>>
>> Changes in v4:
>> - pass struct meminfo * to make_memory_node
>> - call make_memory_node twice for dom0, once for normal memory, once for
>>    reserved-memory regions
>> ---
>>   xen/arch/arm/domain_build.c | 22 +++++++++++++++-------
>>   1 file changed, 15 insertions(+), 7 deletions(-)
>>
>> diff --git a/xen/arch/arm/domain_build.c b/xen/arch/arm/domain_build.c
>> index b4260f1fc2..306180d8cb 100644
>> --- a/xen/arch/arm/domain_build.c
>> +++ b/xen/arch/arm/domain_build.c
>> @@ -639,11 +639,11 @@ static int __init fdt_property_interrupts(void *fdt, 
>> gic_interrupt_t *intr,
>>   static int __init make_memory_node(const struct domain *d,
>>                                      void *fdt,
>>                                      int addrcells, int sizecells,
>> -                                   const struct kernel_info *kinfo)
>> +                                   struct meminfo *mem)
>>   {
>>       int res, i;
>>       int reg_size = addrcells + sizecells;
>> -    int nr_cells = reg_size*kinfo->mem.nr_banks;
>> +    int nr_cells = reg_size * mem->nr_banks;
>>       __be32 reg[NR_MEM_BANKS * 4 /* Worst case addrcells + sizecells */];
>>       __be32 *cells;
>> @@ -662,10 +662,10 @@ static int __init make_memory_node(const struct domain *d,
>>           return res;
>>       cells = &reg[0];
>> -    for ( i = 0 ; i < kinfo->mem.nr_banks; i++ )
>> +    for ( i = 0 ; i < mem->nr_banks; i++ )
>>       {
>> -        u64 start = kinfo->mem.bank[i].start;
>> -        u64 size = kinfo->mem.bank[i].size;
>> +        u64 start = mem->bank[i].start;
>> +        u64 size = mem->bank[i].size;
>>           dt_dprintk("  Bank %d: %#"PRIx64"->%#"PRIx64"\n",
>>                      i, start, start + size);
>> @@ -1486,10 +1486,18 @@ static int __init handle_node(struct domain *d, struct 
>> kernel_info *kinfo,
>>           if ( res )
>>               return res;
>> -        res = make_memory_node(d, kinfo->fdt, addrcells, sizecells, kinfo);
>> +        res = make_memory_node(d, kinfo->fdt, addrcells, sizecells, 
>> &kinfo->mem);
>>           if ( res )
>>               return res;
>> +        /*
>> +         * Create a second memory node to store the ranges covering
>> +         * reserved-memory regions.
>> +         */
>> +        res = make_memory_node(d, kinfo->fdt, addrcells, sizecells,
>> +                               &bootinfo.reserved_mem);
>> +        if ( res )
>> +            return res;
>>       }
>>       res = fdt_end_node(kinfo->fdt);
>> @@ -1745,7 +1753,7 @@ static int __init prepare_dtb_domU(struct domain *d, 
>> struct kernel_info *kinfo)
>>       if ( ret )
>>           goto err;
>> -    ret = make_memory_node(d, kinfo->fdt, addrcells, sizecells, kinfo);
>> +    ret = make_memory_node(d, kinfo->fdt, addrcells, sizecells, &kinfo->mem);
>>       if ( ret )
>>           goto err;
> 
> I don't really know whether it is an issue we should worry about, but I noticed 
> that dom0 (Linux 4.14) reported the following:
> 
> OF: Duplicate name in base, renamed to "memory#1"

Path in the device-tree should always be uniq. So it is not possible to have two 
nodes /memory as we are doing today. It looks like Linux workaround it by adding #1.

In this case, we should create name with the following format 
memory@<unit-address>. Per the DeviceTree specification, <unit-address> should 
match the base of address of the first region.

There are an example in make_cpus_node() that can be re-used here.

Cheers,

-- 
Julien Grall

_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xenproject.org
https://lists.xenproject.org/mailman/listinfo/xen-devel

      reply	other threads:[~2019-08-20 18:35 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-08-19 17:43 [Xen-devel] [PATCH v7 0/8] reserved-memory in dom0 Stefano Stabellini
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 1/8] xen/arm: pass node to device_tree_for_each_node Stefano Stabellini
2019-08-19 17:56   ` Julien Grall
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 2/8] xen/arm: make process_memory_node a device_tree_node_func Stefano Stabellini
2019-08-19 18:03   ` Julien Grall
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 3/8] xen/arm: keep track of reserved-memory regions Stefano Stabellini
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 4/8] xen/arm: fix indentation in early_print_info Stefano Stabellini
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 5/8] xen/arm: early_print_info print reserved_mem Stefano Stabellini
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 6/8] xen/arm: handle reserved-memory in consider_modules and dt_unreserved_regions Stefano Stabellini
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 7/8] xen/arm: don't iomem_permit_access for reserved-memory regions Stefano Stabellini
2019-08-19 18:38   ` Julien Grall
2019-08-19 17:43 ` [Xen-devel] [PATCH v7 8/8] xen/arm: add reserved-memory regions to the dom0 memory node Stefano Stabellini
2019-08-20 15:28   ` Oleksandr
2019-08-20 17:49     ` Julien Grall [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=366ed936-5316-84f3-93df-ad3671fff56b@arm.com \
    --to=julien.grall@arm.com \
    --cc=Volodymyr_Babchuk@epam.com \
    --cc=olekstysh@gmail.com \
    --cc=sstabellini@kernel.org \
    --cc=stefanos@xilinx.com \
    --cc=xen-devel@lists.xenproject.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).