All of lore.kernel.org
 help / color / mirror / Atom feed
From: Julien Grall <julien.grall@linaro.org>
To: Parth Dixit <parth.dixit@linaro.org>
Cc: Ian Campbell <ian.campbell@citrix.com>,
	tim@xen.org, xen-devel <xen-devel@lists.xen.org>,
	Stefano Stabellini <stefano.stabellini@citrix.com>,
	Jan Beulich <jbeulich@suse.com>,
	Christoffer Dall <christoffer.dall@linaro.org>
Subject: Re: [PATCH RFC 34/35] arm : acpi workarounds for firmware/linux dependencies
Date: Thu, 05 Feb 2015 22:59:26 +0800	[thread overview]
Message-ID: <54D3854E.20702@linaro.org> (raw)
In-Reply-To: <CABy3MNmqwOrckbaEmNqxoUd2pBEqeSuKh1rdihAKrPSUKB0i=w@mail.gmail.com>

Hi Parth,

On 05/02/2015 18:30, Parth Dixit wrote:
> On 5 February 2015 at 11:08, Julien Grall <julien.grall@linaro.org> wrote:
>> Hi Parth,
>>
>> On 04/02/2015 14:02, parth.dixit@linaro.org wrote:
>>>
>>> From: Parth Dixit <parth.dixit@linaro.org>
>>>
>>> Some bugs are identified in edk2 and some of the functionality is not
>>> yet merged. This patch contains workarounds for them
>>
>>
>> While I understand some workaround (based on your cover letter), some of
>> them is unclear to me and need explanation.
> Sure, ask them, i'll reply to it.

I asked them on the previous mail. It seems you answered all of them, 
thanks :)

>>>
>>> Signed-off-by: Parth Dixit <parth.dixit@linaro.org>
>>> ---
>>
>>
>> [..]
>>
>>> diff --git a/xen/arch/arm/vgic.c b/xen/arch/arm/vgic.c
>>> index 97061ce..e74555d 100644
>>> --- a/xen/arch/arm/vgic.c
>>> +++ b/xen/arch/arm/vgic.c
>>> @@ -254,6 +254,8 @@ void vgic_disable_irqs(struct vcpu *v, uint32_t r, int
>>> n)
>>>        }
>>>    }
>>>
>>> +#define VGIC_ICFG_MASK(intr) ( 1 << ( ( 2 * ( intr % 16 ) ) + 1 ) )
>>> +
>>>    void vgic_enable_irqs(struct vcpu *v, uint32_t r, int n)
>>>    {
>>>        struct domain *d = v->domain;
>>> @@ -266,6 +268,20 @@ void vgic_enable_irqs(struct vcpu *v, uint32_t r, int
>>> n)
>>>
>>>        while ( (i = find_next_bit(&mask, 32, i)) < 32 ) {
>>>            irq = i + (32 * n);
>>> +#if defined(CONFIG_ARM_64) && defined(CONFIG_ACPI)
>>> +        if( ( n!=0 ) && is_hardware_domain(d) ){
>>> +            struct vgic_irq_rank *vr = vgic_get_rank(v, n);
>>> +            uint32_t tr;
>>> +            tr = vr->icfg[i >> 4] ;
>>> +
>>> +            if( ( tr & VGIC_ICFG_MASK(i) ) )
>>> +                acpi_set_irq(irq, DT_IRQ_TYPE_EDGE_BOTH);
>>> +            else
>>> +                acpi_set_irq(irq, DT_IRQ_TYPE_LEVEL_MASK);
>>
>>
>> What's the status of the dynamic IRQ configuration?
> It would be on top of your patches but this is the place where i am
> planning to trap it.
> I have not rebased it on top of your patches, so that needs to be done.

Ok.

>>> +
>>> +            route_irq_to_guest(d,irq,NULL);
>>
>>
>> Hmmm, do you really plan to keep that here? What's your plan for this?
> yes, but i am open to suggestions , if you think there is a better
> place i'll move it there.

Ok, when we discussed about it in december that wasn't the plan.

While I'm okay for the IRQ configuration (setting level/edge), the 
routing should not be done here.

First at all, route_irq_to_guest could fail and enable doesn't handle 
this use.

Then, DOM0 (aka the hardware domain) may not be able to use all the 
interrupts (think about pass-through).

So, for IRQ routing there is 2 possibles solutions:
	1) Route all the SPIs to the guest in Xen
	2) Let DOM0 Linux requesting to route the IRQ via a PHYSDEV_op

IIRC, we deciced to choose the first solution for now. Even though none 
of the solutions are perfect.

>>> +        }
>>> +#endif
>>>            v_target = d->arch.vgic.handler->get_target_vcpu(v, irq);
>>>            p = irq_to_pending(v_target, irq);
>>>            set_bit(GIC_IRQ_GUEST_ENABLED, &p->status);
>>> diff --git a/xen/drivers/acpi/osl.c b/xen/drivers/acpi/osl.c
>>> index 73da9d9..2d78ba0 100644
>>> --- a/xen/drivers/acpi/osl.c
>>> +++ b/xen/drivers/acpi/osl.c
>>> @@ -66,7 +66,7 @@ void __init acpi_os_vprintf(const char *fmt, va_list
>>> args)
>>>
>>>    acpi_physical_address __init acpi_os_get_root_pointer(void)
>>>    {
>>> -       if (efi_enabled) {
>>> +    if (efi_enabled) {
>>
>>
>> Spurious change
> will take care in next patchset
>>>                  if (efi.acpi20 != EFI_INVALID_TABLE_ADDR)
>>>                          return efi.acpi20;
>>>                  else if (efi.acpi != EFI_INVALID_TABLE_ADDR)
>>> @@ -198,8 +198,11 @@ acpi_os_write_memory(acpi_physical_address phys_addr,
>>> u32 value, u32 width)
>>>
>>>          return AE_OK;
>>>    }
>>> -
>>> +#ifdef CONFIG_X86
>>>    #define is_xmalloc_memory(ptr) ((unsigned long)(ptr) & (PAGE_SIZE - 1))
>>> +#else
>>> +#define is_xmalloc_memory(ptr) 1
>>> +#endif
>>
>>
>> Why? I though this was resolved?
> i am not aware what was the resolution on it?

I didn't have access on my IRC log in the plane. So I wasn't able to 
find the discussion.

AFAIR, this issue was because we are allocating a chunk bigger than 
PAGE_SIZE in acpi_tb_resize_root_table_list.

x86 manage to never allocate a chunk bigger than PAGE_SIZE. So I'm not 
sure why ARM64 requires too. This would need more debug.

This macro is used to know if the memory has been allocated by the boot 
allocator of the memory pool.

So 2 solutions:
	1) We find a better way to use detect it
	2) We avoid to allocate big chunk

