Re: write barriers - Was: Re: [RFC][PATCH] problem of cont_prepare_write()

From: Chris Friesen
Date: Thu Jan 13 2005 - 11:08:43 EST


Anton Altaparmakov wrote:

If I am setting two variables in sequence and it is essential that if a
different cpu reads those variables it seems them updated in the same
order as they were written in the C code do I need a write barrier in
between the two? For example:

ntfs_inode->allocated_size = 10;
ntfs_inode->initilized_size = 10;

I believe so. You may also need to cast them as volatile to prevent the compiler from reordering--can someone with more gcc knowledge than I state definitively whether or not it is smart enough to not reorder barriers?

Should another CPU see initialized_size = 10 but allocated_size < 10 the
ntfs driver will blow up in some places. So does that mean I need a
write barrier, between the two?

As above.

You may also need a read barrier to ensure that they are not speculatively loaded in the wrong order--could someone more knowledgable than I comment on that?

If yes, do I still need it if I wrap the two settings (and all accesses)
with a spin lock? And in particular with a rw-spinlock? For example:

write_lock_irqsave(&ntfs_inode->size_lock, flags);
ntfs_inode->allocated_size = 10;
ntfs_inode->initilized_size = 10;
write_unlock_irqrestore(&ntfs_inode->size_lock, flags);

Do I still need a write barrier or does the spinlock imply it already?

I believe the spinlock implies it.

Thanks a lot in advance and apologies for the stupid(?) questions...

Not stupid. Concurrency is hard.

Chris
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/