diff mbox

irqchip: GICv3: ITS: don't assume 64K page size in its_alloc_tables

Message ID 1431644545-31904-1-git-send-email-stuart.yoder@freescale.com (mailing list archive)
State New, archived
Headers show

Commit Message

Stuart Yoder May 14, 2015, 11:02 p.m. UTC
its_alloc_tables() needs to account for page sizes other than
64KB.  Without this change, when PAGE_SIZE=4KB its_alloc_tables()
gets stuck in an infinite loop.

Signed-off-by: Stuart Yoder <stuart.yoder@freescale.com>
---

think this should go into 4.1 if at all possible...without it I am
unable to boot a 4.1 kernel on the LS2085 SoC

 drivers/irqchip/irq-gic-v3-its.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Marc Zyngier May 18, 2015, 1:23 p.m. UTC | #1
Hi Stuart,

On 15/05/15 00:02, Stuart Yoder wrote:
> its_alloc_tables() needs to account for page sizes other than
> 64KB.  Without this change, when PAGE_SIZE=4KB its_alloc_tables()
> gets stuck in an infinite loop.
> 
> Signed-off-by: Stuart Yoder <stuart.yoder@freescale.com>
> ---
> 
> think this should go into 4.1 if at all possible...without it I am
> unable to boot a 4.1 kernel on the LS2085 SoC

What you are suggesting here is a effectively a revert of commit
790b57a, which would break other implementations.

Can you please explain the actual issue? I'm failing to see how you end
up in an infinite loop here (the system page size and the ITS base
granule should be completely unrelated...).

Or has it anything to do with Minghuan Lian's patch
(https://lkml.org/lkml/2015/4/16/36), which looks more correct (if still
massively under-documented)?

Thanks,

	M.
