public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* buffer_head.b_bsize type
@ 2003-05-29 10:29 Stewart Smith
  2003-05-29 10:35 ` William Lee Irwin III
  0 siblings, 1 reply; 8+ messages in thread
From: Stewart Smith @ 2003-05-29 10:29 UTC (permalink / raw)
  To: linux-kernel; +Cc: trivial

[-- Attachment #1: Type: text/plain, Size: 1276 bytes --]

The buffer_head structure (include/linux/buffer_head.h) uses a u32 type 
while everywhere else (e.g. bread) the size parameter is of type int.

Currently on all architectures u32 is defined as unsigned int. We 
should probably not be doing unsigned and signed swaps. And you should 
never really have a negative size of a buffer.

So, there are two solutions: either change the buffer_head struct to be 
int so it matches everywhere else, or change everywhere else.

The attached patch does the change in one place. Although perhaps 
changing everywhere else would be better. Thoughts? I'm happy to make 
up the patch if needed.


Applies cleanly to 2.5.69 and 2.5.70 and has been tested on i386 
without causing any further problems (that I can see at least).

diff -ur linux-2.5.69-orig/include/linux/buffer_head.h 
linux-2.5.69/include/linux/buffer_head.h
--- linux-2.5.69-orig/include/linux/buffer_head.h	Mon May  5 09:52:49 
2003
+++ linux-2.5.69/include/linux/buffer_head.h	Fri May 16 12:05:16 2003
@@ -51,7 +51,7 @@
  	struct page *b_page;		/* the page this bh is mapped to */

  	sector_t b_blocknr;		/* block number */
-	u32 b_size;			/* block size */
+	int b_size;			/* block size */
  	char *b_data;			/* pointer to data block */

  	struct block_device *b_bdev;



[-- Attachment #2: patch-buffer_head-u32toint.diff --]
[-- Type: application/octet-stream, Size: 509 bytes --]

diff -ur linux-2.5.69-orig/include/linux/buffer_head.h linux-2.5.69/include/linux/buffer_head.h
--- linux-2.5.69-orig/include/linux/buffer_head.h	Mon May  5 09:52:49 2003
+++ linux-2.5.69/include/linux/buffer_head.h	Fri May 16 12:05:16 2003
@@ -51,7 +51,7 @@
 	struct page *b_page;		/* the page this bh is mapped to */
 
 	sector_t b_blocknr;		/* block number */
-	u32 b_size;			/* block size */
+	int b_size;			/* block size */
 	char *b_data;			/* pointer to data block */
 
 	struct block_device *b_bdev;


[-- Attachment #3: Type: text/plain, Size: 158 bytes --]


------------------------------
Stewart Smith
stewartsmith@mac.com
Ph: +61 4 3884 4332
ICQ: 6734154
http://www.flamingspork.com/       http://www.linux.org.au

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2003-05-31  2:07 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2003-05-29 10:29 buffer_head.b_bsize type Stewart Smith
2003-05-29 10:35 ` William Lee Irwin III
2003-05-29 11:15   ` viro
2003-05-29 11:28     ` William Lee Irwin III
2003-05-30 14:24       ` Andries Brouwer
2003-05-30 14:43         ` Andries Brouwer
2003-05-31  2:20         ` William Lee Irwin III
2003-05-29 14:19     ` Stewart Smith

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox