From 447707fd03e401ee2d348cd1b3db3afdc60ae06f Mon Sep 17 00:00:00 2001 From: Andrew Morton Date: Wed, 30 Apr 2008 00:54:54 -0700 Subject: [PATCH] --- yaml --- r: 95285 b: refs/heads/master c: 487798df6d25e76ed6558b3e17c44cf0458cc6f3 h: refs/heads/master i: 95283: 5326ff57d6a8b9fef46e9226828ca5fe3c7217ca v: v3 --- [refs] | 2 +- trunk/fs/hfsplus/btree.c | 10 +++++++--- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 27525920f08c..ca13efaf42ee 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 3e5a5097303eedb4ffae2719843eb064221b1db4 +refs/heads/master: 487798df6d25e76ed6558b3e17c44cf0458cc6f3 diff --git a/trunk/fs/hfsplus/btree.c b/trunk/fs/hfsplus/btree.c index bb5433608a42..e49fcee1e293 100644 --- a/trunk/fs/hfsplus/btree.c +++ b/trunk/fs/hfsplus/btree.c @@ -184,7 +184,9 @@ struct hfs_bnode *hfs_bmap_alloc(struct hfs_btree *tree) struct hfs_bnode *node, *next_node; struct page **pagep; u32 nidx, idx; - u16 off, len; + unsigned off; + u16 off16; + u16 len; u8 *data, byte, m; int i; @@ -211,7 +213,8 @@ struct hfs_bnode *hfs_bmap_alloc(struct hfs_btree *tree) node = hfs_bnode_find(tree, nidx); if (IS_ERR(node)) return node; - len = hfs_brec_lenoff(node, 2, &off); + len = hfs_brec_lenoff(node, 2, &off16); + off = off16; off += node->page_offset; pagep = node->page + (off >> PAGE_CACHE_SHIFT); @@ -256,7 +259,8 @@ struct hfs_bnode *hfs_bmap_alloc(struct hfs_btree *tree) return next_node; node = next_node; - len = hfs_brec_lenoff(node, 0, &off); + len = hfs_brec_lenoff(node, 0, &off16); + off = off16; off += node->page_offset; pagep = node->page + (off >> PAGE_CACHE_SHIFT); data = kmap(*pagep);