Misplaced Pages

Giant lock: Difference between revisions

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 16:56, 25 July 2009 editAlexbot (talk | contribs)196,144 editsm robot Adding: ja:ジャイアントロック← Previous edit Latest revision as of 00:23, 12 October 2024 edit undoGuy Harris (talk | contribs)Extended confirmed users76,812 edits Linux: Use citation templates. Separate clauses with commas. 
(63 intermediate revisions by 42 users not shown)
Line 1: Line 1:
{{Short description|Lock used in computer kernels}}
In ], '''giant lock''', which is also known as '''big-lock''' or '''kernel-lock''', is a ] which may be used to implement a ] in the kernel, which is needed for ] support. In ]s, a '''giant lock''', also known as a '''big-lock''' or '''kernel-lock''', is a ] that may be used in the ] to provide ] required by ] (SMP) systems.


It is an approach of single, global lock which is held when a ] enters the ], for example, after a ], and released when the thread returns to ]. While threads which are in the ] can run concurrently in the ], only one thread can run in the kernel space, and threads in other processors which are going to enter the kernel space have to wait. This means that giant lock eliminates all ] in kernel space. A giant lock is a solitary global lock that is held whenever a ] enters ] and released when the thread returns to ]; a ] is the archetypal example. In this model, threads in user space can run concurrently on any available ] or ], 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 ] in kernel space.


The main disadvantage of giant lock is that it eliminates the concurrency, thus decrease the performance on ] systems. However, the advantage of giant lock is that there is no need to modify many parts of the operating systems, thus it is easy to implement. Giant lock approach is mostly used by operating systems to implement an initial support for SMP. As an alternative to giant lock, most of the modern operating systems use ] approach. By isolating the kernel from concurrency, many parts of the kernel no longer need to be modified to support SMP. However, as in giant-lock SMP systems only one processor can run the kernel code at a time, performance for applications spending significant amounts of time in the kernel is not much improved.{{r|rwatson2007}} 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 ] approach.

== Linux ==
The ] had a big kernel lock (BKL) since the introduction of SMP, until ] removed it in 2011 in kernel version 2.6.39,<ref>{{Cite web |url=https://git.kernel.org/?p=linux%2Fkernel%2Fgit%2Ftorvalds%2Flinux-2.6.git%3Ba%3Dcommitdiff%3Bh%3D4ba8216cd90560bc402f52076f64d8546e8aefcb |title=git.kernel.org: ''BKL: that's all folks'' |access-date=2019-12-28 |archive-url=https://archive.today/20120720043351/http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commitdiff;h=4ba8216cd90560bc402f52076f64d8546e8aefcb |archive-date=2012-07-20 |url-status=dead }}</ref><ref>https://kernelnewbies.org/BigKernelLock – BigKernelLock at kernelnewbies.org</ref> with the remaining uses of the big lock removed or replaced by finer-grained locking. ]s at or above ], ] and ] are therefore not using BKL.

{{As of|2022|09}}, Linux kernel still has ''console_lock'' and ''rtnl_lock'', which are sometimes referred as BKL, and its removal is in progress.<ref>. Daniel Vetter. June 28, 2017</ref><ref>{{cite mailing list |url=https://lore.kernel.org/lkml/20220910222301.479172669@linutronix.de/ |title= printk: Add basic infrastructure for non-BKL consoles |author=Thomas Gleixner |date=September 11, 2022 |mailing-list=linux-kernel}}</ref><ref>{{cite conference |url=https://strlen.de/talks/netdev22_rtnl.pdf |title=rtnl mutex, the network stack big kernel lock |author=Florian Westphal |date=November 2017 |conference=netdev 2.2 |location=Seoul}}</ref><ref>{{cite conference |url=https://lpc.events/event/18/contributions/1959/ |title=Per Netns RTNL |author=Kuniyuki Iwashima |conference=Linux Plumbers Conference 2024 |location=Vienna, Austria |date=September 18, 2024}}</ref>

== BSD ==
{{As of|2019|07}}, ] and ] are still using the ] family of primitives to facilitate synchronisation of critical sections within the kernel,{{r|o/net/if|n/net/if|spl.9}} meaning that many system calls may inhibit SMP capabilities of the system, and, according to ], the SMP capabilities of these two systems cannot be considered modern.{{r|dillon2019}}

