Skip to content

Commit 9333907

Browse files
committed
Merge git://git.kernel.org/pub/scm/linux/kernel/git/joern/misc
2 parents 118af32 + 21d31f1 commit 9333907

File tree

1 file changed

+9
-58
lines changed

1 file changed

+9
-58
lines changed

drivers/mtd/devices/block2mtd.c

Lines changed: 9 additions & 58 deletions
Original file line numberDiff line numberDiff line change
@@ -40,56 +40,9 @@ struct block2mtd_dev {
4040
static LIST_HEAD(blkmtd_device_list);
4141

4242

43-
#define PAGE_READAHEAD 64
44-
static void cache_readahead(struct address_space *mapping, int index)
43+
static struct page* page_read(struct address_space *mapping, int index)
4544
{
4645
filler_t *filler = (filler_t*)mapping->a_ops->readpage;
47-
int i, pagei;
48-
unsigned ret = 0;
49-
unsigned long end_index;
50-
struct page *page;
51-
LIST_HEAD(page_pool);
52-
struct inode *inode = mapping->host;
53-
loff_t isize = i_size_read(inode);
54-
55-
if (!isize) {
56-
INFO("iSize=0 in cache_readahead\n");
57-
return;
58-
}
59-
60-
end_index = ((isize - 1) >> PAGE_CACHE_SHIFT);
61-
62-
read_lock_irq(&mapping->tree_lock);
63-
for (i = 0; i < PAGE_READAHEAD; i++) {
64-
pagei = index + i;
65-
if (pagei > end_index) {
66-
INFO("Overrun end of disk in cache readahead\n");
67-
break;
68-
}
69-
page = radix_tree_lookup(&mapping->page_tree, pagei);
70-
if (page && (!i))
71-
break;
72-
if (page)
73-
continue;
74-
read_unlock_irq(&mapping->tree_lock);
75-
page = page_cache_alloc_cold(mapping);
76-
read_lock_irq(&mapping->tree_lock);
77-
if (!page)
78-
break;
79-
page->index = pagei;
80-
list_add(&page->lru, &page_pool);
81-
ret++;
82-
}
83-
read_unlock_irq(&mapping->tree_lock);
84-
if (ret)
85-
read_cache_pages(mapping, &page_pool, filler, NULL);
86-
}
87-
88-
89-
static struct page* page_readahead(struct address_space *mapping, int index)
90-
{
91-
filler_t *filler = (filler_t*)mapping->a_ops->readpage;
92-
cache_readahead(mapping, index);
9346
return read_cache_page(mapping, index, filler, NULL);
9447
}
9548

@@ -105,14 +58,14 @@ static int _block2mtd_erase(struct block2mtd_dev *dev, loff_t to, size_t len)
10558
u_long *max;
10659

10760
while (pages) {
108-
page = page_readahead(mapping, index);
61+
page = page_read(mapping, index);
10962
if (!page)
11063
return -ENOMEM;
11164
if (IS_ERR(page))
11265
return PTR_ERR(page);
11366

114-
max = (u_long*)page_address(page) + PAGE_SIZE;
115-
for (p=(u_long*)page_address(page); p<max; p++)
67+
max = page_address(page) + PAGE_SIZE;
68+
for (p=page_address(page); p<max; p++)
11669
if (*p != -1UL) {
11770
lock_page(page);
11871
memset(page_address(page), 0xff, PAGE_SIZE);
@@ -174,8 +127,7 @@ static int block2mtd_read(struct mtd_info *mtd, loff_t from, size_t len,
174127
cpylen = len; // this page
175128
len = len - cpylen;
176129

177-
// Get page
178-
page = page_readahead(dev->blkdev->bd_inode->i_mapping, index);
130+
page = page_read(dev->blkdev->bd_inode->i_mapping, index);
179131
if (!page)
180132
return -ENOMEM;
181133
if (IS_ERR(page))
@@ -213,8 +165,7 @@ static int _block2mtd_write(struct block2mtd_dev *dev, const u_char *buf,
213165
cpylen = len; // this page
214166
len = len - cpylen;
215167

216-
// Get page
217-
page = page_readahead(mapping, index);
168+
page = page_read(mapping, index);
218169
if (!page)
219170
return -ENOMEM;
220171
if (IS_ERR(page))
@@ -308,9 +259,9 @@ static struct block2mtd_dev *add_device(char *devname, int erase_size)
308259
/* We might not have rootfs mounted at this point. Try
309260
to resolve the device name by other means. */
310261

311-
dev_t dev = name_to_dev_t(devname);
312-
if (dev != 0) {
313-
bdev = open_by_devnum(dev, FMODE_WRITE | FMODE_READ);
262+
dev_t devt = name_to_dev_t(devname);
263+
if (devt) {
264+
bdev = open_by_devnum(devt, FMODE_WRITE | FMODE_READ);
314265
}
315266
}
316267
#endif

0 commit comments

Comments
 (0)