Actually, are you sure about that?
In filemap.c in do_generic_file_read, you have this:
struct address_space *mapping = filp->f_dentry->d_inode->i_mapping;
...
/*
* Try to find the data in the page cache..
*/
hash = page_hash(mapping, index);
spin_lock(&pagecache_lock);
page = __find_page_nolock(mapping, index, *hash);
Looks as if pages are identified by (mapping, index) pairs, rather
than (major:minor, index) triplets.
And "mapping" itself seems to point to i_data of the device's inode
structure (not the device entry's inode, but the device's itself).
Which means that if the inode is put (all references to the block
device closed), and later the same major/minor is reopened, it may
very well be in a different place in memory... Meaning that the
formerly cached pages (if they are still there...) will no longer be
recognized as the same, as mapping is now a different address, even
though major/minor is the same.
The changing nature of mapping can be confirmed easily by inserting a
printk into the open routine of the device.
As long as at least one reference to the device is open, mapping stays
the same for further opens, but as soon as the last ref is closed, the
next open will return a different address...
For the following test, I've inserted the following debugging printk
in floppy_open:
printk("Mapping=%x data=%x\n", inode->i_mapping, &inode->i_data);
As you see, while the sleep is open, Mapping is always
c25a7a90. However, once the sleep is closed, Mapping changes to
c1ba0cd0 . This seems to explain it things.
> sleep 3600 </dev/fd0 &
[1] 1449
Mapping=c25a7a90 data=cb80dc50
VFS: Disk change detected on device fd(2,0)
> mdir a:
Mapping=c25a7a90 data=cb80dc50
Volume in drive A has no label
Volume Serial Number is 63F7-FED8
Directory for A:/
No files
1 457 664 bytes free
> mdir a:
Mapping=c25a7a90 data=cb80dc50
Volume in drive A has no label
Volume Serial Number is 63F7-FED8
Directory for A:/
No files
1 457 664 bytes free
> kill %1
[1] + 1449 terminated sleep 3600 < /dev/fd0
> mdir a:
Mapping=c1ba0cd0 data=cb80dc50
Volume in drive A has no label
Volume Serial Number is 63F7-FED8
Directory for A:/
No files
1 457 664 bytes free
Regards,
Alain
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/