FreeBSD still has support for ''the Giant mutex'',{{r|f/locking.9}} which provides semantics akin to the old spl interface, but performance-critical core components have long been converted to use finer-grained locking.{{r|rwatson2007}}

It is claimed by ] that out of the ] general-purpose operating systems, only ], ] and ] have modern SMP support, with ] and ] falling behind.{{r|dillon2019}}

The ] Foundation views modern SMP support as vital to the direction of The NetBSD Project, and has offered grants to developers willing to work on SMP improvements; ] was one of the projects that arose as a result of these financial incentives, but further improvements to the core networking stack may still be necessary.{{r|n/net/if|tnf/smp}}


==See also== ==See also==
* ] * ]
* ] * ]
* ]


==References==
]
{{Reflist
]
|refs=
]


<ref name = "o/net/if" >{{cite web
]
|url = http://bxr.su/o/sys/net/if.c
]
|title = /sys/net/if.c
|website = BSD Cross Reference
|publisher = ]
|date = 2019-06-30
|access-date = 2019-07-25
|quote = s = splnet();
}}</ref>

<ref name = "n/net/if" >{{cite web
|url = http://bxr.su/n/sys/net/if.c
|title = /sys/net/if.c
|website = BSD Cross Reference
|publisher = ]
|date = 2019-07-25
|access-date = 2019-07-25
|quote = s = splnet();
}}</ref>

<ref name= spl.9 >{{cite web
|url= http://mdoc.su/n,o/spl.9
|title= splx(9) — modify system interrupt priority level
|publisher= ], ]
|access-date= 2019-07-25
}}</ref>

<ref name = "f/locking.9" >{{cite web
|author= Julian Elischer |year= 2007
|url= http://bxr.su/f/share/man/man9/locking.9
|title= locking(9) — kernel synchronization primitives
|website= BSD Cross Reference |publisher= ]
|access-date= 2019-07-25
|quote= Giant is a special mutex used to protect data structures that do not yet have their own locks. Since it provides semantics akin to the old spl(9) interface, …
}}
*{{cite book |section=locking -- kernel synchronization primitives |title=FreeBSD Manual Pages |url=http://mdoc.su/f/locking.9}}</ref>

<ref name = rwatson2007 >{{cite mailing list
|author= Robert N M Watson |author-link= Robert Watson (computer scientist) |date= 2007-11-25
|url= https://lists.freebsd.org/pipermail/freebsd-hackers/2007-November/022368.html
|title= Before & After Under The Giant Lock
|mailing-list= FreeBSD-Hackers@ |publisher= ]
|access-date= 2019-07-25
}}</ref>

<ref name = dillon2019 >{{cite mailing list
|author= Matthew Dillon
|author-link= Matthew Dillon
|date= 2019-07-22
|url= http://lists.dragonflybsd.org/pipermail/users/2019-July/358226.html
|title= DragonFlyBSD Project Update - colo upgrade, future trends
|mailing-list= users@ |publisher= ]
|access-date= 2019-07-25
}}</ref>

<ref name= "tnf/smp" >{{cite web
|url= http://wiki.netbsd.org/projects/project/smp_networking/
|title= SMP Networking (aka remove the big network lock)
|publisher= ]
|date= 2013-02-14
|access-date= 2023-03-26
|archive-url= https://web.archive.org/web/20190725193614/http://wiki.netbsd.org/projects/project/smp_networking/
|url-status= live
|archive-date= 2019-07-25
}}</ref>

}}

{{DEFAULTSORT:Giant Lock}}
]

