All of lore.kernel.org
 help / color / mirror / Atom feed
From: Chris Friesen <cfriesen@nortelnetworks.com>
To: Anton Altaparmakov <aia21@cam.ac.uk>
Cc: Andrew Morton <akpm@osdl.org>,
	hirofumi@mail.parknet.co.jp, Linus Torvalds <torvalds@osdl.org>,
	lkml <linux-kernel@vger.kernel.org>
Subject: Re: write barriers - Was: Re: [RFC][PATCH] problem of	cont_prepare_write()
Date: Thu, 13 Jan 2005 09:56:24 -0600	[thread overview]
Message-ID: <41E69A28.9080900@nortelnetworks.com> (raw)
In-Reply-To: <1105627627.22536.30.camel@imp.csi.cam.ac.uk>

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

  reply	other threads:[~2005-01-13 16:03 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-11-22 10:30 [RFC][PATCH] problem of cont_prepare_write() OGAWA Hirofumi
2004-11-22 10:41 ` Andrew Morton
2004-11-22 10:46 ` Andrew Morton
2004-11-22 11:03   ` Anton Altaparmakov
2004-11-22 21:53     ` Andrew Morton
2004-11-22 23:30       ` Anton Altaparmakov
2004-11-22 23:43         ` Andrew Morton
2005-01-13 14:47           ` write barriers - Was: " Anton Altaparmakov
2005-01-13 15:56             ` Chris Friesen [this message]
2005-01-13 18:08               ` Florian Weimer
2004-11-22 11:38   ` OGAWA Hirofumi
2004-11-22 21:43     ` Andrew Morton
2004-11-23  2:22       ` OGAWA Hirofumi
2004-11-23  2:30         ` Andrew Morton
2004-11-23  2:55           ` OGAWA Hirofumi

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=41E69A28.9080900@nortelnetworks.com \
    --to=cfriesen@nortelnetworks.com \
    --cc=aia21@cam.ac.uk \
    --cc=akpm@osdl.org \
    --cc=hirofumi@mail.parknet.co.jp \
    --cc=linux-kernel@vger.kernel.org \
    --cc=torvalds@osdl.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.