linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Linus Torvalds <torvalds@transmeta.com>
To: David Howells <dhowells@cambridge.redhat.com>
Cc: Andrew Morton <andrewm@uow.edu.au>, Ben LaHaise <bcrl@redhat.com>,
	Alan Cox <alan@lxorguk.ukuu.org.uk>,
	Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] i386 rw_semaphores fix
Date: Tue, 10 Apr 2001 12:42:07 -0700 (PDT)	[thread overview]
Message-ID: <Pine.LNX.4.31.0104101229150.13071-100000@penguin.transmeta.com> (raw)
In-Reply-To: <11851.986925762@warthog.cambridge.redhat.com>



On Tue, 10 Apr 2001, David Howells wrote:
>
> Here's a patch that fixes RW semaphores on the i386 architecture. It is very
> simple in the way it works.

XADD only works on Pentium+.

That's no problem if we make this SMP-specific - I doubt anybody actually
uses SMP on i486's even if the machines exist, as I think they all had
special glue logic that Linux would have trouble with anyway. But the
advantages of being able to use one generic kernel that works on plain UP
i386 machines as well as SMP P6+ machines is big enough that I would want
to be able to say "CONFIG_X86_GENERIC" + "CONFIG_SMP".

Even if it would be noticeably slower (ie a fallback to a spinlock might
be perfectly ok).

If you do this, I woul dsuggest having asm-i386/{rwsem.h|rwsem-xadd.h},
and just having a

	#ifndef CONFIG_XADD
	#include <asm/rwsem.h>
	#else
	#include <asm/rwsem-xadd.h>
	#endif

(And adding "CONFIG_XADD" to the list of generated optimization
configuration options in arch/i386/config.in, of course).

That way we don't make the semaphore.h file even more unreadable.


		Linus



  reply	other threads:[~2001-04-10 19:42 UTC|newest]

Thread overview: 50+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <3AD0FD0F.9B0C47FD@uow.edu.au>
2001-04-09  3:08 ` rw_semaphores Linus Torvalds
2001-04-09  4:18   ` rw_semaphores Linus Torvalds
2001-04-09 13:55     ` rw_semaphores Ben LaHaise
2001-04-10  2:41 ` rw_semaphores Tachino Nobuhiro
2001-04-10  5:43   ` rw_semaphores Linus Torvalds
2001-04-10  7:47     ` rw_semaphores David Howells
2001-04-10 18:02       ` [PATCH] i386 rw_semaphores fix David Howells
2001-04-10 19:42         ` Linus Torvalds [this message]
2001-04-10 19:56           ` x86 cpu configuration (was: Re: [PATCH] i386 rw_semaphores fix) Jeff Garzik
2001-04-10 21:58             ` Alan Cox
2001-04-10 20:05           ` [PATCH] i386 rw_semaphores fix Andi Kleen
2001-04-10 20:16             ` Linus Torvalds
2001-04-10 22:00             ` Alan Cox
2001-04-11  0:00               ` Andi Kleen
2001-04-11  0:13                 ` David Weinehall
2001-04-11  0:20                   ` Andi Kleen
2001-04-11  0:56                     ` David Weinehall
2001-04-11  1:04                       ` Andi Kleen
2001-04-11 12:32                     ` Alan Cox
2001-04-11  0:55                   ` Linus Torvalds
2001-04-11  1:07                     ` Andi Kleen
2001-04-11  1:12                       ` Linus Torvalds
2001-04-11  1:23                         ` Andi Kleen
2001-04-11 12:36                           ` Alan Cox
2001-04-11 18:05                     ` H. Peter Anvin
2001-04-11 12:28                 ` Alan Cox
2001-04-11 18:06                   ` H. Peter Anvin
2001-04-11 22:06                     ` Alan Cox
2001-04-11 22:42                       ` H. Peter Anvin
2001-04-11 22:55                         ` Alan Cox
2001-04-10 21:57           ` Alan Cox
2001-04-11  0:40             ` Tim Wright
2001-04-11  7:38           ` David Howells
2001-04-11 12:24             ` Maciej W. Rozycki
2001-04-11 12:57           ` [PATCH] 2nd try: " David Howells
2001-04-11 16:37             ` [PATCH] 3rd " David Howells
2001-04-11 21:41               ` [PATCH] 4th " David Howells
2001-04-12 18:16                 ` Andrew Morton
2001-04-11 23:00               ` [PATCH] 3rd " Anton Blanchard
2001-04-12 15:06                 ` [PATCH] i386 rw_semaphores, general abstraction patch David Howells
2001-04-11 16:56         ` [PATCH] i386 rw_semaphores fix Andrew Morton
2001-04-11 17:36           ` David Howells
2001-04-11 18:41             ` Linus Torvalds
2001-04-11 21:27           ` David Howells
2001-04-16 14:39       ` rw_semaphores yodaiken
2001-04-16 14:56         ` rw_semaphores Alan Cox
2001-04-16 17:05         ` rw_semaphores Linus Torvalds
2001-04-16 17:34           ` rw_semaphores yodaiken
2001-04-16 17:26         ` rw_semaphores Andrew Morton
2001-04-10  6:33   ` rw_semaphores Tachino Nobuhiro

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=Pine.LNX.4.31.0104101229150.13071-100000@penguin.transmeta.com \
    --to=torvalds@transmeta.com \
    --cc=alan@lxorguk.ukuu.org.uk \
    --cc=andrewm@uow.edu.au \
    --cc=bcrl@redhat.com \
    --cc=dhowells@cambridge.redhat.com \
    --cc=linux-kernel@vger.kernel.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).