* [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
@ 2016-08-02 8:07 Christophe Leroy
2016-08-02 12:41 ` Segher Boessenkool
` (3 more replies)
0 siblings, 4 replies; 11+ messages in thread
From: Christophe Leroy @ 2016-08-02 8:07 UTC (permalink / raw)
To: Benjamin Herrenschmidt, Paul Mackerras, Michael Ellerman, Scott Wood
Cc: linux-kernel, linuxppc-dev, stable, antoine.blangy, segher
commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
based on copy_tofrom_user()") introduced a bug when destination
address is odd and initial csum is not null
In that (rare) case the initial csum value has to be rotated one byte
as well as the resulting value is
This patch also fixes related comments
Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
based on copy_tofrom_user()")
Cc: stable@vger.kernel.org
Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
---
v2: updated comments as suggested by Segher
arch/powerpc/lib/checksum_32.S | 7 ++++---
1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/arch/powerpc/lib/checksum_32.S b/arch/powerpc/lib/checksum_32.S
index d90870a..0a57fe6 100644
--- a/arch/powerpc/lib/checksum_32.S
+++ b/arch/powerpc/lib/checksum_32.S
@@ -127,8 +127,9 @@ _GLOBAL(csum_partial_copy_generic)
stw r7,12(r1)
stw r8,8(r1)
- andi. r0,r4,1 /* is destination address even ? */
- cmplwi cr7,r0,0
+ rlwinm r0,r4,3,0x8
+ rlwnm r6,r6,r0,0,31 /* odd destination address: rotate one byte */
+ cmplwi cr7,r0,0 /* is destination address even ? */
addic r12,r6,0
addi r6,r4,-4
neg r0,r4
@@ -237,7 +238,7 @@ _GLOBAL(csum_partial_copy_generic)
66: addze r3,r12
addi r1,r1,16
beqlr+ cr7
- rlwinm r3,r3,8,0,31 /* swap bytes for odd destination */
+ rlwinm r3,r3,8,0,31 /* odd destination address: rotate one byte */
blr
/* read fault */
--
2.1.0
^ permalink raw reply related [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-02 8:07 [PATCH v2] powerpc/32: fix csum_partial_copy_generic() Christophe Leroy
@ 2016-08-02 12:41 ` Segher Boessenkool
2016-08-02 12:51 ` Segher Boessenkool
` (2 subsequent siblings)
3 siblings, 0 replies; 11+ messages in thread
From: Segher Boessenkool @ 2016-08-02 12:41 UTC (permalink / raw)
To: Christophe Leroy
Cc: Benjamin Herrenschmidt, Paul Mackerras, Michael Ellerman,
Scott Wood, linux-kernel, linuxppc-dev, stable, antoine.blangy
On Tue, Aug 02, 2016 at 10:07:05AM +0200, Christophe Leroy wrote:
> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
> based on copy_tofrom_user()") introduced a bug when destination
> address is odd and initial csum is not null
>
> In that (rare) case the initial csum value has to be rotated one byte
> as well as the resulting value is
>
> This patch also fixes related comments
>
> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
> based on copy_tofrom_user()")
> Cc: stable@vger.kernel.org
>
> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
> ---
> v2: updated comments as suggested by Segher
Thanks. It looks good to me now.
Segher
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-02 8:07 [PATCH v2] powerpc/32: fix csum_partial_copy_generic() Christophe Leroy
2016-08-02 12:41 ` Segher Boessenkool
@ 2016-08-02 12:51 ` Segher Boessenkool
2016-08-04 3:53 ` Scott Wood
2016-08-10 12:46 ` [v2] " Michael Ellerman
3 siblings, 0 replies; 11+ messages in thread
From: Segher Boessenkool @ 2016-08-02 12:51 UTC (permalink / raw)
To: Christophe Leroy
Cc: Benjamin Herrenschmidt, Paul Mackerras, Michael Ellerman,
Scott Wood, linux-kernel, linuxppc-dev, stable, antoine.blangy
On Tue, Aug 02, 2016 at 10:07:05AM +0200, Christophe Leroy wrote:
> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
> based on copy_tofrom_user()") introduced a bug when destination
> address is odd and initial csum is not null
>
> In that (rare) case the initial csum value has to be rotated one byte
> as well as the resulting value is
>
> This patch also fixes related comments
>
> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
> based on copy_tofrom_user()")
> Cc: stable@vger.kernel.org
>
> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
> ---
> v2: updated comments as suggested by Segher
This looks good to me now, thanks,
Segher
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-02 8:07 [PATCH v2] powerpc/32: fix csum_partial_copy_generic() Christophe Leroy
2016-08-02 12:41 ` Segher Boessenkool
2016-08-02 12:51 ` Segher Boessenkool
@ 2016-08-04 3:53 ` Scott Wood
2016-08-04 6:15 ` Alessio Igor Bogani
2016-08-10 12:46 ` [v2] " Michael Ellerman
3 siblings, 1 reply; 11+ messages in thread
From: Scott Wood @ 2016-08-04 3:53 UTC (permalink / raw)
To: Christophe Leroy, Benjamin Herrenschmidt, Paul Mackerras,
Michael Ellerman
Cc: linux-kernel, linuxppc-dev, stable, antoine.blangy, segher,
Alessio Igor Bogani
On Tue, 2016-08-02 at 10:07 +0200, Christophe Leroy wrote:
> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
> based on copy_tofrom_user()") introduced a bug when destination
> address is odd and initial csum is not null
>
> In that (rare) case the initial csum value has to be rotated one byte
> as well as the resulting value is
>
> This patch also fixes related comments
>
> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
> based on copy_tofrom_user()")
> Cc: stable@vger.kernel.org
>
> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
> ---
> v2: updated comments as suggested by Segher
>
> arch/powerpc/lib/checksum_32.S | 7 ++++---
> 1 file changed, 4 insertions(+), 3 deletions(-)
Alessio, can you confirm whether this fixes the problem you reported?
-Scott
>
> diff --git a/arch/powerpc/lib/checksum_32.S b/arch/powerpc/lib/checksum_32.S
> index d90870a..0a57fe6 100644
> --- a/arch/powerpc/lib/checksum_32.S
> +++ b/arch/powerpc/lib/checksum_32.S
> @@ -127,8 +127,9 @@ _GLOBAL(csum_partial_copy_generic)
> stw r7,12(r1)
> stw r8,8(r1)
>
> - andi. r0,r4,1 /* is destination
> address even ? */
> - cmplwi cr7,r0,0
> + rlwinm r0,r4,3,0x8
> + rlwnm r6,r6,r0,0,31 /* odd destination address:
> rotate one byte */
> + cmplwi cr7,r0,0 /* is destination address even ? */
> addic r12,r6,0
> addi r6,r4,-4
> neg r0,r4
> @@ -237,7 +238,7 @@ _GLOBAL(csum_partial_copy_generic)
> 66: addze r3,r12
> addi r1,r1,16
> beqlr+ cr7
> - rlwinm r3,r3,8,0,31 /* swap bytes for odd destination
> */
> + rlwinm r3,r3,8,0,31 /* odd destination address:
> rotate one byte */
> blr
>
> /* read fault */
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-04 3:53 ` Scott Wood
@ 2016-08-04 6:15 ` Alessio Igor Bogani
2016-08-05 6:57 ` Michael Ellerman
0 siblings, 1 reply; 11+ messages in thread
From: Alessio Igor Bogani @ 2016-08-04 6:15 UTC (permalink / raw)
To: Scott Wood
Cc: Christophe Leroy, Benjamin Herrenschmidt, Paul Mackerras,
Michael Ellerman, LKML, linuxppc-dev, stable, antoine.blangy,
segher
Scott,
On 4 August 2016 at 05:53, Scott Wood <oss@buserror.net> wrote:
> On Tue, 2016-08-02 at 10:07 +0200, Christophe Leroy wrote:
>> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>> based on copy_tofrom_user()") introduced a bug when destination
>> address is odd and initial csum is not null
>>
>> In that (rare) case the initial csum value has to be rotated one byte
>> as well as the resulting value is
>>
>> This patch also fixes related comments
>>
>> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>> based on copy_tofrom_user()")
>> Cc: stable@vger.kernel.org
>>
>> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
>> ---
>> v2: updated comments as suggested by Segher
>>
>> arch/powerpc/lib/checksum_32.S | 7 ++++---
>> 1 file changed, 4 insertions(+), 3 deletions(-)
>
> Alessio, can you confirm whether this fixes the problem you reported?
No unfortunately.
Ciao,
Alessio
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-04 6:15 ` Alessio Igor Bogani
@ 2016-08-05 6:57 ` Michael Ellerman
2016-08-05 7:26 ` Christophe Leroy
0 siblings, 1 reply; 11+ messages in thread
From: Michael Ellerman @ 2016-08-05 6:57 UTC (permalink / raw)
To: Alessio Igor Bogani, Scott Wood
Cc: Christophe Leroy, Benjamin Herrenschmidt, Paul Mackerras, LKML,
linuxppc-dev, stable, antoine.blangy, segher
Alessio Igor Bogani <alessio.bogani@elettra.eu> writes:
> On 4 August 2016 at 05:53, Scott Wood <oss@buserror.net> wrote:
>> On Tue, 2016-08-02 at 10:07 +0200, Christophe Leroy wrote:
>>> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>> based on copy_tofrom_user()") introduced a bug when destination
>>> address is odd and initial csum is not null
>>>
>>> In that (rare) case the initial csum value has to be rotated one byte
>>> as well as the resulting value is
>>>
>>> This patch also fixes related comments
>>>
>>> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>> based on copy_tofrom_user()")
>>> Cc: stable@vger.kernel.org
>>>
>>> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
>>> ---
>>> v2: updated comments as suggested by Segher
>>>
>>> arch/powerpc/lib/checksum_32.S | 7 ++++---
>>> 1 file changed, 4 insertions(+), 3 deletions(-)
>>
>> Alessio, can you confirm whether this fixes the problem you reported?
>
> No unfortunately.
Thanks for testing.
I've dropped the patch for now, send me a new one that works.
cheers
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-05 6:57 ` Michael Ellerman
@ 2016-08-05 7:26 ` Christophe Leroy
0 siblings, 0 replies; 11+ messages in thread
From: Christophe Leroy @ 2016-08-05 7:26 UTC (permalink / raw)
To: Michael Ellerman, Alessio Igor Bogani, Scott Wood
Cc: Benjamin Herrenschmidt, Paul Mackerras, LKML, linuxppc-dev,
stable, antoine.blangy, segher
Le 05/08/2016 à 08:57, Michael Ellerman a écrit :
> Alessio Igor Bogani <alessio.bogani@elettra.eu> writes:
>> On 4 August 2016 at 05:53, Scott Wood <oss@buserror.net> wrote:
>>> On Tue, 2016-08-02 at 10:07 +0200, Christophe Leroy wrote:
>>>> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>>> based on copy_tofrom_user()") introduced a bug when destination
>>>> address is odd and initial csum is not null
>>>>
>>>> In that (rare) case the initial csum value has to be rotated one byte
>>>> as well as the resulting value is
>>>>
>>>> This patch also fixes related comments
>>>>
>>>> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>>> based on copy_tofrom_user()")
>>>> Cc: stable@vger.kernel.org
>>>>
>>>> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
>>>> ---
>>>> v2: updated comments as suggested by Segher
>>>>
>>>> arch/powerpc/lib/checksum_32.S | 7 ++++---
>>>> 1 file changed, 4 insertions(+), 3 deletions(-)
>>> Alessio, can you confirm whether this fixes the problem you reported?
>> No unfortunately.
> Thanks for testing.
>
> I've dropped the patch for now, send me a new one that works.
>
>
The purpose of this patch was not to address Alessio's issue, but to fix
a huge issue on checksum calculation which induces breakdown of TCP
connections.
I think it is worth commiting it upstream and on impacted stable
releases, allthought we don't have yet identified the issue Alessio's has.
Christophe
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
@ 2016-08-05 7:26 ` Christophe Leroy
0 siblings, 0 replies; 11+ messages in thread
From: Christophe Leroy @ 2016-08-05 7:26 UTC (permalink / raw)
To: Michael Ellerman, Alessio Igor Bogani, Scott Wood
Cc: Benjamin Herrenschmidt, Paul Mackerras, LKML, linuxppc-dev,
stable, antoine.blangy, segher
Le 05/08/2016 � 08:57, Michael Ellerman a �crit :
> Alessio Igor Bogani <alessio.bogani@elettra.eu> writes:
>> On 4 August 2016 at 05:53, Scott Wood <oss@buserror.net> wrote:
>>> On Tue, 2016-08-02 at 10:07 +0200, Christophe Leroy wrote:
>>>> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>>> based on copy_tofrom_user()") introduced a bug when destination
>>>> address is odd and initial csum is not null
>>>>
>>>> In that (rare) case the initial csum value has to be rotated one byte
>>>> as well as the resulting value is
>>>>
>>>> This patch also fixes related comments
>>>>
>>>> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>>> based on copy_tofrom_user()")
>>>> Cc: stable@vger.kernel.org
>>>>
>>>> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
>>>> ---
>>>> v2: updated comments as suggested by Segher
>>>>
>>>> arch/powerpc/lib/checksum_32.S | 7 ++++---
>>>> 1 file changed, 4 insertions(+), 3 deletions(-)
>>> Alessio, can you confirm whether this fixes the problem you reported?
>> No unfortunately.
> Thanks for testing.
>
> I've dropped the patch for now, send me a new one that works.
>
>
The purpose of this patch was not to address Alessio's issue, but to fix
a huge issue on checksum calculation which induces breakdown of TCP
connections.
I think it is worth commiting it upstream and on impacted stable
releases, allthought we don't have yet identified the issue Alessio's has.
Christophe
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-05 7:26 ` Christophe Leroy
@ 2016-08-05 9:38 ` Michael Ellerman
-1 siblings, 0 replies; 11+ messages in thread
From: Michael Ellerman @ 2016-08-05 9:38 UTC (permalink / raw)
To: Christophe Leroy, Alessio Igor Bogani, Scott Wood
Cc: Benjamin Herrenschmidt, Paul Mackerras, LKML, linuxppc-dev,
stable, antoine.blangy, segher
Christophe Leroy <christophe.leroy@c-s.fr> writes:
> Le 05/08/2016 à 08:57, Michael Ellerman a écrit :
>> Alessio Igor Bogani <alessio.bogani@elettra.eu> writes:
>>> On 4 August 2016 at 05:53, Scott Wood <oss@buserror.net> wrote:
>>>> On Tue, 2016-08-02 at 10:07 +0200, Christophe Leroy wrote:
>>>>> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>>>> based on copy_tofrom_user()") introduced a bug when destination
>>>>> address is odd and initial csum is not null
>>>>>
>
> The purpose of this patch was not to address Alessio's issue, but to fix
> a huge issue on checksum calculation which induces breakdown of TCP
> connections.
>
> I think it is worth commiting it upstream and on impacted stable
> releases, allthought we don't have yet identified the issue Alessio's has.
OK. I'll put it back into fixes on Monday if I haven't heard anything
further.
cheers
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [PATCH v2] powerpc/32: fix csum_partial_copy_generic()
@ 2016-08-05 9:38 ` Michael Ellerman
0 siblings, 0 replies; 11+ messages in thread
From: Michael Ellerman @ 2016-08-05 9:38 UTC (permalink / raw)
To: Christophe Leroy, Alessio Igor Bogani, Scott Wood
Cc: Benjamin Herrenschmidt, Paul Mackerras, LKML, linuxppc-dev,
stable, antoine.blangy, segher
Christophe Leroy <christophe.leroy@c-s.fr> writes:
> Le 05/08/2016 =C3=A0 08:57, Michael Ellerman a =C3=A9crit :
>> Alessio Igor Bogani <alessio.bogani@elettra.eu> writes:
>>> On 4 August 2016 at 05:53, Scott Wood <oss@buserror.net> wrote:
>>>> On Tue, 2016-08-02 at 10:07 +0200, Christophe Leroy wrote:
>>>>> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
>>>>> based on copy_tofrom_user()") introduced a bug when destination
>>>>> address is odd and initial csum is not null
>>>>>
>
> The purpose of this patch was not to address Alessio's issue, but to fix=
=20
> a huge issue on checksum calculation which induces breakdown of TCP=20
> connections.
>
> I think it is worth commiting it upstream and on impacted stable=20
> releases, allthought we don't have yet identified the issue Alessio's has.
OK. I'll put it back into fixes on Monday if I haven't heard anything
further.
cheers
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: [v2] powerpc/32: fix csum_partial_copy_generic()
2016-08-02 8:07 [PATCH v2] powerpc/32: fix csum_partial_copy_generic() Christophe Leroy
` (2 preceding siblings ...)
2016-08-04 3:53 ` Scott Wood
@ 2016-08-10 12:46 ` Michael Ellerman
3 siblings, 0 replies; 11+ messages in thread
From: Michael Ellerman @ 2016-08-10 12:46 UTC (permalink / raw)
To: Christophe Leroy, Benjamin Herrenschmidt, Paul Mackerras, Scott Wood
Cc: antoine.blangy, linuxppc-dev, linux-kernel, stable
On Tue, 2016-02-08 at 08:07:05 UTC, Christophe Leroy wrote:
> commit 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic()
> based on copy_tofrom_user()") introduced a bug when destination
> address is odd and initial csum is not null
>
> In that (rare) case the initial csum value has to be rotated one byte
> as well as the resulting value is
>
> This patch also fixes related comments
>
> Fixes: 7aef4136566b0 ("powerpc32: rewrite csum_partial_copy_generic() based on copy_tofrom_user()")
> Signed-off-by: Christophe Leroy <christophe.leroy@c-s.fr>
Applied to powerpc fixes, thanks.
https://git.kernel.org/powerpc/c/1bc8b816cb8058c31f61fe7844
cheers
^ permalink raw reply [flat|nested] 11+ messages in thread
end of thread, other threads:[~2016-08-10 19:49 UTC | newest]
Thread overview: 11+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-08-02 8:07 [PATCH v2] powerpc/32: fix csum_partial_copy_generic() Christophe Leroy
2016-08-02 12:41 ` Segher Boessenkool
2016-08-02 12:51 ` Segher Boessenkool
2016-08-04 3:53 ` Scott Wood
2016-08-04 6:15 ` Alessio Igor Bogani
2016-08-05 6:57 ` Michael Ellerman
2016-08-05 7:26 ` Christophe Leroy
2016-08-05 7:26 ` Christophe Leroy
2016-08-05 9:38 ` Michael Ellerman
2016-08-05 9:38 ` Michael Ellerman
2016-08-10 12:46 ` [v2] " Michael Ellerman
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.