* 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