Revision as of 16:03, 9 January 2024 editJdbtwo (talk | contribs)Extended confirmed users695 edits Added references and mentioned the use of the WKdm and the hardware implementation in the Apple M1Tag: 2017 wikitext editor← Previous edit | Revision as of 16:06, 9 January 2024 edit undoJdbtwo (talk | contribs)Extended confirmed users695 edits Added intra-wiki linksTag: 2017 wikitext editorNext edit → | ||
Line 35: | Line 35: | ||
==Notable implementations== | ==Notable implementations== | ||
WKdm compression has been used by Apple's OSX since version 10.9 Mavericks in 2013<ref name="Arstechnica">{{Cite web|url=https://arstechnica.com/apple/2013/10/os-x-10-9/17/#compressed-memory|title=OS X 10.9 Mavericks: The Ars Technica Review|date=22 October 2013}}</ref><ref>{{cite web |url=https://www.apple.com/osx/all-features/pdf/osx_elcapitan_core_technologies_overview.pdf |title="OS X El Capitan Core Technologies Overview September 2015" |author=<!--Not stated--> |date=Sep 2015 |website=apple.com |access-date=9 Jan 2024}}</ref> and also in the shared source of the ] ] operating system / kernel.{{Citation needed|date=January 2024|reason=WKdm is used in at least the XNU kernel, and its implementation is available in Apple's and Github's source code browser, but I can't find a reliable source outside the source that mentions this}} WKdm compression is also used in the ] Linux kernel.<ref>{{cite web |url=https://marc.info/?l=olpc-linux-mm-cc&m=117972870310131&w=2 |title=" Compression structure implementation" |author=<!--Not stated--> |date=7 Jul 2006 |website=marc.info |access-date=9 Jan 2024}}</ref> Also, since the development of the Apple M1, Apple has included undocumented extensions to the ARM ISA that implement WKdm compression and decompression in hardware.<ref>{{cite web |url=https://news.ycombinator.com/item?id=25801500#25801602 |title="The Secret Apple M1 Coprocessor" |author=<!--Not stated--> |date=16 Jan 2021 |website=news.ycombinator.com |access-date=9 Jan 2024}}</ref><ref>{{cite web |url=https://forums.macrumors.com/threads/m1-owners-is-16gb-the-same-as-intel-or-has-it-better-memory-management.2280709/page-5?post=32051687#post-32051687 |title="M1 Owners: Is 16GB the same as Intel or has it better memory management?" |author=<!--Not stated--> |date=23 Mar 2023 |website=forums.macrumors.com |access-date=9 Jan 2024}}</ref><ref>{{cite web |url=https://github.com/AsahiLinux/docs/HW%3AApple-Instructions |title="HW:Apple Instructions" |author=<!--Not stated--> |date=4 Nov 2022 |website=github.com |access-date=9 Jan 2024}}</ref> | WKdm compression has been used by Apple's OSX since version 10.9 Mavericks in 2013<ref name="Arstechnica">{{Cite web|url=https://arstechnica.com/apple/2013/10/os-x-10-9/17/#compressed-memory|title=OS X 10.9 Mavericks: The Ars Technica Review|date=22 October 2013}}</ref><ref>{{cite web |url=https://www.apple.com/osx/all-features/pdf/osx_elcapitan_core_technologies_overview.pdf |title="OS X El Capitan Core Technologies Overview September 2015" |author=<!--Not stated--> |date=Sep 2015 |website=apple.com |access-date=9 Jan 2024}}</ref> and also in the shared source of the ] ] operating system / kernel.{{Citation needed|date=January 2024|reason=WKdm is used in at least the XNU kernel, and its implementation is available in Apple's and Github's source code browser, but I can't find a reliable source outside the source that mentions this}} WKdm compression is also used in the ] Linux kernel.<ref>{{cite web |url=https://marc.info/?l=olpc-linux-mm-cc&m=117972870310131&w=2 |title=" Compression structure implementation" |author=<!--Not stated--> |date=7 Jul 2006 |website=marc.info |access-date=9 Jan 2024}}</ref> Also, since the development of the ], Apple has included undocumented extensions to the ] that implement WKdm compression and decompression in hardware.<ref>{{cite web |url=https://news.ycombinator.com/item?id=25801500#25801602 |title="The Secret Apple M1 Coprocessor" |author=<!--Not stated--> |date=16 Jan 2021 |website=news.ycombinator.com |access-date=9 Jan 2024}}</ref><ref>{{cite web |url=https://forums.macrumors.com/threads/m1-owners-is-16gb-the-same-as-intel-or-has-it-better-memory-management.2280709/page-5?post=32051687#post-32051687 |title="M1 Owners: Is 16GB the same as Intel or has it better memory management?" |author=<!--Not stated--> |date=23 Mar 2023 |website=forums.macrumors.com |access-date=9 Jan 2024}}</ref><ref>{{cite web |url=https://github.com/AsahiLinux/docs/HW%3AApple-Instructions |title="HW:Apple Instructions" |author=<!--Not stated--> |date=4 Nov 2022 |website=github.com |access-date=9 Jan 2024}}</ref> | ||
Revision as of 16:06, 9 January 2024
Virtual memory compression algorithmReview waiting, please be patient.
This may take 2 months or more, since drafts are reviewed in no specific order. There are 1,767 pending submissions waiting for review.
Where to get help
You can also browse Misplaced Pages:Featured articles and Misplaced Pages:Good articles to find examples of Misplaced Pages's best writing on topics similar to your proposed article. Improving your odds of a speedy reviewTo improve your odds of a faster review, tag your draft with relevant WikiProject tags using the button below. This will let reviewers know a new draft has been submitted in their area of interest. For instance, if you wrote about a female astronomer, you would want to add the Biography, Astronomy, and Women scientists tags. Add tags to your draft Editor resources
Reviewer tools
|
Submission declined on 8 January 2024 by Lewcm (talk).This draft's references do not show that the subject qualifies for a Misplaced Pages article. In summary, the draft needs multiple published sources that are:
Where to get help
You can also browse Misplaced Pages:Featured articles and Misplaced Pages:Good articles to find examples of Misplaced Pages's best writing on topics similar to your proposed article. Improving your odds of a speedy reviewTo improve your odds of a faster review, tag your draft with relevant WikiProject tags using the button below. This will let reviewers know a new draft has been submitted in their area of interest. For instance, if you wrote about a female astronomer, you would want to add the Biography, Astronomy, and Women scientists tags. Add tags to your draft Editor resources
|
The WKdm algorithm is one of the first in the class of WK virtual memory compression techniques developed initially by Paul R. Wilson and Scott F. Kaplan et al. circa 1999. The "dm" in the WKdm acronym stands for "direct mapped" and refers to the direct mapped hash method used to map uncompressed words in memory to the WKdm algorithm's dictionary.
Motivation
The key insight on which the WKdm algorithm is built is the realization that most high-level programming languages compile to output whose data section(s) have certain very strong data regularities with regard to integers and pointers. Firstly, a large amount of integers and pointers are word-aligned within records, where "word" here and for the rest of this article is 32 bits. Additionally, most integers usually contain small values relative to their maximum ranges. For pointers, most proximal in memory to each other reference addresses that are close to each other in memory. Finally, certain data patterns, particularly words of all zeroes, frequently occur and this is exploited by the algorithm.
To make use of the above data regularities, one need only realize that, frequently, words will share many of their high-order bits either because they aren’t large enough to require a full-word bit width, or, said words are pointers whose values reference addresses close in memory to those referenced by nearby pointers. Also, words of all zeroes, which occur frequently, can be easily compressed.
Algorithm
Compression
The WKdm algorithm reads one word at a time from an address range, usually a page or pages, and uses a 16-entry direct mapped dictionary of words to produce compressed output which is segregated into four arrays or "segments" which contain, respectively, "tags" ( 2-bit values indicating the type of (non)match ), dictionary indices, unmatched words and the lower 10 bits of partially matched words. The tag, index and partial match values are initially output into bytes or words in their respective segments, before being “packed” after the number of words in the addresses range to be compressed is exhausted.
For each word read, the word is mapped to the dictionary using a direct-mapped hash, and then the type of (non)match is determined. If a full 32-bit word match is found in the dictionary, then a 2-bit "tag" value indicating a full-word match is written to the tags segment and the 4-bit index of the match within the dictionary is written to the indices segment. If only the high-order 22 bits match, then a different tag is written to the tags segment, the dictionary index of the partial match is output to the indices segment and the differing 10 lower-order bits are recorded in the partial match segment. If no match is found then the new value is added to the dictionary, as well as being emitted to the unmatched-words segment, and another tag signaling this is written to the tags segment. If the read word is all zeroes, then only one tag indicating this is output to the tags segment.
After all the words in the address range to be compressed have been read, the tags, indices and 10-bit partial match values, which are stored in bytes or words in their segments, are "packed" within their respective segments ( eg. their bits are made contiguous if their particular segment is taken to be one large bit vector. Additional steps may be taken — the exact details are implementation specific ) using bitwise operations to further reduce the compressed size of the data.
Decompression
Decompression is quite straightforward. The tags segment is processed one 2-bit tag at a time and action is taken depending on the value of the tag. If the value indicates a full-word match, then the corresponding dictionary index within the indices segment is referenced and the value referenced by the index in the dictionary is output. If a partial match is indicated, then the corresponding entry in the indices segment is consulted to look up the value that matches the high-order 22 bits and then the partial match segment is read to reconstruct the full 32-bit word, which is written to the uncompressed output. If the current tag indicates that there was no match, then the corresponding 32-bit word in the unmatched words segment is referenced and added to the dictionary as well as being emitted as part of the uncompressed output. If the tag indicates that a word was read that was all zeroes, then a 32-bit zero value is sent to the output.
Performance
From the authors' simulations and others', it was found that WKdm compression achieves a compression ratio comparable or superior to LZ-based dictionary compressors -- 2:1 to 2.5:1 . The WKdm algorithm also has much less overhead than an LZ-class compressor as it only uses a dictionary that is 64 bytes in size as compared to eg. 64 kilobytes. Furthermore, because of the simplicity of the algorithm, compression and decompression is usually much faster than traditional LZ-based compressors.
Notable implementations
WKdm compression has been used by Apple's OSX since version 10.9 Mavericks in 2013 and also in the shared source of the Darwin-XNU open source operating system / kernel. WKdm compression is also used in the OLPC Linux kernel. Also, since the development of the Apple M1, Apple has included undocumented extensions to the ARM ISA that implement WKdm compression and decompression in hardware.
See also
References
- ^ Wilson, Paul R.; Kaplan, Scott F.; Smaragdakis, Yannis (1999-06-06). The Case for Compressed Caching in Virtual Memory Systems (PDF). USENIX Annual Technical Conference. Monterey, California, USA. pp. 101–116.
- ^ Simpson, Matthew (12 Aug 2003). "Analysis of Compression Algorithms for Program Data" (PDF). umd.edu. Retrieved 6 Jan 2024.
- "OS X 10.9 Mavericks: The Ars Technica Review". 22 October 2013.
- ""OS X El Capitan Core Technologies Overview September 2015"" (PDF). apple.com. Sep 2015. Retrieved 9 Jan 2024.
- ""[linux-mm-cc] Compression structure implementation"". marc.info. 7 Jul 2006. Retrieved 9 Jan 2024.
- ""The Secret Apple M1 Coprocessor"". news.ycombinator.com. 16 Jan 2021. Retrieved 9 Jan 2024.
- ""M1 Owners: Is 16GB the same as Intel or has it better memory management?"". forums.macrumors.com. 23 Mar 2023. Retrieved 9 Jan 2024.
- ""HW:Apple Instructions"". github.com. 4 Nov 2022. Retrieved 9 Jan 2024.