On Fri, Apr 29, 2005 at 10:44:17AM +1000, Paul Mackerras wrote:
> You have made semaphores bigger and slower on the architectures that
> have load-linked/store-conditional instructions, which is at least
> ppc, ppc64, sparc64 and alpha.  Did you take the trouble to understand
> the ppc semaphore implementation?

The ppc implementation does have some good ideas that are worth using.  
It's hard to know which of the 23 versions were worth using, but I'm 
getting a picture where at least 2 variants are need.  The atomic ops 
variant should use the single counter as ppc does (why did nobody port 
that to x86?).  A spinlock version is needed at least by parisc.

> What changes do you want to make to the semaphore functionality?

There are at least two users who need asynchronous semaphore/mutex 
operations: aio_write (which needs to acquire i_sem), and nfs.  
Changing 23 different architectures and verifying that they are 
correct is next to impossible, so it makes sense to have at least 
some unification take place.

                -ben
-- 
"Time is what keeps everything from happening all at once." -- John Wheeler

Reply via email to