* 2.4.28-pre2 and ntfs-2.1.6b ?
@ 2004-08-26 20:59 O.Sezer
2004-08-26 22:12 ` Willy Tarreau
0 siblings, 1 reply; 5+ messages in thread
From: O.Sezer @ 2004-08-26 20:59 UTC (permalink / raw)
To: linux-kernel
Hi all:
With 2.4.28-pre2, ntfs-2.1.6b from linux-ntfs site
started failing to compile at aops.c:
aops.c: In function `ntfs_read_block':
aops.c:315: parse error before "else"
-- or in case of gcc3.4 --
aops.c:315: error: syntax error before "else"
This happens with gcc-3.2.2 and gcc-3.4.0
and can be fixed by:
--- aops.c.BAK 2004-08-26 19:35:11.000000000 +0300
+++ aops.c 2004-08-26 21:41:53.000000000 +0300
@@ -310,10 +310,11 @@
return 0;
}
/* No i/o was scheduled on any of the buffers. */
- if (likely(!PageError(page)))
+ if (likely(!PageError(page))) {
SetPageUptodate(page);
- else /* Signal synchronous i/o error. */
+ } else { /* Signal synchronous i/o error. */
nr = -EIO;
+ }
unlock_page(page);
return nr;
}
The very same code used to compile fine with
2.4.27 without any changes to it. I can't see
where the problem is (it's 23:57 here ;)).
Can anyone tell, please?
Regards,
Ozkan Sezer
^ permalink raw reply [flat|nested] 5+ messages in thread* Re: 2.4.28-pre2 and ntfs-2.1.6b ? 2004-08-26 20:59 2.4.28-pre2 and ntfs-2.1.6b ? O.Sezer @ 2004-08-26 22:12 ` Willy Tarreau 2004-08-26 22:53 ` O.Sezer 0 siblings, 1 reply; 5+ messages in thread From: Willy Tarreau @ 2004-08-26 22:12 UTC (permalink / raw) To: O.Sezer; +Cc: linux-kernel Hi, On Thu, Aug 26, 2004 at 11:59:47PM +0300, O.Sezer wrote: > Hi all: > > With 2.4.28-pre2, ntfs-2.1.6b from linux-ntfs site > started failing to compile at aops.c: > > aops.c: In function `ntfs_read_block': > aops.c:315: parse error before "else" > -- or in case of gcc3.4 -- > aops.c:315: error: syntax error before "else" > > This happens with gcc-3.2.2 and gcc-3.4.0 > and can be fixed by: > > --- aops.c.BAK 2004-08-26 19:35:11.000000000 +0300 > +++ aops.c 2004-08-26 21:41:53.000000000 +0300 > @@ -310,10 +310,11 @@ > return 0; > } > /* No i/o was scheduled on any of the buffers. */ > - if (likely(!PageError(page))) > + if (likely(!PageError(page))) { > SetPageUptodate(page); > - else /* Signal synchronous i/o error. */ > + } else { /* Signal synchronous i/o error. */ > nr = -EIO; > + } > unlock_page(page); > return nr; > } No ! Please don't fix it this way ! The problem lies within the declaration of SetPageUptodate() which it seems is a macro which lacks some braces somewhere. You were very lucky that there was an 'else' to point it out, but imagine what it would do in the following case : if (likely(!PageError(page))) { SetPageUptodate(page); blah(); It would always execute the second half of SetPageUptodate(), whatever the condition, and nothing will alert you. What does SetPageUptodate() look like ? > The very same code used to compile fine with > 2.4.27 without any changes to it. I think that the gcc-3.4 fixes might have hit some sensible parts... > I can't see > where the problem is (it's 23:57 here ;)). > Can anyone tell, please? It's even later now, good night :-) Regards, Willy ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: 2.4.28-pre2 and ntfs-2.1.6b ? 2004-08-26 22:12 ` Willy Tarreau @ 2004-08-26 22:53 ` O.Sezer 2004-08-27 0:08 ` [PATCH 2.4] fix typo in mm.h introduced 2.4.28-pre2 O.Sezer 0 siblings, 1 reply; 5+ messages in thread From: O.Sezer @ 2004-08-26 22:53 UTC (permalink / raw) To: Willy Tarreau; +Cc: linux-kernel, marcelo.tosatti Willy Tarreau wrote: > Hi, > > On Thu, Aug 26, 2004 at 11:59:47PM +0300, O.Sezer wrote: > >>Hi all: >> >>With 2.4.28-pre2, ntfs-2.1.6b from linux-ntfs site >>started failing to compile at aops.c: >> >>aops.c: In function `ntfs_read_block': >>aops.c:315: parse error before "else" >>-- or in case of gcc3.4 -- >>aops.c:315: error: syntax error before "else" >> >>This happens with gcc-3.2.2 and gcc-3.4.0 >>and can be fixed by: >> >>--- aops.c.BAK 2004-08-26 19:35:11.000000000 +0300 >>+++ aops.c 2004-08-26 21:41:53.000000000 +0300 >>@@ -310,10 +310,11 @@ >> return 0; >> } >> /* No i/o was scheduled on any of the buffers. */ >>- if (likely(!PageError(page))) >>+ if (likely(!PageError(page))) { >> SetPageUptodate(page); >>- else /* Signal synchronous i/o error. */ >>+ } else { /* Signal synchronous i/o error. */ >> nr = -EIO; >>+ } >> unlock_page(page); >> return nr; >> } > > > No ! > Please don't fix it this way ! The problem lies within the declaration of > SetPageUptodate() which it seems is a macro which lacks some braces somewhere. > You were very lucky that there was an 'else' to point it out, but imagine > what it would do in the following case : > > if (likely(!PageError(page))) { > SetPageUptodate(page); > blah(); > > It would always execute the second half of SetPageUptodate(), whatever > the condition, and nothing will alert you. > > What does SetPageUptodate() look like ? > > >>The very same code used to compile fine with >>2.4.27 without any changes to it. > > > I think that the gcc-3.4 fixes might have hit some sensible parts... > > >>I can't see >>where the problem is (it's 23:57 here ;)). >>Can anyone tell, please? > > > It's even later now, good night :-) > > Regards, > Willy > > - > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/ > > Hi Willy, and thanks, you're a lifesaver! All the evidence points to the s390 changes in -pre2, specificly cset-1.1514 by schwidefsky which touches include/linux/mm.h this way: --- 1.44/include/linux/mm.h 2004-08-26 15:51:04 -07:00 +++ 1.45/include/linux/mm.h 2004-08-26 15:51:04 -07:00 @@ -308,11 +308,9 @@ /* Make it prettier to test the above... */ #define UnlockPage(page) unlock_page(page) #define Page_Uptodate(page) test_bit(PG_uptodate, &(page)->flags) -#define SetPageUptodate(page) \ - do { \ - arch_set_page_uptodate(page); \ - set_bit(PG_uptodate, &(page)->flags); \ - } while (0) +#ifndef SetPageUptodate +#define SetPageUptodate(page) set_bit(PG_uptodate, &(page)->flags); +#endif #define ClearPageUptodate(page) clear_bit(PG_uptodate, &(page)->flags) #define PageDirty(page) test_bit(PG_dirty, &(page)->flags) #define SetPageDirty(page) set_bit(PG_dirty, &(page)->flags) Marcelo, you maybe interested in this. Cheers, Ozkan Sezer ^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH 2.4] fix typo in mm.h introduced 2.4.28-pre2 2004-08-26 22:53 ` O.Sezer @ 2004-08-27 0:08 ` O.Sezer 2004-08-27 9:04 ` Mikael Pettersson 0 siblings, 1 reply; 5+ messages in thread From: O.Sezer @ 2004-08-27 0:08 UTC (permalink / raw) To: linux-kernel; +Cc: marcelo.tosatti, willy [-- Attachment #1: Type: text/plain, Size: 1146 bytes --] > All the evidence points > to the s390 changes in -pre2, specificly cset-1.1514 by schwidefsky > which touches include/linux/mm.h this way: > > --- 1.44/include/linux/mm.h 2004-08-26 15:51:04 -07:00 > +++ 1.45/include/linux/mm.h 2004-08-26 15:51:04 -07:00 > @@ -308,11 +308,9 @@ > /* Make it prettier to test the above... */ > #define UnlockPage(page) unlock_page(page) > #define Page_Uptodate(page) test_bit(PG_uptodate, &(page)->flags) > -#define SetPageUptodate(page) \ > - do { \ > - arch_set_page_uptodate(page); \ > - set_bit(PG_uptodate, &(page)->flags); \ > - } while (0) > +#ifndef SetPageUptodate > +#define SetPageUptodate(page) set_bit(PG_uptodate, &(page)->flags); > +#endif > #define ClearPageUptodate(page) clear_bit(PG_uptodate, &(page)->flags) > #define PageDirty(page) test_bit(PG_dirty, &(page)->flags) > #define SetPageDirty(page) set_bit(PG_dirty, &(page)->flags) > > Marcelo, you maybe interested in this. > > Cheers, > Ozkan Sezer > And I beleive this was a typo? Marcelo, please review and apply. Ozkan Sezer [-- Attachment #2: mm.h.diff --] [-- Type: text/plain, Size: 566 bytes --] --- 28p2/include/linux/mm.h.BAK 2004-08-27 02:39:21.000000000 +0300 +++ 28p2/include/linux/mm.h 2004-08-27 02:56:10.000000000 +0300 @@ -309,7 +309,7 @@ #define UnlockPage(page) unlock_page(page) #define Page_Uptodate(page) test_bit(PG_uptodate, &(page)->flags) #ifndef SetPageUptodate -#define SetPageUptodate(page) set_bit(PG_uptodate, &(page)->flags); +#define SetPageUptodate(page) set_bit(PG_uptodate, &(page)->flags) #endif #define ClearPageUptodate(page) clear_bit(PG_uptodate, &(page)->flags) #define PageDirty(page) test_bit(PG_dirty, &(page)->flags) ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH 2.4] fix typo in mm.h introduced 2.4.28-pre2 2004-08-27 0:08 ` [PATCH 2.4] fix typo in mm.h introduced 2.4.28-pre2 O.Sezer @ 2004-08-27 9:04 ` Mikael Pettersson 0 siblings, 0 replies; 5+ messages in thread From: Mikael Pettersson @ 2004-08-27 9:04 UTC (permalink / raw) To: O.Sezer; +Cc: linux-kernel, marcelo.tosatti, willy O.Sezer writes: > And I beleive this was a typo? Marcelo, please review and apply. > > Ozkan Sezer > > --- 28p2/include/linux/mm.h.BAK 2004-08-27 02:39:21.000000000 +0300 > +++ 28p2/include/linux/mm.h 2004-08-27 02:56:10.000000000 +0300 > @@ -309,7 +309,7 @@ > #define UnlockPage(page) unlock_page(page) > #define Page_Uptodate(page) test_bit(PG_uptodate, &(page)->flags) > #ifndef SetPageUptodate > -#define SetPageUptodate(page) set_bit(PG_uptodate, &(page)->flags); > +#define SetPageUptodate(page) set_bit(PG_uptodate, &(page)->flags) ACK. That semi-colon must go. ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2004-08-27 9:08 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2004-08-26 20:59 2.4.28-pre2 and ntfs-2.1.6b ? O.Sezer 2004-08-26 22:12 ` Willy Tarreau 2004-08-26 22:53 ` O.Sezer 2004-08-27 0:08 ` [PATCH 2.4] fix typo in mm.h introduced 2.4.28-pre2 O.Sezer 2004-08-27 9:04 ` Mikael Pettersson
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox