All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] Corrections to affs and sfs
@ 2008-11-22 19:55 Krzysztof Smiechowicz
  2008-11-28 20:14 ` Robert Millan
  0 siblings, 1 reply; 8+ messages in thread
From: Krzysztof Smiechowicz @ 2008-11-22 19:55 UTC (permalink / raw)
  To: grub-devel

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

Hello,

I would like to submit the following patch:

* fs/affs.c: Return failure when directory iteration failed.

* fs/sfs.c: Return failure when directory iteration failed. Correct
order in which btree nodes are read.

These changes are needed to boot AROS Research Operating System from SFS
/ FFS.

Best regards,
Krzysztof


[-- Attachment #2: affs-sfs.diff --]
[-- Type: text/x-diff, Size: 1345 bytes --]

Index: fs/affs.c
===================================================================
--- fs/affs.c	(revision 1919)
+++ fs/affs.c	(working copy)
@@ -381,7 +381,7 @@
  fail:
   grub_free (node);
   grub_free (hashtable);
-  return 1;
+  return 0;
 }
 
 
Index: fs/sfs.c
===================================================================
--- fs/sfs.c	(revision 1919)
+++ fs/sfs.c	(working copy)
@@ -172,7 +172,8 @@
 	  return grub_errno;
 	}
 
-      for (i = 0; i < grub_be_to_cpu16 (tree->nodes); i++)
+      grub_uint16_t nodescount = grub_be_to_cpu16(tree->nodes);
+      for (i = nodescount - 1; i >= 0; i--)
 	{
 
 #define EXTNODE(tree, index)						\
@@ -180,17 +181,9 @@
 					 + (index) * (tree)->nodesize))
 
 	  /* Follow the tree down to the leaf level.  */
-	  if ((grub_be_to_cpu32 (EXTNODE(tree, i)->key) >= block)
+	  if ((grub_be_to_cpu32 (EXTNODE(tree, i)->key) <= block)
 	      && !tree->leaf)
 	    {
-	      next = grub_be_to_cpu32 (EXTNODE (tree, i - 1)->data);
-	      break;
-	    }
-
-	  /* In case the last node is reached just use that one, it is
-	     the right match.  */
-	  if (i + 1 == grub_be_to_cpu16 (tree->nodes) && !tree->leaf)
-	    {
 	      next = grub_be_to_cpu32 (EXTNODE (tree, i)->data);
 	      break;
 	    }
@@ -451,7 +444,7 @@
 
  fail:
   grub_free (objc_data);
-  return 1;
+  return 0;
 }
 
 



^ permalink raw reply	[flat|nested] 8+ messages in thread
* Re: [PATCH] Corrections to affs and sfs
@ 2009-02-22  1:30 Kalamatee
  2009-02-27 19:51 ` Robert Millan
  0 siblings, 1 reply; 8+ messages in thread
From: Kalamatee @ 2009-02-22  1:30 UTC (permalink / raw)
  To: grub-devel

<bump>

FWIW - This patch has been used in the AROS build of grub for the best
part of the last year - without it SFS doesnt work.



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

end of thread, other threads:[~2009-02-27 19:51 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-11-22 19:55 [PATCH] Corrections to affs and sfs Krzysztof Smiechowicz
2008-11-28 20:14 ` Robert Millan
2008-11-29  8:27   ` Krzysztof Smiechowicz
2009-01-06 17:44   ` Krzysztof Smiechowicz
2009-02-07 20:33     ` Robert Millan
2009-02-11 19:39     ` Krzysztof Smiechowicz
  -- strict thread matches above, loose matches on Subject: below --
2009-02-22  1:30 Kalamatee
2009-02-27 19:51 ` Robert Millan

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.