Latest revision as of 00:23, 12 October 2024

Lock used in computer kernels

In operating systems, a giant lock, also known as a big-lock or kernel-lock, is a lock that may be used in the kernel to provide 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 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. However, as in giant-lock SMP systems only one processor can run the kernel code at a time, performance for applications spending significant amounts of time in the kernel is not much improved. 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.

Linux

The Linux kernel had a big kernel lock (BKL) since the introduction of SMP, until Arnd Bergmann removed it in 2011 in kernel version 2.6.39, with the remaining uses of the big lock removed or replaced by finer-grained locking. Linux distributions at or above CentOS 7, Debian 7 (Wheezy) and Ubuntu 11.10 are therefore not using BKL.

As of September 2022, Linux kernel still has console_lock and rtnl_lock, which are sometimes referred as BKL, and its removal is in progress.

BSD

As of July 2019, OpenBSD and NetBSD are still using the spl family of primitives to facilitate synchronisation of critical sections within the kernel, meaning that many system calls may inhibit SMP capabilities of the system, and, according to Matthew Dillon, the SMP capabilities of these two systems cannot be considered modern.

FreeBSD still has support for the Giant mutex, which provides semantics akin to the old spl interface, but performance-critical core components have long been converted to use finer-grained locking.

It is claimed by Matthew Dillon that out of the open-source software general-purpose operating systems, only Linux, DragonFly BSD and FreeBSD have modern SMP support, with OpenBSD and NetBSD falling behind.

The NetBSD Foundation views modern SMP support as vital to the direction of The NetBSD Project, and has offered grants to developers willing to work on SMP improvements; NPF (firewall) was one of the projects that arose as a result of these financial incentives, but further improvements to the core networking stack may still be necessary.

See also

References

  1. ^ Robert N M Watson (2007-11-25). "Before & After Under The Giant Lock". FreeBSD-Hackers@ (Mailing list). FreeBSD. Retrieved 2019-07-25.
  2. "git.kernel.org: BKL: that's all folks". Archived from the original on 2012-07-20. Retrieved 2019-12-28.
  3. https://kernelnewbies.org/BigKernelLock – BigKernelLock at kernelnewbies.org
  4. PATCH - fbcon: Make fbcon a built-time depency for fbdev. Daniel Vetter. June 28, 2017
  5. Thomas Gleixner (September 11, 2022). "[patch RFC 19/29] printk: Add basic infrastructure for non-BKL consoles". linux-kernel (Mailing list).
  6. Florian Westphal (November 2017). rtnl mutex, the network stack big kernel lock (PDF). netdev 2.2. Seoul.
  7. Kuniyuki Iwashima (September 18, 2024). Per Netns RTNL. Linux Plumbers Conference 2024. Vienna, Austria.
  8. "/sys/net/if.c". BSD Cross Reference. OpenBSD. 2019-06-30. Retrieved 2019-07-25. s = splnet();
  9. ^ "/sys/net/if.c". BSD Cross Reference. NetBSD. 2019-07-25. Retrieved 2019-07-25. s = splnet();
  10. "splx(9) — modify system interrupt priority level". NetBSD, OpenBSD. Retrieved 2019-07-25.
  11. ^ Matthew Dillon (2019-07-22). "DragonFlyBSD Project Update - colo upgrade, future trends". users@ (Mailing list). DragonFly BSD. Retrieved 2019-07-25.
  12. Julian Elischer (2007). "locking(9) — kernel synchronization primitives". BSD Cross Reference. FreeBSD. Retrieved 2019-07-25. Giant is a special mutex used to protect data structures that do not yet have their own locks. Since it provides semantics akin to the old spl(9) interface, …
  13. "SMP Networking (aka remove the big network lock)". NetBSD. 2013-02-14. Archived from the original on 2019-07-25. Retrieved 2023-03-26.
Category:
Giant lock: Difference between revisions Add topic