> >BTW. neither getblk nor mark_buffer_uptodate check for i/o completion.
> 
> That was exactly what I wanted to point out :).
> 
> >Isn't it race? Many filesystem do it this way.
> 
> All depends on the semantics you want I think. It doesn't seems black and
> white to me.
> 
> Note that for example in 2.3.25 with shared mappings you can't avoid
> userspace to not change the mapped memory while at the same time a
> peripheral is reading it in DMA. This is by design.
> 
> But the shared mapped region is only data, while if the buffer you are
> over-writing is _valid_ metadata (likely to be metadata otherwise you
> wouldn't play with the buffer cache in first place) then you probably like
> to know that if your machine will reboot -f, there will be at least an old
> _valid_ snapshot of metadata in such block.
> 
> So maybe you want a wait_on_buffer() before the memcpy if the buffer you
> are going to write to was previously valid.

What if user does cat /dev/hda1>/dev/null on mounted device while
filesystem driver does getblk? ... the buffer gets corrupted.

User:                           Filesystem driver:
--------------------------------------------------------
open("/dev/hda1", O_RDONLY);
read();
waiting for io completion...
                                getblk();
                                mark_buffer_uptodate();
                                write_some_data_there
read data is stored, end_request()
                                BOOM! changes are lost.

Mikulas Patocka

Reply via email to