> 
>  drivers/irqchip/irq-gic-v3-its.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c
> index 9687f8a..58a6612 100644
> --- a/drivers/irqchip/irq-gic-v3-its.c
> +++ b/drivers/irqchip/irq-gic-v3-its.c
> @@ -800,7 +800,7 @@ static int its_alloc_tables(struct its_node *its)
>  {
>  	int err;
>  	int i;
> -	int psz = SZ_64K;
> +	int psz = PAGE_SIZE;
>  	u64 shr = GITS_BASER_InnerShareable;
>  	u64 cache = GITS_BASER_WaWb;
>  
>
Stuart Yoder May 18, 2015, 1:38 p.m. UTC | #2
> -----Original Message-----
> From: Marc Zyngier [mailto:marc.zyngier@arm.com]
> Sent: Monday, May 18, 2015 8:23 AM
> To: Yoder Stuart-B08248; tglx@linutronix.de
> Cc: linux-arm-kernel@lists.infradead.org
> Subject: Re: [PATCH] irqchip: GICv3: ITS: don't assume 64K page size in its_alloc_tables
> 
> Hi Stuart,
> 
> On 15/05/15 00:02, Stuart Yoder wrote:
> > its_alloc_tables() needs to account for page sizes other than
> > 64KB.  Without this change, when PAGE_SIZE=4KB its_alloc_tables()
> > gets stuck in an infinite loop.
> >
> > Signed-off-by: Stuart Yoder <stuart.yoder@freescale.com>
> > ---
> >
> > think this should go into 4.1 if at all possible...without it I am
> > unable to boot a 4.1 kernel on the LS2085 SoC
> 
> What you are suggesting here is a effectively a revert of commit
> 790b57a, which would break other implementations.
> 
> Can you please explain the actual issue? I'm failing to see how you end
> up in an infinite loop here (the system page size and the ITS base
> granule should be completely unrelated...).

Here is the problem line:

      val |= (alloc_size / psz) - 1;

In our case:
   alloc_size=16K
   psz=64K

...so (alloc_size / psz) = 0, and thus val becomes -1, and everything
is screwed up.  We get stuck in a loop to retry_baser:

Thanks,
Stuart
Marc Zyngier May 18, 2015, 2:09 p.m. UTC | #3
On 18/05/15 14:38, Stuart Yoder wrote:
> 
> 
>> -----Original Message-----
>> From: Marc Zyngier [mailto:marc.zyngier@arm.com]
>> Sent: Monday, May 18, 2015 8:23 AM
>> To: Yoder Stuart-B08248; tglx@linutronix.de
>> Cc: linux-arm-kernel@lists.infradead.org
>> Subject: Re: [PATCH] irqchip: GICv3: ITS: don't assume 64K page size in its_alloc_tables
>>
>> Hi Stuart,
>>
>> On 15/05/15 00:02, Stuart Yoder wrote:
>>> its_alloc_tables() needs to account for page sizes other than
>>> 64KB.  Without this change, when PAGE_SIZE=4KB its_alloc_tables()
>>> gets stuck in an infinite loop.
>>>
>>> Signed-off-by: Stuart Yoder <stuart.yoder@freescale.com>
>>> ---
>>>
>>> think this should go into 4.1 if at all possible...without it I am
>>> unable to boot a 4.1 kernel on the LS2085 SoC
>>
>> What you are suggesting here is a effectively a revert of commit
>> 790b57a, which would break other implementations.
>>
>> Can you please explain the actual issue? I'm failing to see how you end
>> up in an infinite loop here (the system page size and the ITS base
>> granule should be completely unrelated...).
> 
> Here is the problem line:
> 
>       val |= (alloc_size / psz) - 1;
> 
> In our case:
>    alloc_size=16K
>    psz=64K
> 
> ...so (alloc_size / psz) = 0, and thus val becomes -1, and everything
> is screwed up.  We get stuck in a loop to retry_baser:

If alloc_size is 16k, you have an order of 2, and I have to assume this
is an allocation for a device table (otherwise order would be 4). So
things fail because we've computed an alloc_size smaller than what we
want to allocate as a minimum.

Isn't that exactly what Minghuan's patch fixes?

Thanks,

	M.
Stuart Yoder May 18, 2015, 3:33 p.m. UTC | #4
> -----Original Message-----
> From: Marc Zyngier [mailto:marc.zyngier@arm.com]
> Sent: Monday, May 18, 2015 9:09 AM
> To: Yoder Stuart-B08248; tglx@linutronix.de
> Cc: linux-arm-kernel@lists.infradead.org
> Subject: Re: [PATCH] irqchip: GICv3: ITS: don't assume 64K page size in its_alloc_tables
> 
> On 18/05/15 14:38, Stuart Yoder wrote:
> >
> >
> >> -----Original Message-----
> >> From: Marc Zyngier [mailto:marc.zyngier@arm.com]
> >> Sent: Monday, May 18, 2015 8:23 AM
> >> To: Yoder Stuart-B08248; tglx@linutronix.de
> >> Cc: linux-arm-kernel@lists.infradead.org
> >> Subject: Re: [PATCH] irqchip: GICv3: ITS: don't assume 64K page size in its_alloc_tables
> >>
> >> Hi Stuart,
> >>
> >> On 15/05/15 00:02, Stuart Yoder wrote:
> >>> its_alloc_tables() needs to account for page sizes other than
> >>> 64KB.  Without this change, when PAGE_SIZE=4KB its_alloc_tables()
> >>> gets stuck in an infinite loop.
> >>>
> >>> Signed-off-by: Stuart Yoder <stuart.yoder@freescale.com>
> >>> ---
> >>>
> >>> think this should go into 4.1 if at all possible...without it I am
> >>> unable to boot a 4.1 kernel on the LS2085 SoC
> >>
> >> What you are suggesting here is a effectively a revert of commit
> >> 790b57a, which would break other implementations.
> >>
> >> Can you please explain the actual issue? I'm failing to see how you end
> >> up in an infinite loop here (the system page size and the ITS base
> >> granule should be completely unrelated...).
> >
> > Here is the problem line:
> >
> >       val |= (alloc_size / psz) - 1;
> >
> > In our case:
> >    alloc_size=16K
> >    psz=64K
> >
> > ...so (alloc_size / psz) = 0, and thus val becomes -1, and everything
> > is screwed up.  We get stuck in a loop to retry_baser:
> 
> If alloc_size is 16k, you have an order of 2, and I have to assume this
> is an allocation for a device table (otherwise order would be 4). So
> things fail because we've computed an alloc_size smaller than what we
> want to allocate as a minimum.
> 
> Isn't that exactly what Minghuan's patch fixes?

Yes.  I'll get with Minghuan and between the 2 of us we'll get a properly
commented version of his patch sent out.

Thanks,
Stuart
Marc Zyngier May 18, 2015, 3:36 p.m. UTC | #5
On 18/05/15 16:33, Stuart Yoder wrote:
> 
> 
>> -----Original Message-----
>> From: Marc Zyngier [mailto:marc.zyngier@arm.com]
>> Sent: Monday, May 18, 2015 9:09 AM
>> To: Yoder Stuart-B08248; tglx@linutronix.de
>> Cc: linux-arm-kernel@lists.infradead.org
>> Subject: Re: [PATCH] irqchip: GICv3: ITS: don't assume 64K page size in its_alloc_tables
>>
>> On 18/05/15 14:38, Stuart Yoder wrote:
>>>
>>>
>>>> -----Original Message-----
>>>> From: Marc Zyngier [mailto:marc.zyngier@arm.com]
>>>> Sent: Monday, May 18, 2015 8:23 AM
>>>> To: Yoder Stuart-B08248; tglx@linutronix.de
>>>> Cc: linux-arm-kernel@lists.infradead.org
>>>> Subject: Re: [PATCH] irqchip: GICv3: ITS: don't assume 64K page size in its_alloc_tables
>>>>
>>>> Hi Stuart,
>>>>
>>>> On 15/05/15 00:02, Stuart Yoder wrote:
>>>>> its_alloc_tables() needs to account for page sizes other than
>>>>> 64KB.  Without this change, when PAGE_SIZE=4KB its_alloc_tables()
>>>>> gets stuck in an infinite loop.
>>>>>
>>>>> Signed-off-by: Stuart Yoder <stuart.yoder@freescale.com>
>>>>> ---
>>>>>
>>>>> think this should go into 4.1 if at all possible...without it I am
>>>>> unable to boot a 4.1 kernel on the LS2085 SoC
>>>>
>>>> What you are suggesting here is a effectively a revert of commit
>>>> 790b57a, which would break other implementations.
>>>>
>>>> Can you please explain the actual issue? I'm failing to see how you end
>>>> up in an infinite loop here (the system page size and the ITS base
>>>> granule should be completely unrelated...).
>>>
>>> Here is the problem line:
>>>
>>>       val |= (alloc_size / psz) - 1;
>>>
>>> In our case:
>>>    alloc_size=16K
>>>    psz=64K
>>>
>>> ...so (alloc_size / psz) = 0, and thus val becomes -1, and everything
>>> is screwed up.  We get stuck in a loop to retry_baser:
>>
>> If alloc_size is 16k, you have an order of 2, and I have to assume this
>> is an allocation for a device table (otherwise order would be 4). So
>> things fail because we've computed an alloc_size smaller than what we
>> want to allocate as a minimum.
>>
>> Isn't that exactly what Minghuan's patch fixes?
> 
> Yes.  I'll get with Minghuan and between the 2 of us we'll get a properly
> commented version of his patch sent out.

Thanks Stuart.

	M.
diff mbox

Patch

diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c
index 9687f8a..58a6612 100644
--- a/drivers/irqchip/irq-gic-v3-its.c
+++ b/drivers/irqchip/irq-gic-v3-its.c
@@ -800,7 +800,7 @@  static int its_alloc_tables(struct its_node *its)
 {
 	int err;
 	int i;
-	int psz = SZ_64K;
+	int psz = PAGE_SIZE;
 	u64 shr = GITS_BASER_InnerShareable;
 	u64 cache = GITS_BASER_WaWb;