Re: 2.6.4-rc1 oops on HPFS filesystem file rename

From: Maurice van der Stee
Date: Sat Feb 28 2004 - 12:12:49 EST


Thanks, looks like it fixes my problem.

On Sat, Feb 28, 2004 at 12:04:03PM +0100, Maurice van der Stee wrote:
When saving an edited file residing on a HPFS filesystem I get the
following
oops.
Kernel is 2.6.4-rc1, compiled with gcc 3.3.2. After this any access
to
the
filesystem hangs the session. Kernel 2.6.3 has the same behavior.
Don't
know
about earlier ones.

<stares at the code>
<blinks>
<wonders whereTF do we assign hpfs1_i and hpfs2_i if both inodes are
non-NULL>
<finds the patch in question>
<stares at jgarzik>

Fix follows. That, BTW, means that *nobody* had ever tried to use hpfs
r/w since 2.5.3-pre3.

diff -urN RC4-rc1/fs/hpfs/buffer.c RC4-rc1-current/fs/hpfs/buffer.c
--- RC4-rc1/fs/hpfs/buffer.c Mon Oct 7 15:58:24 2002
+++ RC4-rc1-current/fs/hpfs/buffer.c Sat Feb 28 06:33:29 2004
@@ -62,56 +62,28 @@
<
void hpfs_lock_2inodes(struct inode *i1, struct inode *i2)
< {
- struct hpfs_inode_info *hpfs_i1 = NULL, *hpfs_i2 = NULL;
-
- if (!i1) {
- if (i2) {
- hpfs_i2 = hpfs_i(i2);
+ if (!i2 || i1 == i2) {
+ hpfs_lock_inode(i1);
+ } else if (!i1) {
+ hpfs_lock_inode(i2);
+ } else {
+ struct hpfs_inode_info *hpfs_i1 = hpfs_i(i1);
+ struct hpfs_inode_info *hpfs_i2 = hpfs_i(i2);
+ if (i1->i_ino < i2->i_ino) {
+ down(&hpfs_i1->i_sem);
+ down(&hpfs_i2->i_sem);
+ } else {
down(&hpfs_i2->i_sem);
- }
- return;
- }
- if (!i2) {
- if (i1) {
- hpfs_i1 = hpfs_i(i1);
down(&hpfs_i1->i_sem);
}
- return;
}
- if (i1->i_ino < i2->i_ino) {
- down(&hpfs_i1->i_sem);
- down(&hpfs_i2->i_sem);
- } else if (i1->i_ino > i2->i_ino) {
- down(&hpfs_i2->i_sem);
- down(&hpfs_i1->i_sem);
- } else down(&hpfs_i1->i_sem);
}

void hpfs_unlock_2inodes(struct inode *i1, struct inode *i2)
{
- struct hpfs_inode_info *hpfs_i1 = NULL, *hpfs_i2 = NULL;
-
- if (!i1) {
- if (i2) {
- hpfs_i2 = hpfs_i(i2);
- up(&hpfs_i2->i_sem);
- }
- return;
- }
- if (!i2) {
- if (i1) {
- hpfs_i1 = hpfs_i(i1);
- up(&hpfs_i1->i_sem);
- }
- return;
- }
- if (i1->i_ino < i2->i_ino) {
- up(&hpfs_i2->i_sem);
- up(&hpfs_i1->i_sem);
- } else if (i1->i_ino > i2->i_ino) {
- up(&hpfs_i1->i_sem);
- up(&hpfs_i2->i_sem);
- } else up(&hpfs_i1->i_sem);
+ /* order of up() doesn't matter here */
+ hpfs_unlock_inode(i1);
+ hpfs_unlock_inode(i2);
}

void hpfs_lock_3inodes(struct inode *i1, struct inode *i2, struct
inode *i3)
-

--
Maurice van der Stee
stee@xxxxxxxxx
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/