I'm not sure which one is the easiest/better one.

Regards,

-- 
Julien Grall

  reply	other threads:[~2015-02-05 14:59 UTC|newest]

Thread overview: 166+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-02-04 14:01 [PATCH RFC 00/35] Add ACPI support for arm64 on Xen parth.dixit
2015-02-04 14:01 ` [PATCH RFC 01/35] xen: acpi: Build numa and pmstate x86 only parth.dixit
2015-02-04 17:03   ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 02/35] xen: arm64: ACPI: Support common ACPI drivers parth.dixit
2015-02-04 17:34   ` Stefano Stabellini
2015-02-04 17:36   ` Julien Grall
2015-02-05 11:04     ` Ian Campbell
2015-02-05 11:35       ` Jan Beulich
2015-02-05 11:57         ` Ian Campbell
2015-02-05 12:01           ` Jan Beulich
2015-02-05 14:05       ` Julien Grall
2015-02-05 11:34     ` Jan Beulich
2015-02-05 11:56       ` Ian Campbell
2015-02-04 14:01 ` [PATCH RFC 03/35] xen: arm64: ACPI: Add basic ACPI initialization parth.dixit
2015-02-04 17:40   ` Stefano Stabellini
2015-02-04 21:00   ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 04/35] ACPI / ACPICA: Introduce ARM Boot Architecture Flags in FADT parth.dixit
2015-02-04 17:42   ` Stefano Stabellini
2015-02-04 21:03   ` Julien Grall
2015-02-05 11:06     ` Ian Campbell
2015-02-05 14:09       ` Julien Grall
2015-02-05 14:10       ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 05/35] ARM64 / ACPI: Parse FADT table to get PSCI flags parth.dixit
2015-02-04 17:45   ` Stefano Stabellini
2015-02-05  3:56     ` Hanjun Guo
2015-02-05 11:09     ` Ian Campbell
2015-02-04 21:14   ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 06/35] ACPI: Add Generic Interrupt and Distributor struct parth.dixit
2015-02-04 17:52   ` Stefano Stabellini
2015-02-04 21:16   ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 07/35] ACPI / ACPICA: Add new features for MADT which introduced by ACPI 5.1 parth.dixit
2015-02-04 17:52   ` Stefano Stabellini
2015-02-08 14:27   ` Tomasz Nowicki
2015-02-04 14:01 ` [PATCH RFC 08/35] ACPI / table: Print GIC information when MADT is parsed parth.dixit
2015-02-04 14:01 ` [PATCH RFC 09/35] Add cpumask_next_zero set_cpu_present and possible parth.dixit
2015-02-04 18:47   ` Stefano Stabellini
2015-02-05 11:47     ` Jan Beulich
2015-02-04 21:28   ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 10/35] asm / arm: Introduce cputype.h parth.dixit
2015-02-04 18:56   ` Stefano Stabellini
2015-02-04 21:33   ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 11/35] ARM64 / ACPI: Parse MADT to map logical cpu to MPIDR and get cpu_possible/present_map parth.dixit
2015-02-04 21:44   ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 12/35] ARM64: Initialization of cpu_logical_map(0) parth.dixit
2015-02-04 21:45   ` Julien Grall
2015-02-05 10:26   ` Stefano Stabellini
2015-02-11  5:09     ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 13/35] ACPI: Introduce acpi_parse_entries parth.dixit
2015-02-05 10:29   ` Stefano Stabellini
2015-02-11  5:26     ` Julien Grall
2015-02-04 14:01 ` [PATCH RFC 14/35] ACPI / ACPICA: Add GTDT support updated by ACPI 5.1 parth.dixit
2015-02-05 13:22   ` Stefano Stabellini
2015-02-04 14:01 ` [PATCH RFC 15/35] ARM64 / ACPI: Define ACPI_IRQ_MODEL_GIC needed for arm parth.dixit
2015-02-05 14:39   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 16/35] ARM64 / ACPI: Parse GTDT to initialize timer parth.dixit
2015-02-04 21:51   ` Julien Grall
2015-02-05 11:39     ` Ian Campbell
2015-02-05 14:26       ` Julien Grall
2015-02-05 14:51       ` Stefano Stabellini
2015-02-05 14:55         ` Ian Campbell
2015-02-05 14:46   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 17/35] pl011: Initialize serial from ACPI SPCR table parth.dixit
2015-02-04 21:57   ` Julien Grall
2015-02-05 11:42     ` Ian Campbell
2015-02-05 14:29       ` Julien Grall
2015-02-05 14:52         ` Ian Campbell
2015-02-11  6:10           ` Julien Grall
2015-02-05 15:27   ` Stefano Stabellini
2015-02-05 15:32     ` Ian Campbell
2015-02-04 14:02 ` [PATCH RFC 18/35] arm : add helper function for setting interrupt type parth.dixit
2015-02-04 21:59   ` Julien Grall
2015-02-05 15:33   ` Stefano Stabellini
2015-02-11  6:12     ` Julien Grall
2015-02-04 14:02 ` [PATCH RFC 19/35] ACPI / GICv2: Add GIC specific ACPI boot support parth.dixit
2015-02-04 14:43   ` G Gregory
2015-02-05  6:26     ` Parth Dixit
2015-02-05  3:41   ` Julien Grall
2015-02-05 15:54   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 20/35] xen/arm: Prepare a min DT for DOM0 parth.dixit
2015-02-05  3:48   ` Julien Grall
2015-02-05 15:58   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 21/35] xen/arm: Create memory node " parth.dixit
2015-02-05  3:51   ` Julien Grall
2015-02-05 16:01   ` Stefano Stabellini
2015-02-11  6:27     ` Julien Grall
2015-02-04 14:02 ` [PATCH RFC 22/35] xen/arm: Create chosen " parth.dixit
2015-02-05 16:09   ` Stefano Stabellini
2015-02-06  0:29     ` Julien Grall
2015-02-06 14:09       ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 23/35] arm: acpi add status override table parth.dixit
2015-02-05 16:14   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 24/35] arm : acpi add xen environment table parth.dixit
2015-02-05 16:16   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 25/35] arm: acpi add helper functions to map memory regions parth.dixit
2015-02-05  4:03   ` Julien Grall
2015-02-05 16:21     ` Stefano Stabellini
2015-02-06  0:35       ` Julien Grall
2015-02-06 14:12         ` Stefano Stabellini
2015-02-11  6:49           ` Julien Grall
2015-02-04 14:02 ` [PATCH RFC 26/35] arm : acpi read mmio tables from uefi parth.dixit
2015-02-05  4:17   ` Julien Grall
2015-02-05 16:34   ` Stefano Stabellini
2015-02-06  0:38     ` Julien Grall
2015-02-06 14:17       ` Stefano Stabellini
2015-02-11  9:14         ` Julien Grall
2015-02-04 14:02 ` [PATCH RFC 27/35] arm: acpi map mmio regions to dom0 parth.dixit
2015-02-05 16:49   ` Stefano Stabellini
2015-02-05 19:40     ` Parth Dixit
2015-02-06  0:44       ` Julien Grall
2015-02-06 14:21         ` Stefano Stabellini
2015-02-11  9:26   ` Julien Grall
2015-02-04 14:02 ` [PATCH RFC 28/35] arm: acpi map acpi tables in dom0 parth.dixit
2015-02-05  4:29   ` Julien Grall
2015-02-05 16:55   ` Stefano Stabellini
2015-02-05 19:38     ` Parth Dixit
2015-02-06 14:23       ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 29/35] arm : acpi enable PSCI and hvc in acpi FADT table parth.dixit
2015-02-05  4:33   ` Julien Grall
2015-02-05 17:12   ` Stefano Stabellini
2015-02-06  0:47     ` Julien Grall
2015-02-06 15:13       ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 30/35] arm : acpi map XSDT table to dom0 parth.dixit
2015-02-05  4:46   ` Julien Grall
2015-02-05 17:24   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 31/35] arm : acpi map status override " parth.dixit
2015-02-05  5:24   ` Julien Grall
2015-02-05 10:57     ` Parth Dixit
2015-02-05 11:47       ` Ian Campbell
2015-02-11  9:45         ` Julien Grall
2015-02-12  6:50           ` Stefano Stabellini
2015-02-05 14:39       ` Julien Grall
2015-02-05 17:39         ` Stefano Stabellini
2015-02-06  0:54           ` Julien Grall
2015-02-06 14:32             ` Stefano Stabellini
2015-02-05 17:27   ` Stefano Stabellini
2015-02-04 14:02 ` [PATCH RFC 32/35] arm : acpi map xen environment " parth.dixit
2015-02-05  5:29   ` Julien Grall
2015-02-05 10:49     ` Parth Dixit
2015-02-05 17:36   ` Stefano Stabellini
2015-02-06  0:57     ` Julien Grall
2015-02-04 14:02 ` [PATCH RFC 33/35] arm : acpi enable efi for acpi parth.dixit
2015-02-05  5:31   ` Julien Grall
2015-02-05 10:32     ` Parth Dixit
2015-02-05 11:58     ` Jan Beulich
2015-02-05 12:05       ` Ian Campbell
2015-02-11  9:57         ` Julien Grall
2015-02-11 10:31           ` Jan Beulich
2015-02-11 14:34             ` Julien Grall
2015-02-11  9:51   ` Usage of efi_enabled - Was: " Julien Grall
2015-02-11 10:28     ` Jan Beulich
2015-02-11 10:49       ` Ian Campbell
2015-02-11 11:22         ` Jan Beulich
2015-02-12  4:18           ` Ian Campbell
2015-02-04 14:02 ` [PATCH RFC 34/35] arm : acpi workarounds for firmware/linux dependencies parth.dixit
2015-02-05  5:38   ` Julien Grall
2015-02-05 10:30     ` Parth Dixit
2015-02-05 14:59       ` Julien Grall [this message]
2015-02-10  9:38         ` Julien Grall
2015-02-10 10:01           ` Jan Beulich
2015-02-10 10:26             ` Julien Grall
2015-02-05 17:48   ` Stefano Stabellini
2015-02-05 19:30     ` Parth Dixit
2015-02-06 14:38       ` Stefano Stabellini
2015-02-06 14:49         ` Jan Beulich
2015-02-04 14:02 ` [PATCH RFC 35/35] xen: arm64: Add ACPI support parth.dixit
2015-02-04 16:38 ` [PATCH RFC 00/35] Add ACPI support for arm64 on Xen Julien Grall

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=54D3854E.20702@linaro.org \
    --to=julien.grall@linaro.org \
    --cc=christoffer.dall@linaro.org \
    --cc=ian.campbell@citrix.com \
    --cc=jbeulich@suse.com \
    --cc=parth.dixit@linaro.org \
    --cc=stefano.stabellini@citrix.com \
    --cc=tim@xen.org \
    --cc=xen-devel@lists.xen.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.