Giant Lock

In operating systems, a giant lock, also known as a big-lock or kernel-lock, is a lock which may be used in the kernel to provide the concurrency control required by symmetric multiprocessing (SMP) systems.

A giant lock is a solitary global lock that is held whenever a thread enters kernel space, and is released when the thread returns to user space (a system call is the archetypal example). In this model, threads in user space can run concurrently on any available processors or processor cores, but no more than one thread can run in kernel space; any other threads that try to enter kernel space are forced to wait. In other words, the giant lock eliminates all concurrency in kernel space.

By isolating the kernel from concurrency, many parts of the kernel no longer need to be modified to support SMP. By the same token, performance is predictably inefficient on SMP systems. Accordingly, the giant lock approach is commonly seen as a preliminary means of bringing SMP support to an operating system, yielding benefits only in user space. Most modern operating systems use a fine-grained locking approach.

The Linux kernel had a big kernel lock from the introduction of SMP until Arnd Bergmann removed it in 2011 after the final remaining uses of the big lock had been removed or replaced by finer grained locking.

Famous quotes containing the words giant and/or lock:

    The point of the dragonfly’s terrible lip, the giant water bug, birdsong, or the beautiful dazzle and flash of sunlighted minnows, is not that it all fits together like clockwork--for it doesn’t ... but that it all flows so freely wild, like the creek, that it all surges in such a free, finged tangle. Freedom is the world’s water and weather, the world’s nourishment freely given, its soil and sap: and the creator loves pizzazz.
    Annie Dillard (b. 1945)

    Nae living man I’ll love again,
    Since that my lovely knight is slain.
    Wi ae lock of his yellow hair
    I’ll chain my heart for evermair.
    —Unknown. The Lament of the Border Widow (l. 25–28)