* [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