* [PATCH] math-emu/setcc: avoid gcc extension
@ 2007-01-07 6:19 Randy Dunlap
2007-01-07 13:27 ` Segher Boessenkool
0 siblings, 1 reply; 10+ messages in thread
From: Randy Dunlap @ 2007-01-07 6:19 UTC (permalink / raw)
To: lkml; +Cc: segher, akpm
From: Randy Dunlap <randy.dunlap@oracle.com>
setcc() in math-emu is written as a gcc extension statement expression
macro that returns a value. However, it's not used that way and it's
not needed like that, so just make it a do-while non-extension macro
so that we don't use an extension when it's not needed.
All 4 .c files that use setcc() produce the same code after this patch.
Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com>
---
arch/i386/math-emu/status_w.h | 5 +++--
---
arch/i386/math-emu/status_w.h | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
--- linux-2620-rc2.orig/arch/i386/math-emu/status_w.h
+++ linux-2620-rc2/arch/i386/math-emu/status_w.h
@@ -48,9 +48,10 @@
#define status_word() \
((partial_status & ~SW_Top & 0xffff) | ((top << SW_Top_Shift) & SW_Top))
-#define setcc(cc) ({ \
+#define setcc(cc) do { \
partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
- partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
+ partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); } \
+ while (0)
#ifdef PECULIAR_486
/* Default, this conveys no information, but an 80486 does it. */
---
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 6:19 [PATCH] math-emu/setcc: avoid gcc extension Randy Dunlap
@ 2007-01-07 13:27 ` Segher Boessenkool
2007-01-07 18:45 ` Randy Dunlap
0 siblings, 1 reply; 10+ messages in thread
From: Segher Boessenkool @ 2007-01-07 13:27 UTC (permalink / raw)
To: Randy Dunlap; +Cc: akpm, lkml
> setcc() in math-emu is written as a gcc extension statement expression
> macro that returns a value. However, it's not used that way and it's
> not needed like that, so just make it a do-while non-extension macro
> so that we don't use an extension when it's not needed.
Looks fine, except
> -#define setcc(cc) ({ \
> +#define setcc(cc) do { \
> partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
> - partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
> + partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); } \
> + while (0)
closing brace on the "while" line, please.
Segher
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 13:27 ` Segher Boessenkool
@ 2007-01-07 18:45 ` Randy Dunlap
2007-01-07 19:12 ` Segher Boessenkool
0 siblings, 1 reply; 10+ messages in thread
From: Randy Dunlap @ 2007-01-07 18:45 UTC (permalink / raw)
To: Segher Boessenkool; +Cc: akpm, lkml
On Sun, 7 Jan 2007 14:27:32 +0100 Segher Boessenkool wrote:
> closing brace on the "while" line, please.
---
From: Randy Dunlap <randy.dunlap@oracle.com>
setcc() in math-emu is written as a gcc extension statement expression
macro that returns a value. However, it's not used that way and it's
not needed like that, so just make it a do-while non-extension macro
so that we don't use an extension when it's not needed.
Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com>
---
arch/i386/math-emu/status_w.h | 5 +++--
---
arch/i386/math-emu/status_w.h | 5 +++--
1 file changed, 3 insertions(+), 2 deletions(-)
--- linux-2620-rc2.orig/arch/i386/math-emu/status_w.h
+++ linux-2620-rc2/arch/i386/math-emu/status_w.h
@@ -48,9 +48,10 @@
#define status_word() \
((partial_status & ~SW_Top & 0xffff) | ((top << SW_Top_Shift) & SW_Top))
-#define setcc(cc) ({ \
+#define setcc(cc) do { \
partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
- partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
+ partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); \
+ } while (0)
#ifdef PECULIAR_486
/* Default, this conveys no information, but an 80486 does it. */
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 18:45 ` Randy Dunlap
@ 2007-01-07 19:12 ` Segher Boessenkool
2007-01-07 19:19 ` Randy Dunlap
0 siblings, 1 reply; 10+ messages in thread
From: Segher Boessenkool @ 2007-01-07 19:12 UTC (permalink / raw)
To: Randy Dunlap; +Cc: akpm, lkml
> -#define setcc(cc) ({ \
> +#define setcc(cc) do { \
> partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
> - partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
> + partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); \
> + } while (0)
There's an extra tab in that last line. Could you also
please fix the indenting (use a tab, not spaces) -- I know
it was there originally, but since there are only a few
lines in that file like that... :-)
[You must be tired of me by now, heh]
Thanks,
Segher
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 19:12 ` Segher Boessenkool
@ 2007-01-07 19:19 ` Randy Dunlap
2007-01-07 19:22 ` Robert P. J. Day
` (2 more replies)
0 siblings, 3 replies; 10+ messages in thread
From: Randy Dunlap @ 2007-01-07 19:19 UTC (permalink / raw)
To: Segher Boessenkool; +Cc: akpm, lkml
On Sun, 7 Jan 2007 20:12:42 +0100 Segher Boessenkool wrote:
> There's an extra tab in that last line. Could you also
> please fix the indenting (use a tab, not spaces) -- I know
> it was there originally, but since there are only a few
> lines in that file like that... :-)
how's this one?
---
From: Randy Dunlap <randy.dunlap@oracle.com>
setcc() in math-emu is written as a gcc extension statement expression
macro that returns a value. However, it's not used that way and it's
not needed like that, so just make it a do-while non-extension macro
so that we don't use an extension when it's not needed.
Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com>
---
arch/i386/math-emu/status_w.h | 5 +++--
---
arch/i386/math-emu/status_w.h | 7 ++++---
1 file changed, 4 insertions(+), 3 deletions(-)
--- linux-2620-rc2.orig/arch/i386/math-emu/status_w.h
+++ linux-2620-rc2/arch/i386/math-emu/status_w.h
@@ -48,9 +48,10 @@
#define status_word() \
((partial_status & ~SW_Top & 0xffff) | ((top << SW_Top_Shift) & SW_Top))
-#define setcc(cc) ({ \
- partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
- partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
+#define setcc(cc) do { \
+ partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
+ partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); \
+} while (0)
#ifdef PECULIAR_486
/* Default, this conveys no information, but an 80486 does it. */
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 19:19 ` Randy Dunlap
@ 2007-01-07 19:22 ` Robert P. J. Day
2007-01-07 19:29 ` Segher Boessenkool
2007-01-07 19:58 ` Christoph Hellwig
2 siblings, 0 replies; 10+ messages in thread
From: Robert P. J. Day @ 2007-01-07 19:22 UTC (permalink / raw)
To: Randy Dunlap; +Cc: Segher Boessenkool, akpm, lkml
On Sun, 7 Jan 2007, Randy Dunlap wrote:
> On Sun, 7 Jan 2007 20:12:42 +0100 Segher Boessenkool wrote:
>
> > There's an extra tab in that last line. Could you also
> > please fix the indenting (use a tab, not spaces) -- I know
> > it was there originally, but since there are only a few
> > lines in that file like that... :-)
>
> how's this one?
> ---
> From: Randy Dunlap <randy.dunlap@oracle.com>
>
> setcc() in math-emu is written as a gcc extension statement
> expression macro that returns a value. However, it's not used that
> way and it's not needed like that, so just make it a do-while
> non-extension macro so that we don't use an extension when it's not
> needed.
is that the proposed coding style for macros? if it returns a value,
use "({ })"? if not, use the "do ... while" notation?
rday
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 19:19 ` Randy Dunlap
2007-01-07 19:22 ` Robert P. J. Day
@ 2007-01-07 19:29 ` Segher Boessenkool
2007-01-07 19:30 ` Randy Dunlap
2007-01-07 19:58 ` Christoph Hellwig
2 siblings, 1 reply; 10+ messages in thread
From: Segher Boessenkool @ 2007-01-07 19:29 UTC (permalink / raw)
To: Randy Dunlap; +Cc: akpm, lkml
>> There's an extra tab in that last line. Could you also
>> please fix the indenting (use a tab, not spaces) -- I know
>> it was there originally, but since there are only a few
>> lines in that file like that... :-)
>
> how's this one?
I meant fix all the wrongly indented lines in that file (there
are only a few, and all around where you're patching anyway).
Care for one extra time? :-)
Segher
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 19:29 ` Segher Boessenkool
@ 2007-01-07 19:30 ` Randy Dunlap
0 siblings, 0 replies; 10+ messages in thread
From: Randy Dunlap @ 2007-01-07 19:30 UTC (permalink / raw)
To: Segher Boessenkool; +Cc: akpm, lkml
On Sun, 7 Jan 2007 20:29:21 +0100 Segher Boessenkool wrote:
> >> There's an extra tab in that last line. Could you also
> >> please fix the indenting (use a tab, not spaces) -- I know
> >> it was there originally, but since there are only a few
> >> lines in that file like that... :-)
> >
> > how's this one?
>
> I meant fix all the wrongly indented lines in that file (there
> are only a few, and all around where you're patching anyway).
>
> Care for one extra time? :-)
Not really. That should be a different patch IMO.
---
~Randy
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 19:19 ` Randy Dunlap
2007-01-07 19:22 ` Robert P. J. Day
2007-01-07 19:29 ` Segher Boessenkool
@ 2007-01-07 19:58 ` Christoph Hellwig
2007-01-07 21:07 ` Randy Dunlap
2 siblings, 1 reply; 10+ messages in thread
From: Christoph Hellwig @ 2007-01-07 19:58 UTC (permalink / raw)
To: Randy Dunlap; +Cc: Segher Boessenkool, akpm, lkml
On Sun, Jan 07, 2007 at 11:19:00AM -0800, Randy Dunlap wrote:
> On Sun, 7 Jan 2007 20:12:42 +0100 Segher Boessenkool wrote:
>
> > There's an extra tab in that last line. Could you also
> > please fix the indenting (use a tab, not spaces) -- I know
> > it was there originally, but since there are only a few
> > lines in that file like that... :-)
>
> how's this one?
> ---
> From: Randy Dunlap <randy.dunlap@oracle.com>
>
> setcc() in math-emu is written as a gcc extension statement expression
> macro that returns a value. However, it's not used that way and it's
> not needed like that, so just make it a do-while non-extension macro
> so that we don't use an extension when it's not needed.
>
> Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com>
> ---
> arch/i386/math-emu/status_w.h | 5 +++--
>
> ---
> arch/i386/math-emu/status_w.h | 7 ++++---
> 1 file changed, 4 insertions(+), 3 deletions(-)
>
> --- linux-2620-rc2.orig/arch/i386/math-emu/status_w.h
> +++ linux-2620-rc2/arch/i386/math-emu/status_w.h
> @@ -48,9 +48,10 @@
>
> #define status_word() \
> ((partial_status & ~SW_Top & 0xffff) | ((top << SW_Top_Shift) & SW_Top))
> -#define setcc(cc) ({ \
> - partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
> - partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
> +#define setcc(cc) do { \
> + partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
> + partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); \
> +} while (0)
Is there any reason you this shouldn't be an inline function?
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] math-emu/setcc: avoid gcc extension
2007-01-07 19:58 ` Christoph Hellwig
@ 2007-01-07 21:07 ` Randy Dunlap
0 siblings, 0 replies; 10+ messages in thread
From: Randy Dunlap @ 2007-01-07 21:07 UTC (permalink / raw)
To: Christoph Hellwig; +Cc: Segher Boessenkool, akpm, lkml
On Sun, 7 Jan 2007 19:58:45 +0000 Christoph Hellwig wrote:
> On Sun, Jan 07, 2007 at 11:19:00AM -0800, Randy Dunlap wrote:
> > On Sun, 7 Jan 2007 20:12:42 +0100 Segher Boessenkool wrote:
> >
> > > There's an extra tab in that last line. Could you also
> > > please fix the indenting (use a tab, not spaces) -- I know
> > > it was there originally, but since there are only a few
> > > lines in that file like that... :-)
> >
> > how's this one?
> > ---
> > From: Randy Dunlap <randy.dunlap@oracle.com>
> >
> > setcc() in math-emu is written as a gcc extension statement expression
> > macro that returns a value. However, it's not used that way and it's
> > not needed like that, so just make it a do-while non-extension macro
> > so that we don't use an extension when it's not needed.
> >
> > Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com>
> > ---
> > arch/i386/math-emu/status_w.h | 5 +++--
> >
> > ---
> > arch/i386/math-emu/status_w.h | 7 ++++---
> > 1 file changed, 4 insertions(+), 3 deletions(-)
> >
> > --- linux-2620-rc2.orig/arch/i386/math-emu/status_w.h
> > +++ linux-2620-rc2/arch/i386/math-emu/status_w.h
> > @@ -48,9 +48,10 @@
> >
> > #define status_word() \
> > ((partial_status & ~SW_Top & 0xffff) | ((top << SW_Top_Shift) & SW_Top))
> > -#define setcc(cc) ({ \
> > - partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
> > - partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
> > +#define setcc(cc) do { \
> > + partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
> > + partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); \
> > +} while (0)
>
> Is there any reason you this shouldn't be an inline function?
That would be OK in theory, so I just tried it.
I don't get the same object files produced with an inline function
(for arch/i386/math-emu/fpu_etc.o), so I don't feel that it's quite
as safe without digging deeping into the .o file and its changes.
The 3 other .o files that use setcc() were the same when using
the inline patch version.
---
From: Randy Dunlap <randy.dunlap@oracle.com>
setcc() in math-emu is written as a gcc extension statement expression
macro that returns a value. However, it's not used that way and it's
not needed like that, so just make it a do-while non-extension macro
so that we don't use an extension when it's not needed.
Signed-off-by: Randy Dunlap <randy.dunlap@oracle.com>
---
arch/i386/math-emu/status_w.h | 5 +++--
---
arch/i386/math-emu/status_w.h | 8 +++++---
1 file changed, 5 insertions(+), 3 deletions(-)
--- linux-2620-rc2.orig/arch/i386/math-emu/status_w.h
+++ linux-2620-rc2/arch/i386/math-emu/status_w.h
@@ -48,9 +48,11 @@
#define status_word() \
((partial_status & ~SW_Top & 0xffff) | ((top << SW_Top_Shift) & SW_Top))
-#define setcc(cc) ({ \
- partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3); \
- partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3); })
+static inline void setcc(int cc)
+{
+ partial_status &= ~(SW_C0|SW_C1|SW_C2|SW_C3);
+ partial_status |= (cc) & (SW_C0|SW_C1|SW_C2|SW_C3);
+}
#ifdef PECULIAR_486
/* Default, this conveys no information, but an 80486 does it. */
^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2007-01-07 21:08 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-01-07 6:19 [PATCH] math-emu/setcc: avoid gcc extension Randy Dunlap
2007-01-07 13:27 ` Segher Boessenkool
2007-01-07 18:45 ` Randy Dunlap
2007-01-07 19:12 ` Segher Boessenkool
2007-01-07 19:19 ` Randy Dunlap
2007-01-07 19:22 ` Robert P. J. Day
2007-01-07 19:29 ` Segher Boessenkool
2007-01-07 19:30 ` Randy Dunlap
2007-01-07 19:58 ` Christoph Hellwig
2007-01-07 21:07 ` Randy Dunlap
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox