| From: | Brent Verner <brent(at)rcfile(dot)org> | 
|---|---|
| To: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> | 
| Cc: | Bruce Momjian <pgman(at)candle(dot)pha(dot)pa(dot)us>, pgsql-hackers(at)postgresql(dot)org | 
| Subject: | Re: Some interesting results from tweaking spinlocks | 
| Date: | 2002-01-05 07:54:33 | 
| Message-ID: | 20020105075433.GA2306@rcfile.org | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
[2002-01-05 00:00] Tom Lane said:
| Bruce Momjian <pgman(at)candle(dot)pha(dot)pa(dot)us> writes:
| > OK, I am a little confused now.  I thought the spinlock was only done a
| > few times if we couldn't get a lock, and if we don't we go to sleep, and
| > the count determines how many times we try.  Isn't that expected to
| > affect SMP machines?
| 
| Yeah, but if the spinlock is only held for a few dozen instructions,
| one would think that the max useful delay is also a few dozen
| instructions (or maybe a few times that, allowing for the possibility
| that other processors might claim the lock before we can get it).
| If we spin for longer than that, the obvious conclusion is that the
| spinlock is held by a process that's lost the CPU, and we should
| ourselves yield the CPU so that it can run again.  Further spinning
| just wastes CPU time that might be used elsewhere.
| 
| These measurements seem to say there's a flaw in that reasoning.
| What is the flaw?
Knowing very little of SMP, it looks like the spinning is parallelizing
as expected, getting to select() faster, then serializing on the 
select() call.  I suspect using usleep() instead of select() might 
relieve the serialization.  I'm aware that usleep(10) will actually 
yield between 10 and 20us due to the kernel's scheduler.
b
-- 
"Develop your talent, man, and leave the world something. Records are 
really gifts from people. To think that an artist would love you enough
to share his music with anyone is a beautiful thing."  -- Duane Allman
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Sean Chittenden | 2002-01-05 08:46:40 | pgcryto strangeness... | 
| Previous Message | Marc G. Fournier | 2002-01-05 06:49:49 | Re: RC1 time? |