| From: | "Dann Corbit" <DCorbit(at)connx(dot)com> | 
|---|---|
| To: | "Simon Riggs" <simon(at)2ndquadrant(dot)com>, "Peter Eisentraut" <peter_e(at)gmx(dot)net> | 
| Cc: | <pgsql-hackers(at)postgresql(dot)org>, "Tom Lane" <tgl(at)sss(dot)pgh(dot)pa(dot)us>, <robennals(at)users(dot)sourceforge(dot)net> | 
| Subject: | Re: Spinlocks and CPU Architectures | 
| Date: | 2005-10-11 18:09:32 | 
| Message-ID: | D425483C2C5C9F49B5B7A41F8944154757D1AC@postal.corporate.connx.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
As an aside, here is a package that has recently been BSD re-licensed:
http://sourceforge.net/projects/libltx/
It is a lightweight memory transaction package.  It comes with a paper
entitled "Cache Sensitive Software Transactional Memory" by Robert
Ennals.
In the paper, Robert Ennals suggests this form of concurrent programming
as a replacement for lock based programming.  A quote:
"We have now reached the point where transactions are outperforming
locks -- and people are starting to get interested."
There are a number of interesting claims in the paper.  Since the
license is now compatible, it may have some interest for integration
into the PostgreSQL core where appropriate.
It would certainly be worthwhile to read the paper and fool around with
the supplied test driver to compare the approaches.
If nobody on the PostgreSQL team has time for the experimentations, it
might be a good project for a PhD candidate at some university.
> -----Original Message-----
> From: pgsql-hackers-owner(at)postgresql(dot)org [mailto:pgsql-hackers-
> owner(at)postgresql(dot)org] On Behalf Of Simon Riggs
> Sent: Tuesday, October 11, 2005 10:56 AM
> To: Peter Eisentraut
> Cc: pgsql-hackers(at)postgresql(dot)org; Tom Lane
> Subject: Re: [HACKERS] Spinlocks and CPU Architectures
> 
> On Tue, 2005-10-11 at 18:45 +0200, Peter Eisentraut wrote:
> > Tom Lane wrote:
> > > This seems pretty unworkable from a packaging standpoint.  Even if
> > > you teach autoconf how to tell which model it's running on,
there's
> > > no guarantee that the resulting executables will be used on that
same
> > > machine.
> >
> > A number of packages in the video area (and perhaps others) do
compile
> > "sub-architecture" specific variants.  This could be done for
> > PostgreSQL, but you'd probably need to show some pretty convincing
> > performance numbers before people start the packaging effort.
> 
> I completely agree, just note that we already have some cases where
> convincing performance numbers exist.
> 
> Tom is suggesting having different behaviour for x86 and x86_64. The
x86
> will still run on x86_64 architecture would it not? So we'll have two
> binaries for each OS, yes?
> 
> In general, where we do find a clear difference, we should at very
least
> identify/record which variant the binary is most suitable for. At best
> we could produce different executables, but I understand the packaging
> effort required to do that.
> 
> Best Regards, Simon Riggs
> 
> 
> 
> 
> ---------------------------(end of
broadcast)---------------------------
> TIP 4: Have you searched our list archives?
> 
>                http://archives.postgresql.org
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Ilia Kantor | 2005-10-11 18:13:01 | Re: slow IN() clause for many cases | 
| Previous Message | Simon Riggs | 2005-10-11 17:55:43 | Re: Spinlocks and CPU Architectures |