moraes@csri.toronto.edu (Mark Moraes) (09/06/89)
On an Iris4d multiprocessor, what is the difference between a semaphore and a lock? I couldn't find any specific mention of the difference in the documentation. As far as I can tell, semaphores have queues in which threads wait till the semaphore is freed, whereas locks are continuously retried (assuming ussetlock) with some delay. For a system with hardware locks, which is faster/cheaper - a semaphore or a lock? Does a lock consume much cpu time while spinning? Is the cost of going to sleep and awakening on a semaphore high? Does anyone have any numbers on these? Is there a section of the manual summarizing the parallel facilities available? (Suggestion: Perhaps a future release of the documentation could group manual pages by subsection and alphabetically - i.e. all manual pages for 3P together, rather than alphabetically across all subsections) The following is a list I've created, with some attempt to order them in 'recommended reading order'. Have I missed anything? usinit, _utrace (3P) - semaphore and lock initialization routine usconfig (3P) - semaphore and lock configuration operations taskblock, taskunblock, tasksetblockcnt (3P) - routines to block/unblock tasks taskcreate (3P) - create a new task taskdestroy (3P) - destroy a task taskctl (3P) - operations on a task barrier, new_barrier, free_barrier (3P) - barrier functions usnewlock (3P) - allocates and initializes a lock usinitlock (3P) - initializes a lock ussetlock, uscsetlock, uswsetlock, ustestlock, usunsetlock (3P) - lock routines usfreelock (3P) - free a lock usctllock (3P) - lock control operations usnewsema (3P) - allocates and initializes a semaphore usinitsema (3P) - initializes a semaphore uspsema (3P) - attempt to acquire a semaphore usvsema (3P) - frees a resource to a semaphore ustestsema (3P) - return the value of a semaphore uscpsema (3P) - attempts to acquire a semaphore, and fails if not possible usfreesema (3P) - free a semaphore usctlsema (3P) - semaphore control operations usmalloc, usfree, usrealloc (3P) - user shared memory allocator acreate, adelete, amalloc, afree, arealloc, acalloc, amallopt, amallinfo (3P) - arbitrary arena main memory allocator pcreate: pcreatel, pcreatev, pcreateve, pcreatelp, pcreatevp (3P) - create a process m_fork, m_kill_procs, m_set_procs, m_get_numprocs, m_get_myid, m_next, m_lock, m_unlock, (3P) - parallel programming primitives sproc (2) - create a new share group process blockproc, unblockproc, setblockproccnt (2) - routines to block/unblock processes Thanks.
jmb@patton.sgi.com (Jim Barton) (09/07/89)
In article <1989Sep5.185510.7836@jarvis.csri.toronto.edu>, moraes@csri.toronto.edu (Mark Moraes) writes: > On an Iris4d multiprocessor, what is the difference between a semaphore > and a lock? I couldn't find any specific mention of the difference in > the documentation. As far as I can tell, semaphores have queues in > which threads wait till the semaphore is freed, whereas locks are > continuously retried (assuming ussetlock) with some delay. > Semaphores and spinlocks are standard OS primitives which have existed for 25 years or more. There are many professors and others who have made their living writing textbooks about how to use these in operating systems. For a description in a UNIX context, Maurice Bach's book, "The Design of the UNIX Operating System" has a chapter dedicated to multiprocessing, where he describes how these primitives work (be careful though - there is a bug in the algorithm for psema() he gives). Fundamentally, a spinlock is a loop in software that does the following: while (!(location changes)) ; Thus, the spinlock reacts very quickly when the location changes, but some time may be wasted waiting for it. A semaphore is a queue with a counter, using a spinlock to protect the queue and the counter. Semaphores were originally designed by Edgar Dijkstra, as documented in the seminal paper "Cooperating Sequential Processes" which has been reprinted in hundreds of places. I'm posting a section of the original kernel design document that goes into some detail on this stuff. > For a system with hardware locks, which is faster/cheaper - a > semaphore or a lock? Does a lock consume much cpu time while spinning? > Is the cost of going to sleep and awakening on a semaphore high? Does > anyone have any numbers on these? Cost of a lock < cost of a semaphore. A semaphore implies that a context switch may happen, while none happens with a spinlock. The generic rule is that if the time spent spinning on the average is greater than the time to block a process and switch to another one, use a semaphore, else use a spinlock. > > Is there a section of the manual summarizing the parallel facilities > available? (Suggestion: Perhaps a future release of the documentation > could group manual pages by subsection and alphabetically - i.e. all > manual pages for 3P together, rather than alphabetically across all > subsections) The following is a list I've created, with some attempt > to order them in 'recommended reading order'. Have I missed anything? > The list given is complete. The parallel programmers guide is in final edit now, and should be available from SGI Real Soon Now. > Thanks. -- Jim Barton Silicon Graphics Computer Systems "UNIX: Live Free Or Die!" jmb@sgi.sgi.com, sgi!jmb@decwrl.dec.com, ...{decwrl,sun}!sgi!jmb