On Wed, Nov 28, 2012 at 1:29 PM, Mikulas Patocka <mpatocka@xxxxxxxxxx> wrote: > > The problem with this approach is that it is very easy to miss points > where it is assumed that the block size doesn't change - and if you miss a > point, it results in a hidden bug that has a little possibility of being > found. Umm. Mikulas, *your* approach has resulted in bugs. So let's not throw stones in glass houses, shall we? The whole reason for this long thread (and several threads before it) is that your model isn't working and is causing problems. I already pointed out how bogus your arguments about mmap() locking were, and then you have the gall to talk about potential bugs, when I have pointed you to *actual* bugs, and actual mistakes. > For example, __block_write_full_page and __block_write_begin do > if (!page_has_buffers(page)) { create_empty_buffers... } > and then they do > WARN_ON(bh->b_size != blocksize) > err = get_block(inode, block, bh, 1) Right. And none of this is new. > ... so if the buffers were left over from some previous call to > create_empty_buffers with a different blocksize, that WARN_ON is trigged. None of this can happen. > Locking the whole read/write/mmap operations is crude, but at least it can > be done without thorough review of all the memory management code. Umm. Which you clearly didn't do, and raised totally crap arguments for. In contrast, I have a very simple argument for the correctness of my patch: every single user of the "get_block[s]()" interface now takes the lock for as long as get_block[s]() is passed off to somebody else. And since get_block[s]() is the only way to create those empty buffers, I think I pretty much proved exactly what you ask for. And THAT is the whole point and advantage of making locking sane. Sane locking you can actually *think* about! In contrast, locking around "mmap()" is absolutely *guaranteed* to be insane, because mmap() doesn't actually do any of the IO that the lock is supposed to protect against! So Mikulas, quite frankly, your arguments argue against you. When you say "Locking the whole read/write/mmap operations is crude, but at least it can be done without thorough", you are doubly correct: it *is* crude, and it clearly *was* done without thought, since it's a f*cking idiotic AND INCORRECT thing to do. Seriously. Locking around "mmap()" is insane. It leads to insane semantics (the whole EBUSY thing is purely because of that problem) and it leads to bad code (your "let's add a new "mmap_region" hook is just disgusting, and while Al's idea of doing it in the existing "->open" method is at least not nasty, it's definitely extra code and complexity). There are serious *CORRECTNESS* advantages to simplicity and directness. And locking at the right point is definitely very much part of that. Anyway, as far as block size goes, we have exactly two cases: - random IO that does not care about the block size, and will just do whatever the current block size is (ie normal anonymous accesses to the block device). This is the case that needs the locking - but it only needs it around the individual page operations, ie exactly where I put it. In fact, they can happily deal with different block sizes for different pages, they don't really care. - mounted filesystems etc that require a particular block size and set it at mount time, and they have exclusivity rules The second case is the case that actually calls set_blocksize(), and if "kill_bdev()" doesn't get rid of the old blocksizes, then they have always been in trouble, and would always _continue_ to be in trouble, regardless of locking. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html