diff --git a/ch9-log/.lock b/ch9-log/.lock
new file mode 100755
index 00000000..e69de29b
diff --git a/ch9-log/COPYRIGHT.txt b/ch9-log/COPYRIGHT.txt
new file mode 100644
index 00000000..c2629a83
--- /dev/null
+++ b/ch9-log/COPYRIGHT.txt
@@ -0,0 +1,50 @@
+These documentation pages include resources by third parties. This copyright
+file applies only to those resources. The following third party resources are
+included, and carry their own copyright notices and license terms:
+
+* Fira Sans (FiraSans-Regular.woff2, FiraSans-Medium.woff2,
+ FiraSans-Regular.woff, FiraSans-Medium.woff):
+
+ Copyright (c) 2014, Mozilla Foundation https://mozilla.org/
+ with Reserved Font Name Fira Sans.
+
+ Copyright (c) 2014, Telefonica S.A.
+
+ Licensed under the SIL Open Font License, Version 1.1.
+ See FiraSans-LICENSE.txt.
+
+* rustdoc.css, main.js, and playpen.js:
+
+ Copyright 2015 The Rust Developers.
+ Licensed under the Apache License, Version 2.0 (see LICENSE-APACHE.txt) or
+ the MIT license (LICENSE-MIT.txt) at your option.
+
+* normalize.css:
+
+ Copyright (c) Nicolas Gallagher and Jonathan Neal.
+ Licensed under the MIT license (see LICENSE-MIT.txt).
+
+* Source Code Pro (SourceCodePro-Regular.ttf.woff2,
+ SourceCodePro-Semibold.ttf.woff2, SourceCodePro-It.ttf.woff2,
+ SourceCodePro-Regular.ttf.woff, SourceCodePro-Semibold.ttf.woff,
+ SourceCodePro-It.ttf.woff):
+
+ Copyright 2010, 2012 Adobe Systems Incorporated (http://www.adobe.com/),
+ with Reserved Font Name 'Source'. All Rights Reserved. Source is a trademark
+ of Adobe Systems Incorporated in the United States and/or other countries.
+
+ Licensed under the SIL Open Font License, Version 1.1.
+ See SourceCodePro-LICENSE.txt.
+
+* Source Serif 4 (SourceSerif4-Regular.ttf.woff2, SourceSerif4-Bold.ttf.woff2,
+ SourceSerif4-It.ttf.woff2, SourceSerif4-Regular.ttf.woff,
+ SourceSerif4-Bold.ttf.woff, SourceSerif4-It.ttf.woff):
+
+ Copyright 2014-2021 Adobe (http://www.adobe.com/), with Reserved Font Name
+ 'Source'. All Rights Reserved. Source is a trademark of Adobe in the United
+ States and/or other countries.
+
+ Licensed under the SIL Open Font License, Version 1.1.
+ See SourceSerif4-LICENSE.md.
+
+This copyright file is intended to be distributed with rustdoc output.
diff --git a/ch9-log/FiraSans-LICENSE.txt b/ch9-log/FiraSans-LICENSE.txt
new file mode 100644
index 00000000..ff9afab0
--- /dev/null
+++ b/ch9-log/FiraSans-LICENSE.txt
@@ -0,0 +1,94 @@
+Digitized data copyright (c) 2012-2015, The Mozilla Foundation and Telefonica S.A.
+with Reserved Font Name < Fira >,
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at:
+http://scripts.sil.org/OFL
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/ch9-log/FiraSans-Medium.woff b/ch9-log/FiraSans-Medium.woff
new file mode 100644
index 00000000..7d742c5f
Binary files /dev/null and b/ch9-log/FiraSans-Medium.woff differ
diff --git a/ch9-log/FiraSans-Medium.woff2 b/ch9-log/FiraSans-Medium.woff2
new file mode 100644
index 00000000..7a1e5fc5
Binary files /dev/null and b/ch9-log/FiraSans-Medium.woff2 differ
diff --git a/ch9-log/FiraSans-Regular.woff b/ch9-log/FiraSans-Regular.woff
new file mode 100644
index 00000000..d8e0363f
Binary files /dev/null and b/ch9-log/FiraSans-Regular.woff differ
diff --git a/ch9-log/FiraSans-Regular.woff2 b/ch9-log/FiraSans-Regular.woff2
new file mode 100644
index 00000000..e766e06c
Binary files /dev/null and b/ch9-log/FiraSans-Regular.woff2 differ
diff --git a/ch9-log/LICENSE-APACHE.txt b/ch9-log/LICENSE-APACHE.txt
new file mode 100644
index 00000000..16fe87b0
--- /dev/null
+++ b/ch9-log/LICENSE-APACHE.txt
@@ -0,0 +1,201 @@
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+END OF TERMS AND CONDITIONS
+
+APPENDIX: How to apply the Apache License to your work.
+
+ To apply the Apache License to your work, attach the following
+ boilerplate notice, with the fields enclosed by brackets "[]"
+ replaced with your own identifying information. (Don't include
+ the brackets!) The text should be enclosed in the appropriate
+ comment syntax for the file format. We also recommend that a
+ file or class name and description of purpose be included on the
+ same "printed page" as the copyright notice for easier
+ identification within third-party archives.
+
+Copyright [yyyy] [name of copyright owner]
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
diff --git a/ch9-log/LICENSE-MIT.txt b/ch9-log/LICENSE-MIT.txt
new file mode 100644
index 00000000..31aa7938
--- /dev/null
+++ b/ch9-log/LICENSE-MIT.txt
@@ -0,0 +1,23 @@
+Permission is hereby granted, free of charge, to any
+person obtaining a copy of this software and associated
+documentation files (the "Software"), to deal in the
+Software without restriction, including without
+limitation the rights to use, copy, modify, merge,
+publish, distribute, sublicense, and/or sell copies of
+the Software, and to permit persons to whom the Software
+is furnished to do so, subject to the following
+conditions:
+
+The above copyright notice and this permission notice
+shall be included in all copies or substantial portions
+of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF
+ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
+TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
+PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
+SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
+IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+DEALINGS IN THE SOFTWARE.
diff --git a/ch9-log/NanumBarunGothic-LICENSE.txt b/ch9-log/NanumBarunGothic-LICENSE.txt
new file mode 100644
index 00000000..0bf46682
--- /dev/null
+++ b/ch9-log/NanumBarunGothic-LICENSE.txt
@@ -0,0 +1,99 @@
+Copyright (c) 2010, NAVER Corporation (https://www.navercorp.com/),
+
+with Reserved Font Name Nanum, Naver Nanum, NanumGothic, Naver NanumGothic,
+NanumMyeongjo, Naver NanumMyeongjo, NanumBrush, Naver NanumBrush, NanumPen,
+Naver NanumPen, Naver NanumGothicEco, NanumGothicEco, Naver NanumMyeongjoEco,
+NanumMyeongjoEco, Naver NanumGothicLight, NanumGothicLight, NanumBarunGothic,
+Naver NanumBarunGothic, NanumSquareRound, NanumBarunPen, MaruBuri
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at:
+http://scripts.sil.org/OFL
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/ch9-log/NanumBarunGothic.ttf.woff b/ch9-log/NanumBarunGothic.ttf.woff
new file mode 100644
index 00000000..fb063e8f
Binary files /dev/null and b/ch9-log/NanumBarunGothic.ttf.woff differ
diff --git a/ch9-log/NanumBarunGothic.ttf.woff2 b/ch9-log/NanumBarunGothic.ttf.woff2
new file mode 100644
index 00000000..1866ad4b
Binary files /dev/null and b/ch9-log/NanumBarunGothic.ttf.woff2 differ
diff --git a/ch9-log/SourceCodePro-It.ttf.woff b/ch9-log/SourceCodePro-It.ttf.woff
new file mode 100644
index 00000000..8d68f2fe
Binary files /dev/null and b/ch9-log/SourceCodePro-It.ttf.woff differ
diff --git a/ch9-log/SourceCodePro-It.ttf.woff2 b/ch9-log/SourceCodePro-It.ttf.woff2
new file mode 100644
index 00000000..462c34ef
Binary files /dev/null and b/ch9-log/SourceCodePro-It.ttf.woff2 differ
diff --git a/ch9-log/SourceCodePro-LICENSE.txt b/ch9-log/SourceCodePro-LICENSE.txt
new file mode 100644
index 00000000..07542572
--- /dev/null
+++ b/ch9-log/SourceCodePro-LICENSE.txt
@@ -0,0 +1,93 @@
+Copyright 2010, 2012 Adobe Systems Incorporated (http://www.adobe.com/), with Reserved Font Name 'Source'. All Rights Reserved. Source is a trademark of Adobe Systems Incorporated in the United States and/or other countries.
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+
+This license is copied below, and is also available with a FAQ at: http://scripts.sil.org/OFL
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/ch9-log/SourceCodePro-Regular.ttf.woff b/ch9-log/SourceCodePro-Regular.ttf.woff
new file mode 100644
index 00000000..7be076e1
Binary files /dev/null and b/ch9-log/SourceCodePro-Regular.ttf.woff differ
diff --git a/ch9-log/SourceCodePro-Regular.ttf.woff2 b/ch9-log/SourceCodePro-Regular.ttf.woff2
new file mode 100644
index 00000000..10b558e0
Binary files /dev/null and b/ch9-log/SourceCodePro-Regular.ttf.woff2 differ
diff --git a/ch9-log/SourceCodePro-Semibold.ttf.woff b/ch9-log/SourceCodePro-Semibold.ttf.woff
new file mode 100644
index 00000000..61bc67b8
Binary files /dev/null and b/ch9-log/SourceCodePro-Semibold.ttf.woff differ
diff --git a/ch9-log/SourceCodePro-Semibold.ttf.woff2 b/ch9-log/SourceCodePro-Semibold.ttf.woff2
new file mode 100644
index 00000000..5ec64eef
Binary files /dev/null and b/ch9-log/SourceCodePro-Semibold.ttf.woff2 differ
diff --git a/ch9-log/SourceSerif4-Bold.ttf.woff b/ch9-log/SourceSerif4-Bold.ttf.woff
new file mode 100644
index 00000000..8ad41888
Binary files /dev/null and b/ch9-log/SourceSerif4-Bold.ttf.woff differ
diff --git a/ch9-log/SourceSerif4-Bold.ttf.woff2 b/ch9-log/SourceSerif4-Bold.ttf.woff2
new file mode 100644
index 00000000..db57d214
Binary files /dev/null and b/ch9-log/SourceSerif4-Bold.ttf.woff2 differ
diff --git a/ch9-log/SourceSerif4-It.ttf.woff b/ch9-log/SourceSerif4-It.ttf.woff
new file mode 100644
index 00000000..2a34b5c4
Binary files /dev/null and b/ch9-log/SourceSerif4-It.ttf.woff differ
diff --git a/ch9-log/SourceSerif4-It.ttf.woff2 b/ch9-log/SourceSerif4-It.ttf.woff2
new file mode 100644
index 00000000..1cbc021a
Binary files /dev/null and b/ch9-log/SourceSerif4-It.ttf.woff2 differ
diff --git a/ch9-log/SourceSerif4-LICENSE.md b/ch9-log/SourceSerif4-LICENSE.md
new file mode 100644
index 00000000..68ea1892
--- /dev/null
+++ b/ch9-log/SourceSerif4-LICENSE.md
@@ -0,0 +1,93 @@
+Copyright 2014-2021 Adobe (http://www.adobe.com/), with Reserved Font Name 'Source'. All Rights Reserved. Source is a trademark of Adobe in the United States and/or other countries.
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+
+This license is copied below, and is also available with a FAQ at: http://scripts.sil.org/OFL
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/ch9-log/SourceSerif4-Regular.ttf.woff b/ch9-log/SourceSerif4-Regular.ttf.woff
new file mode 100644
index 00000000..45a5521a
Binary files /dev/null and b/ch9-log/SourceSerif4-Regular.ttf.woff differ
diff --git a/ch9-log/SourceSerif4-Regular.ttf.woff2 b/ch9-log/SourceSerif4-Regular.ttf.woff2
new file mode 100644
index 00000000..2db73fe2
Binary files /dev/null and b/ch9-log/SourceSerif4-Regular.ttf.woff2 differ
diff --git a/ch9-log/ayu.css b/ch9-log/ayu.css
new file mode 100644
index 00000000..dea87bf1
--- /dev/null
+++ b/ch9-log/ayu.css
@@ -0,0 +1 @@
+ body{background-color:#0f1419;color:#c5c5c5;}h1,h2,h3,h4{color:white;}h1.fqn{border-bottom-color:#5c6773;}h1.fqn a{color:#fff;}h2,h3,h4{border-bottom-color:#5c6773;}h4{border:none;}.in-band{background-color:#0f1419;}.invisible{background:rgba(0,0,0,0);}.docblock code{color:#ffb454;}.code-header{color:#e6e1cf;}.docblock pre>code,pre>code{color:#e6e1cf;}span code{color:#e6e1cf;}.docblock a>code{color:#39AFD7 !important;}.docblock code,.docblock-short code{background-color:#191f26;}pre,.rustdoc.source .example-wrap{color:#e6e1cf;background-color:#191f26;}.sidebar{background-color:#14191f;}.rust-logo{filter:drop-shadow(1px 0 0px #fff) drop-shadow(0 1px 0 #fff) drop-shadow(-1px 0 0 #fff) drop-shadow(0 -1px 0 #fff);}*{scrollbar-color:#5c6773 #24292f;}.sidebar{scrollbar-color:#5c6773 #24292f;}::-webkit-scrollbar-track{background-color:transparent;}::-webkit-scrollbar-thumb{background-color:#5c6773;}.sidebar::-webkit-scrollbar-track{background-color:transparent;}.sidebar::-webkit-scrollbar-thumb{background-color:#5c6773;}.sidebar .current{background-color:transparent;color:#ffb44c;}.source .sidebar{background-color:#14191f;}.sidebar .location{border-color:#000;background-color:#0f1419;color:#fff;}.sidebar-elems .location{color:#ff7733;}.sidebar-elems .location a{color:#fff;}.sidebar .version{border-bottom-color:#424c57;}.sidebar-title{border-top-color:#5c6773;border-bottom-color:#5c6773;}.block a:hover{background:transparent;color:#ffb44c;}.line-numbers span{color:#5c6773;}.line-numbers .line-highlighted{color:#708090;background-color:rgba(255,236,164,0.06);padding-right:4px;border-right:1px solid #ffb44c;}.docblock h1,.docblock h2,.docblock h3,.docblock h4,.docblock h5,.docblock h6{border-bottom-color:#5c6773;}.docblock table td,.docblock table th{border-color:#5c6773;}.content .method .where,.content .fn .where,.content .where.fmt-newline{color:#c5c5c5;}.search-results a:hover{background-color:#777;}.search-results a:focus{color:#000 !important;background-color:#c6afb3;}.search-results a{color:#0096cf;}.search-results a div.desc{color:#c5c5c5;}.content .item-info::before{color:#ccc;}.content span.foreigntype,.content a.foreigntype{color:#ffa0a5;}.content span.union,.content a.union{color:#ffa0a5;}.content span.constant,.content a.constant,.content span.static,.content a.static{color:#39AFD7;}.content span.primitive,.content a.primitive{color:#ffa0a5;}.content span.traitalias,.content a.traitalias{color:#39AFD7;}.content span.keyword,.content a.keyword{color:#39AFD7;}.content span.externcrate,.content span.mod,.content a.mod{color:#39AFD7;}.content span.struct,.content a.struct{color:#ffa0a5;}.content span.enum,.content a.enum{color:#ffa0a5;}.content span.trait,.content a.trait{color:#39AFD7;}.content span.type,.content a.type{color:#39AFD7;}.content span.type,.content a.type,.block a.current.type{color:#39AFD7;}.content span.associatedtype,.content a.associatedtype,.block a.current.associatedtype{color:#39AFD7;}.content span.fn,.content a.fn,.content span.method,.content a.method,.content span.tymethod,.content a.tymethod,.content .fnname{color:#fdd687;}.content span.attr,.content a.attr,.content span.derive,.content a.derive,.content span.macro,.content a.macro{color:#a37acc;}pre.rust .comment{color:#788797;}pre.rust .doccomment{color:#a1ac88;}nav:not(.sidebar){border-bottom-color:#424c57;}nav.main .current{border-top-color:#5c6773;border-bottom-color:#5c6773;}nav.main .separator{border:1px solid #5c6773;}a{color:#39AFD7;}a#toggle-all-docs,a.anchor,.small-section-header a,#source-sidebar a,pre.rust a,.sidebar a,.in-band a{color:#c5c5c5;}.search-results a{color:#0096cf;}body.source .example-wrap pre.rust a{background:#333;}details.rustdoc-toggle>summary.hideme>span,details.rustdoc-toggle>summary::before,details.undocumented>summary::before{color:#999;}details.rustdoc-toggle>summary::before,details.undocumented>summary::before{filter:invert(100%);}#crate-search{color:#c5c5c5;background-color:#141920;box-shadow:0 0 0 1px #424c57,0 0 0 2px transparent;border-color:#424c57;}.search-input{color:#ffffff;background-color:#141920;box-shadow:0 0 0 1px #424c57,0 0 0 2px transparent;transition:box-shadow 150ms ease-in-out;}#crate-search+.search-input:focus{box-shadow:0 0 0 1px #148099,0 0 0 2px transparent;}.module-item .stab,.import-item .stab{color:#000;}.stab.unstable,.stab.deprecated,.stab.portability{color:#c5c5c5;background:#314559 !important;border-style:none !important;border-radius:4px;padding:3px 6px 3px 6px;}.stab.portability>code{color:#e6e1cf;background:none;}#help>div{background:#14191f;box-shadow:0px 6px 20px 0px black;border:none;border-radius:4px;}#help span.bottom,#help span.top{border-color:#5c6773;}.rightside,.out-of-band{color:grey;}.result-name .primitive>i,.result-name .keyword>i{color:#788797;}.line-numbers :target{background-color:transparent;}pre.rust .number,pre.rust .string{color:#b8cc52;}pre.rust .kw,pre.rust .kw-2,pre.rust .prelude-ty,pre.rust .bool-val,pre.rust .prelude-val,pre.rust .op,pre.rust .lifetime{color:#ff7733;}pre.rust .macro,pre.rust .macro-nonterminal{color:#a37acc;}pre.rust .question-mark{color:#ff9011;}pre.rust .self{color:#36a3d9;font-style:italic;}pre.rust .attribute{color:#e6e1cf;}pre.rust .attribute .ident,pre.rust .attribute .op{color:#e6e1cf;}.example-wrap>pre.line-number{color:#5c67736e;border:none;}a.test-arrow{font-size:100%;color:#788797;border-radius:4px;background-color:rgba(57,175,215,0.09);}a.test-arrow:hover{background-color:rgba(57,175,215,0.368);color:#c5c5c5;}.toggle-label,.code-attribute{color:#999;}:target{background:rgba(255,236,164,0.06);border-right:3px solid rgba(255,180,76,0.85);}pre.compile_fail{border-left:2px solid rgba(255,0,0,.4);}pre.compile_fail:hover,.information:hover+pre.compile_fail{border-left:2px solid #f00;}pre.should_panic{border-left:2px solid rgba(255,0,0,.4);}pre.should_panic:hover,.information:hover+pre.should_panic{border-left:2px solid #f00;}pre.ignore{border-left:2px solid rgba(255,142,0,.6);}pre.ignore:hover,.information:hover+pre.ignore{border-left:2px solid #ff9200;}.tooltip.compile_fail{color:rgba(255,0,0,.5);}.information>.compile_fail:hover{color:#f00;}.tooltip.should_panic{color:rgba(255,0,0,.5);}.information>.should_panic:hover{color:#f00;}.tooltip.ignore{color:rgba(255,142,0,.6);}.information>.ignore:hover{color:#ff9200;}.search-failed a{color:#39AFD7;}.tooltip::after{background-color:#314559;color:#c5c5c5;border:1px solid #5c6773;}.tooltip::before{border-color:transparent #314559 transparent transparent;}.notable-traits-tooltiptext{background-color:#314559;border-color:#5c6773;}.notable-traits-tooltiptext .notable{border-bottom-color:#5c6773;}#titles>button.selected{background-color:#141920 !important;border-bottom:1px solid #ffb44c !important;border-top:none;}#titles>button:not(.selected){background-color:transparent !important;border:none;}#titles>button:hover{border-bottom:1px solid rgba(242,151,24,0.3);}#titles>button>div.count{color:#888;}.search-input:focus{}.content span.attr,.content a.attr,.block a.current.attr,.content span.derive,.content a.derive,.block a.current.derive,.content span.macro,.content a.macro,.block a.current.macro{}.content span.struct,.content a.struct,.block a.current.struct{}#titles>button:hover,#titles>button.selected{}.content span.typedef,.content a.typedef,.block a.current.typedef{}.content span.union,.content a.union,.block a.current.union{}pre.rust .lifetime{}.stab.unstable{}h2,h3:not(.impl):not(.method):not(.type):not(.tymethod),h4:not(.method):not(.type):not(.tymethod){}.content span.enum,.content a.enum,.block a.current.enum{}.content span.constant,.content a.constant,.block a.current.constant,.content span.static,.content a.static,.block a.current.static{}.content span.keyword,.content a.keyword,.block a.current.keyword{}pre.rust .comment{}.content span.traitalias,.content a.traitalias,.block a.current.traitalias{}.content span.fn,.content a.fn,.block a.current.fn,.content span.method,.content a.method,.block a.current.method,.content span.tymethod,.content a.tymethod,.block a.current.tymethod,.content .fnname{}pre.rust .kw{}pre.rust .self,pre.rust .bool-val,pre.rust .prelude-val,pre.rust .attribute,pre.rust .attribute .ident{}.content span.foreigntype,.content a.foreigntype,.block a.current.foreigntype{}pre.rust .doccomment{}.stab.deprecated{}.content a.attr,.content a.derive,.content a.macro{}.stab.portability{}.content span.primitive,.content a.primitive,.block a.current.primitive{}.content span.externcrate,.content span.mod,.content a.mod,.block a.current.mod{}pre.rust .kw-2,pre.rust .prelude-ty{}.content span.trait,.content a.trait,.block a.current.trait{}.search-results a:focus span{}a.result-trait:focus{}a.result-traitalias:focus{}a.result-mod:focus,a.result-externcrate:focus{}a.result-mod:focus{}a.result-externcrate:focus{}a.result-enum:focus{}a.result-struct:focus{}a.result-union:focus{}a.result-fn:focus,a.result-method:focus,a.result-tymethod:focus{}a.result-type:focus{}a.result-associatedtype:focus{}a.result-foreigntype:focus{}a.result-attr:focus,a.result-derive:focus,a.result-macro:focus{}a.result-constant:focus,a.result-static:focus{}a.result-primitive:focus{}a.result-keyword:focus{}@media (max-width:700px){.sidebar-menu{background-color:#14191f;border-bottom-color:#5c6773;border-right-color:#5c6773;}.sidebar-elems{background-color:#14191f;border-right-color:#5c6773;}#sidebar-filler{background-color:#14191f;border-bottom-color:#5c6773;}}kbd{color:#c5c5c5;background-color:#314559;border-color:#5c6773;border-bottom-color:#5c6773;box-shadow-color:#c6cbd1;}#theme-picker,#settings-menu,#help-button{border-color:#5c6773;background-color:#0f1419;color:#fff;}#theme-picker>img,#settings-menu>img{filter:invert(100);}#copy-path{color:#fff;}#copy-path>img{filter:invert(70%);}#copy-path:hover>img{filter:invert(100%);}#theme-picker:hover,#theme-picker:focus,#settings-menu:hover,#settings-menu:focus,#help-button:hover,#help-button:focus{border-color:#e0e0e0;}#theme-choices{border-color:#5c6773;background-color:#0f1419;}#theme-choices>button:not(:first-child){border-top-color:#5c6773;}#theme-choices>button:hover,#theme-choices>button:focus{background-color:rgba(110,110,110,0.33);}@media (max-width:700px){#theme-picker{background:#0f1419;}}#all-types{background-color:#14191f;}#all-types:hover{background-color:rgba(70,70,70,0.33);}.search-results .result-name span.alias{color:#c5c5c5;}.search-results .result-name span.grey{color:#999;}#sidebar-toggle{background-color:#14191f;}#sidebar-toggle:hover{background-color:rgba(70,70,70,0.33);}#source-sidebar{background-color:#14191f;}#source-sidebar>.title{color:#fff;border-bottom-color:#5c6773;}div.files>a:hover,div.name:hover{background-color:#14191f;color:#ffb44c;}div.files>.selected{background-color:#14191f;color:#ffb44c;}.setting-line>.title{border-bottom-color:#5c6773;}input:checked+.slider{background-color:#ffb454 !important;}.scraped-example .example-wrap .rust span.highlight{background:rgb(91,59,1);}.scraped-example .example-wrap .rust span.highlight.focus{background:rgb(124,75,15);}.scraped-example:not(.expanded) .code-wrapper:before{background:linear-gradient(to bottom,rgba(15,20,25,1),rgba(15,20,25,0));}.scraped-example:not(.expanded) .code-wrapper:after{background:linear-gradient(to top,rgba(15,20,25,1),rgba(15,20,25,0));}.toggle-line-inner{background:#616161;}.toggle-line:hover .toggle-line-inner{background:##898989;}
\ No newline at end of file
diff --git a/ch9-log/brush.svg b/ch9-log/brush.svg
new file mode 100644
index 00000000..ea266e85
--- /dev/null
+++ b/ch9-log/brush.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/ch9-log/clipboard.svg b/ch9-log/clipboard.svg
new file mode 100644
index 00000000..8adbd996
--- /dev/null
+++ b/ch9-log/clipboard.svg
@@ -0,0 +1 @@
+
diff --git a/ch9-log/crates.js b/ch9-log/crates.js
new file mode 100644
index 00000000..58e198fb
--- /dev/null
+++ b/ch9-log/crates.js
@@ -0,0 +1 @@
+window.ALL_CRATES = ["os"];
\ No newline at end of file
diff --git a/ch9-log/dark.css b/ch9-log/dark.css
new file mode 100644
index 00000000..5b8e0f75
--- /dev/null
+++ b/ch9-log/dark.css
@@ -0,0 +1 @@
+body{background-color:#353535;color:#ddd;}h1,h2,h3,h4{color:#ddd;}h1.fqn{border-bottom-color:#d2d2d2;}h2,h3,h4{border-bottom-color:#d2d2d2;}.in-band{background-color:#353535;}.invisible{background:rgba(0,0,0,0);}.docblock code,.docblock-short code{background-color:#2A2A2A;}pre,.rustdoc.source .example-wrap{background-color:#2A2A2A;}.sidebar{background-color:#505050;}.rust-logo{filter:drop-shadow(1px 0 0px #fff) drop-shadow(0 1px 0 #fff) drop-shadow(-1px 0 0 #fff) drop-shadow(0 -1px 0 #fff)}*{scrollbar-color:rgb(64,65,67) #717171;}.sidebar{scrollbar-color:rgba(32,34,37,.6) #5a5a5a;}::-webkit-scrollbar-track{background-color:#717171;}::-webkit-scrollbar-thumb{background-color:rgba(32,34,37,.6);}.sidebar::-webkit-scrollbar-track{background-color:#717171;}.sidebar::-webkit-scrollbar-thumb{background-color:rgba(32,34,37,.6);}.sidebar .current{background-color:#333;}.source .sidebar{background-color:#565656;}.sidebar .location{border-color:#fff;background:#575757;color:#DDD;}.sidebar .version{border-bottom-color:#DDD;}.sidebar-title{border-top-color:#777;border-bottom-color:#777;}.block a:hover{background:#444;}.line-numbers span{color:#3B91E2;}.line-numbers .line-highlighted{background-color:#0a042f !important;}.docblock h1,.docblock h2,.docblock h3,.docblock h4,.docblock h5,.docblock h6{border-bottom-color:#DDD;}.docblock table td,.docblock table th{border-color:#ddd;}.content .method .where,.content .fn .where,.content .where.fmt-newline{color:#ddd;}.search-results a:hover{background-color:#777;}.search-results a:focus{color:#eee !important;background-color:#616161;}.search-results a:focus span{color:#eee !important;}a.result-trait:focus{background-color:#013191;}a.result-traitalias:focus{background-color:#013191;}a.result-mod:focus,a.result-externcrate:focus{background-color:#884719;}a.result-enum:focus{background-color:#194e9f;}a.result-struct:focus{background-color:#194e9f;}a.result-union:focus{background-color:#194e9f;}a.result-fn:focus,a.result-method:focus,a.result-tymethod:focus{background-color:#4950ed;}a.result-type:focus{background-color:#194e9f;}a.result-associatedtype:focus{background-color:#884719;}a.result-foreigntype:focus{background-color:#194e9f;}a.result-attr:focus,a.result-derive:focus,a.result-macro:focus{background-color:#217d1c;}a.result-constant:focus,a.result-static:focus{background-color:#884719;}a.result-primitive:focus{background-color:#194e9f;}a.result-keyword:focus{background-color:#884719;}.content .item-info::before{color:#ccc;}.content span.enum,.content a.enum,.block a.current.enum{color:#2dbfb8;}.content span.struct,.content a.struct,.block a.current.struct{color:#2dbfb8;}.content span.type,.content a.type,.block a.current.type{color:#2dbfb8;}.content span.associatedtype,.content a.associatedtype,.block a.current.associatedtype{color:#D2991D;}.content span.foreigntype,.content a.foreigntype,.block a.current.foreigntype{color:#2dbfb8;}.content span.attr,.content a.attr,.block a.current.attr,.content span.derive,.content a.derive,.block a.current.derive,.content span.macro,.content a.macro,.block a.current.macro{color:#09bd00;}.content span.union,.content a.union,.block a.current.union{color:#2dbfb8;}.content span.constant,.content a.constant,.block a.current.constant,.content span.static,.content a.static,.block a.current.static{color:#D2991D;}.content span.primitive,.content a.primitive,.block a.current.primitive{color:#2dbfb8;}.content span.externcrate,.content span.mod,.content a.mod,.block a.current.mod{color:#D2991D;}.content span.trait,.content a.trait,.block a.current.trait{color:#b78cf2;}.content span.traitalias,.content a.traitalias,.block a.current.traitalias{color:#b78cf2;}.content span.fn,.content a.fn,.block a.current.fn,.content span.method,.content a.method,.block a.current.method,.content span.tymethod,.content a.tymethod,.block a.current.tymethod,.content .fnname{color:#2BAB63;}.content span.keyword,.content a.keyword,.block a.current.keyword{color:#D2991D;}pre.rust .comment{color:#8d8d8b;}pre.rust .doccomment{color:#8ca375;}nav:not(.sidebar){border-bottom-color:#4e4e4e;}nav.main .current{border-top-color:#eee;border-bottom-color:#eee;}nav.main .separator{border-color:#eee;}a{color:#D2991D;}a#toggle-all-docs,a.anchor,.small-section-header a,#source-sidebar a,pre.rust a,.sidebar a,.in-band a{color:#ddd;}.search-results a{color:#ddd;}a.test-arrow{color:#dedede;}body.source .example-wrap pre.rust a{background:#333;}details.rustdoc-toggle>summary.hideme>span,details.rustdoc-toggle>summary::before,details.undocumented>summary::before{color:#999;}details.rustdoc-toggle>summary::before,details.undocumented>summary::before{filter:invert(100%);}#crate-search{color:#111;background-color:#f0f0f0;border-color:#000;box-shadow:0 0 0 1px #000,0 0 0 2px transparent;}.search-input{color:#111;background-color:#f0f0f0;box-shadow:0 0 0 1px #000,0 0 0 2px transparent;}.search-input:focus{border-color:#008dfd;}#crate-search+.search-input:focus{box-shadow:0 0 8px 4px #078dd8;}.module-item .stab,.import-item .stab{color:#ddd;}.stab.unstable{background:#FFF5D6;border-color:#FFC600;color:#2f2f2f;}.stab.deprecated{background:#ffc4c4;border-color:#db7b7b;color:#2f2f2f;}.stab.portability{background:#F3DFFF;border-color:#b07bdb;color:#2f2f2f;}.stab.portability>code{background:none;}#help>div{background:#4d4d4d;border-color:#bfbfbf;}#help span.bottom,#help span.top{border-color:#bfbfbf;}#help dt{border-color:#bfbfbf;background:rgba(0,0,0,0);}.rightside,.out-of-band{color:grey;}.result-name .primitive>i,.result-name .keyword>i{color:#ddd;}.line-numbers :target{background-color:transparent;}pre.rust .kw{color:#ab8ac1;}pre.rust .kw-2,pre.rust .prelude-ty{color:#769acb;}pre.rust .number,pre.rust .string{color:#83a300;}pre.rust .self,pre.rust .bool-val,pre.rust .prelude-val,pre.rust .attribute,pre.rust .attribute .ident{color:#ee6868;}pre.rust .macro,pre.rust .macro-nonterminal{color:#3E999F;}pre.rust .lifetime{color:#d97f26;}pre.rust .question-mark{color:#ff9011;}.example-wrap>pre.line-number{border-color:#4a4949;}a.test-arrow{background-color:rgba(78,139,202,0.2);}a.test-arrow:hover{background-color:#4e8bca;}.toggle-label,.code-attribute{color:#999;}:target{background-color:#494a3d;border-right:3px solid #bb7410;}pre.compile_fail{border-left:2px solid rgba(255,0,0,.8);}pre.compile_fail:hover,.information:hover+pre.compile_fail{border-left:2px solid #f00;}pre.should_panic{border-left:2px solid rgba(255,0,0,.8);}pre.should_panic:hover,.information:hover+pre.should_panic{border-left:2px solid #f00;}pre.ignore{border-left:2px solid rgba(255,142,0,.6);}pre.ignore:hover,.information:hover+pre.ignore{border-left:2px solid #ff9200;}.tooltip.compile_fail{color:rgba(255,0,0,.8);}.information>.compile_fail:hover{color:#f00;}.tooltip.should_panic{color:rgba(255,0,0,.8);}.information>.should_panic:hover{color:#f00;}.tooltip.ignore{color:rgba(255,142,0,.6);}.information>.ignore:hover{color:#ff9200;}.search-failed a{color:#0089ff;}.tooltip::after{background-color:#000;color:#fff;border-color:#000;}.tooltip::before{border-color:transparent black transparent transparent;}.notable-traits-tooltiptext{background-color:#111;border-color:#777;}.notable-traits-tooltiptext .notable{border-bottom-color:#d2d2d2;}#titles>button:not(.selected){background-color:#252525;border-top-color:#252525;}#titles>button:hover,#titles>button.selected{border-top-color:#0089ff;background-color:#353535;}#titles>button>div.count{color:#888;}@media (max-width:700px){.sidebar-menu{background-color:#505050;border-bottom-color:#e0e0e0;border-right-color:#e0e0e0;}.sidebar-elems{background-color:#505050;border-right-color:#000;}#sidebar-filler{background-color:#505050;border-bottom-color:#e0e0e0;}}kbd{color:#000;background-color:#fafbfc;border-color:#d1d5da;border-bottom-color:#c6cbd1;box-shadow-color:#c6cbd1;}#theme-picker,#settings-menu,#help-button{border-color:#e0e0e0;background:#f0f0f0;color:#000;}#theme-picker:hover,#theme-picker:focus,#settings-menu:hover,#settings-menu:focus,#help-button:hover,#help-button:focus{border-color:#ffb900;}#copy-path{color:#999;}#copy-path>img{filter:invert(50%);}#copy-path:hover>img{filter:invert(65%);}#theme-choices{border-color:#e0e0e0;background-color:#353535;}#theme-choices>button:not(:first-child){border-top-color:#e0e0e0;}#theme-choices>button:hover,#theme-choices>button:focus{background-color:#4e4e4e;}@media (max-width:700px){#theme-picker{background:#f0f0f0;}}#all-types{background-color:#505050;}#all-types:hover{background-color:#606060;}.search-results .result-name span.alias{color:#fff;}.search-results .result-name span.grey{color:#ccc;}#sidebar-toggle{background-color:#565656;}#sidebar-toggle:hover{background-color:#676767;}#source-sidebar{background-color:#565656;}#source-sidebar>.title{border-bottom-color:#ccc;}div.files>a:hover,div.name:hover{background-color:#444;}div.files>.selected{background-color:#333;}.setting-line>.title{border-bottom-color:#ddd;}.scraped-example .example-wrap .rust span.highlight{background:rgb(91,59,1);}.scraped-example .example-wrap .rust span.highlight.focus{background:rgb(124,75,15);}.scraped-example:not(.expanded) .code-wrapper:before{background:linear-gradient(to bottom,rgba(53,53,53,1),rgba(53,53,53,0));}.scraped-example:not(.expanded) .code-wrapper:after{background:linear-gradient(to top,rgba(53,53,53,1),rgba(53,53,53,0));}.toggle-line-inner{background:#616161;}.toggle-line:hover .toggle-line-inner{background:##898989;}
\ No newline at end of file
diff --git a/ch9-log/down-arrow.svg b/ch9-log/down-arrow.svg
new file mode 100644
index 00000000..35437e77
--- /dev/null
+++ b/ch9-log/down-arrow.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/ch9-log/favicon-16x16.png b/ch9-log/favicon-16x16.png
new file mode 100644
index 00000000..ea4b45ca
Binary files /dev/null and b/ch9-log/favicon-16x16.png differ
diff --git a/ch9-log/favicon-32x32.png b/ch9-log/favicon-32x32.png
new file mode 100644
index 00000000..69b8613c
Binary files /dev/null and b/ch9-log/favicon-32x32.png differ
diff --git a/ch9-log/favicon.svg b/ch9-log/favicon.svg
new file mode 100644
index 00000000..8b34b511
--- /dev/null
+++ b/ch9-log/favicon.svg
@@ -0,0 +1,24 @@
+
diff --git a/ch9-log/implementors/core/clone/trait.Clone.js b/ch9-log/implementors/core/clone/trait.Clone.js
new file mode 100644
index 00000000..c78f1ef4
--- /dev/null
+++ b/ch9-log/implementors/core/clone/trait.Clone.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Clone for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Clone for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Clone for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Clone for IntrTargetPriority","synthetic":false,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl Clone for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Clone for RingBufferStatus","synthetic":false,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl Clone for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl Clone for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl Clone for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Clone for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T: Clone> Clone for SimpleRange<T> where T: StepByOne + Copy + PartialEq + PartialOrd + Debug, ","synthetic":false,"types":["os::mm::address::SimpleRange"]},{"text":"impl Clone for MapType","synthetic":false,"types":["os::mm::memory_set::MapType"]},{"text":"impl Clone for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Clone for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Clone for PageTableEntry","synthetic":false,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl Clone for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl Clone for TaskStatus","synthetic":false,"types":["os::task::task::TaskStatus"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/cmp/trait.Eq.js b/ch9-log/implementors/core/cmp/trait.Eq.js
new file mode 100644
index 00000000..3408ed40
--- /dev/null
+++ b/ch9-log/implementors/core/cmp/trait.Eq.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Eq for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Eq for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Eq for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Eq for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Eq for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl Eq for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl Eq for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Eq for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl Eq for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Eq for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Eq for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl Eq for TimerCondVar","synthetic":false,"types":["os::timer::TimerCondVar"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/cmp/trait.Ord.js b/ch9-log/implementors/core/cmp/trait.Ord.js
new file mode 100644
index 00000000..5598db00
--- /dev/null
+++ b/ch9-log/implementors/core/cmp/trait.Ord.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Ord for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Ord for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Ord for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Ord for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Ord for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl Ord for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl Ord for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Ord for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl Ord for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Ord for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Ord for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl Ord for TimerCondVar","synthetic":false,"types":["os::timer::TimerCondVar"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/cmp/trait.PartialEq.js b/ch9-log/implementors/core/cmp/trait.PartialEq.js
new file mode 100644
index 00000000..e7c60fab
--- /dev/null
+++ b/ch9-log/implementors/core/cmp/trait.PartialEq.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl PartialEq<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl PartialEq<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl PartialEq<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl PartialEq<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl PartialEq<RingBufferStatus> for RingBufferStatus","synthetic":false,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl PartialEq<PhysAddr> for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl PartialEq<VirtAddr> for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl PartialEq<PhysPageNum> for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl PartialEq<VirtPageNum> for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl PartialEq<MapType> for MapType","synthetic":false,"types":["os::mm::memory_set::MapType"]},{"text":"impl PartialEq<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl PartialEq<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl PartialEq<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl PartialEq<TaskStatus> for TaskStatus","synthetic":false,"types":["os::task::task::TaskStatus"]},{"text":"impl PartialEq<TimerCondVar> for TimerCondVar","synthetic":false,"types":["os::timer::TimerCondVar"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/cmp/trait.PartialOrd.js b/ch9-log/implementors/core/cmp/trait.PartialOrd.js
new file mode 100644
index 00000000..57c85ba4
--- /dev/null
+++ b/ch9-log/implementors/core/cmp/trait.PartialOrd.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl PartialOrd<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl PartialOrd<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl PartialOrd<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl PartialOrd<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl PartialOrd<PhysAddr> for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl PartialOrd<VirtAddr> for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl PartialOrd<PhysPageNum> for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl PartialOrd<VirtPageNum> for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl PartialOrd<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl PartialOrd<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl PartialOrd<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl PartialOrd<TimerCondVar> for TimerCondVar","synthetic":false,"types":["os::timer::TimerCondVar"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/convert/trait.From.js b/ch9-log/implementors/core/convert/trait.From.js
new file mode 100644
index 00000000..d2fbb8c0
--- /dev/null
+++ b/ch9-log/implementors/core/convert/trait.From.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl From<usize> for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl From<usize> for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl From<usize> for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl From<usize> for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl From<PhysAddr> for usize","synthetic":false,"types":[]},{"text":"impl From<PhysPageNum> for usize","synthetic":false,"types":[]},{"text":"impl From<VirtAddr> for usize","synthetic":false,"types":[]},{"text":"impl From<VirtPageNum> for usize","synthetic":false,"types":[]},{"text":"impl From<VirtAddr> for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl From<VirtPageNum> for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl From<PhysAddr> for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl From<PhysPageNum> for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/fmt/trait.Binary.js b/ch9-log/implementors/core/fmt/trait.Binary.js
new file mode 100644
index 00000000..9bc9019c
--- /dev/null
+++ b/ch9-log/implementors/core/fmt/trait.Binary.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Binary for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Binary for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Binary for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Binary for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Binary for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Binary for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Binary for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/fmt/trait.Debug.js b/ch9-log/implementors/core/fmt/trait.Debug.js
new file mode 100644
index 00000000..2fa7be35
--- /dev/null
+++ b/ch9-log/implementors/core/fmt/trait.Debug.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Debug for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Debug for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Debug for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Debug for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Debug for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl Debug for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl Debug for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl Debug for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Debug for FrameTracker","synthetic":false,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl Debug for MapType","synthetic":false,"types":["os::mm::memory_set::MapType"]},{"text":"impl Debug for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Debug for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Debug for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl Debug for TrapContext","synthetic":false,"types":["os::trap::context::TrapContext"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/fmt/trait.LowerHex.js b/ch9-log/implementors/core/fmt/trait.LowerHex.js
new file mode 100644
index 00000000..dea4c392
--- /dev/null
+++ b/ch9-log/implementors/core/fmt/trait.LowerHex.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl LowerHex for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl LowerHex for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl LowerHex for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl LowerHex for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl LowerHex for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl LowerHex for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl LowerHex for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/fmt/trait.Octal.js b/ch9-log/implementors/core/fmt/trait.Octal.js
new file mode 100644
index 00000000..7eb3d070
--- /dev/null
+++ b/ch9-log/implementors/core/fmt/trait.Octal.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Octal for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Octal for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Octal for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Octal for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Octal for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Octal for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Octal for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/fmt/trait.UpperHex.js b/ch9-log/implementors/core/fmt/trait.UpperHex.js
new file mode 100644
index 00000000..24ca25cc
--- /dev/null
+++ b/ch9-log/implementors/core/fmt/trait.UpperHex.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl UpperHex for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl UpperHex for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl UpperHex for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl UpperHex for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl UpperHex for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl UpperHex for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl UpperHex for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/fmt/trait.Write.js b/ch9-log/implementors/core/fmt/trait.Write.js
new file mode 100644
index 00000000..1b67c0fa
--- /dev/null
+++ b/ch9-log/implementors/core/fmt/trait.Write.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Write for Stdout","synthetic":false,"types":["os::console::Stdout"]},{"text":"impl Write for Kstdout","synthetic":false,"types":["os::console::Kstdout"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/hash/trait.Hash.js b/ch9-log/implementors/core/hash/trait.Hash.js
new file mode 100644
index 00000000..416f505d
--- /dev/null
+++ b/ch9-log/implementors/core/hash/trait.Hash.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Hash for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Hash for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Hash for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Hash for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Hash for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Hash for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Hash for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/iter/traits/collect/trait.Extend.js b/ch9-log/implementors/core/iter/traits/collect/trait.Extend.js
new file mode 100644
index 00000000..2f283f04
--- /dev/null
+++ b/ch9-log/implementors/core/iter/traits/collect/trait.Extend.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Extend<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Extend<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Extend<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Extend<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Extend<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Extend<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Extend<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/iter/traits/collect/trait.FromIterator.js b/ch9-log/implementors/core/iter/traits/collect/trait.FromIterator.js
new file mode 100644
index 00000000..bd004f10
--- /dev/null
+++ b/ch9-log/implementors/core/iter/traits/collect/trait.FromIterator.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl FromIterator<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl FromIterator<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl FromIterator<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl FromIterator<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl FromIterator<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl FromIterator<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl FromIterator<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/iter/traits/collect/trait.IntoIterator.js b/ch9-log/implementors/core/iter/traits/collect/trait.IntoIterator.js
new file mode 100644
index 00000000..7a056c59
--- /dev/null
+++ b/ch9-log/implementors/core/iter/traits/collect/trait.IntoIterator.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl<T> IntoIterator for SimpleRange<T> where T: StepByOne + Copy + PartialEq + PartialOrd + Debug, ","synthetic":false,"types":["os::mm::address::SimpleRange"]},{"text":"impl IntoIterator for UserBuffer","synthetic":false,"types":["os::mm::page_table::UserBuffer"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/iter/traits/iterator/trait.Iterator.js b/ch9-log/implementors/core/iter/traits/iterator/trait.Iterator.js
new file mode 100644
index 00000000..ede026ae
--- /dev/null
+++ b/ch9-log/implementors/core/iter/traits/iterator/trait.Iterator.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl<T> Iterator for SimpleRangeIterator<T> where T: StepByOne + Copy + PartialEq + PartialOrd + Debug, ","synthetic":false,"types":["os::mm::address::SimpleRangeIterator"]},{"text":"impl Iterator for UserBufferIterator","synthetic":false,"types":["os::mm::page_table::UserBufferIterator"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/marker/trait.Copy.js b/ch9-log/implementors/core/marker/trait.Copy.js
new file mode 100644
index 00000000..fff81ba0
--- /dev/null
+++ b/ch9-log/implementors/core/marker/trait.Copy.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Copy for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Copy for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Copy for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Copy for IntrTargetPriority","synthetic":false,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl Copy for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Copy for RingBufferStatus","synthetic":false,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl Copy for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl Copy for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl Copy for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Copy for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T: Copy> Copy for SimpleRange<T> where T: StepByOne + Copy + PartialEq + PartialOrd + Debug, ","synthetic":false,"types":["os::mm::address::SimpleRange"]},{"text":"impl Copy for MapType","synthetic":false,"types":["os::mm::memory_set::MapType"]},{"text":"impl Copy for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Copy for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Copy for PageTableEntry","synthetic":false,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl Copy for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl Copy for TaskStatus","synthetic":false,"types":["os::task::task::TaskStatus"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/marker/trait.Freeze.js b/ch9-log/implementors/core/marker/trait.Freeze.js
new file mode 100644
index 00000000..647c435b
--- /dev/null
+++ b/ch9-log/implementors/core/marker/trait.Freeze.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Freeze for Stdout","synthetic":true,"types":["os::console::Stdout"]},{"text":"impl Freeze for Kstdout","synthetic":true,"types":["os::console::Kstdout"]},{"text":"impl !Freeze for VirtIOBlock","synthetic":true,"types":["os::drivers::block::virtio_blk::VirtIOBlock"]},{"text":"impl Freeze for QUEUE_FRAMES","synthetic":true,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl Freeze for BLOCK_DEVICE","synthetic":true,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl Freeze for IER","synthetic":true,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Freeze for LSR","synthetic":true,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Freeze for MCR","synthetic":true,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Freeze for ReadWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::ReadWithoutDLAB"]},{"text":"impl Freeze for WriteWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::WriteWithoutDLAB"]},{"text":"impl Freeze for NS16550aRaw","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aRaw"]},{"text":"impl Freeze for NS16550aInner","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aInner"]},{"text":"impl<const BASE_ADDR: usize> !Freeze for NS16550a<BASE_ADDR>","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550a"]},{"text":"impl Freeze for UART","synthetic":true,"types":["os::drivers::chardev::UART"]},{"text":"impl Freeze for PLIC","synthetic":true,"types":["os::drivers::plic::PLIC"]},{"text":"impl Freeze for IntrTargetPriority","synthetic":true,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl !Freeze for OSInode","synthetic":true,"types":["os::fs::inode::OSInode"]},{"text":"impl Freeze for OSInodeInner","synthetic":true,"types":["os::fs::inode::OSInodeInner"]},{"text":"impl Freeze for ROOT_INODE","synthetic":true,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl Freeze for OpenFlags","synthetic":true,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Freeze for Pipe","synthetic":true,"types":["os::fs::pipe::Pipe"]},{"text":"impl Freeze for RingBufferStatus","synthetic":true,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl Freeze for PipeRingBuffer","synthetic":true,"types":["os::fs::pipe::PipeRingBuffer"]},{"text":"impl Freeze for Stdin","synthetic":true,"types":["os::fs::stdio::Stdin"]},{"text":"impl Freeze for Stdout","synthetic":true,"types":["os::fs::stdio::Stdout"]},{"text":"impl Freeze for PhysAddr","synthetic":true,"types":["os::mm::address::PhysAddr"]},{"text":"impl Freeze for VirtAddr","synthetic":true,"types":["os::mm::address::VirtAddr"]},{"text":"impl Freeze for PhysPageNum","synthetic":true,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Freeze for VirtPageNum","synthetic":true,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T> Freeze for SimpleRange<T> where T: Freeze, ","synthetic":true,"types":["os::mm::address::SimpleRange"]},{"text":"impl<T> Freeze for SimpleRangeIterator<T> where T: Freeze, ","synthetic":true,"types":["os::mm::address::SimpleRangeIterator"]},{"text":"impl Freeze for FrameTracker","synthetic":true,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl Freeze for StackFrameAllocator","synthetic":true,"types":["os::mm::frame_allocator::StackFrameAllocator"]},{"text":"impl Freeze for FRAME_ALLOCATOR","synthetic":true,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl Freeze for KERNEL_SPACE","synthetic":true,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl Freeze for MemorySet","synthetic":true,"types":["os::mm::memory_set::MemorySet"]},{"text":"impl Freeze for MapArea","synthetic":true,"types":["os::mm::memory_set::MapArea"]},{"text":"impl Freeze for MapType","synthetic":true,"types":["os::mm::memory_set::MapType"]},{"text":"impl Freeze for MapPermission","synthetic":true,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Freeze for PTEFlags","synthetic":true,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Freeze for PageTableEntry","synthetic":true,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl Freeze for PageTable","synthetic":true,"types":["os::mm::page_table::PageTable"]},{"text":"impl Freeze for UserBuffer","synthetic":true,"types":["os::mm::page_table::UserBuffer"]},{"text":"impl Freeze for UserBufferIterator","synthetic":true,"types":["os::mm::page_table::UserBufferIterator"]},{"text":"impl !Freeze for Condvar","synthetic":true,"types":["os::sync::condvar::Condvar"]},{"text":"impl Freeze for CondvarInner","synthetic":true,"types":["os::sync::condvar::CondvarInner"]},{"text":"impl !Freeze for MutexSpin","synthetic":true,"types":["os::sync::mutex::MutexSpin"]},{"text":"impl !Freeze for MutexBlocking","synthetic":true,"types":["os::sync::mutex::MutexBlocking"]},{"text":"impl Freeze for MutexBlockingInner","synthetic":true,"types":["os::sync::mutex::MutexBlockingInner"]},{"text":"impl !Freeze for Semaphore","synthetic":true,"types":["os::sync::semaphore::Semaphore"]},{"text":"impl Freeze for SemaphoreInner","synthetic":true,"types":["os::sync::semaphore::SemaphoreInner"]},{"text":"impl<T> !Freeze for UPSafeCellRaw<T>","synthetic":true,"types":["os::sync::up::UPSafeCellRaw"]},{"text":"impl Freeze for IntrMaskingInfo","synthetic":true,"types":["os::sync::up::IntrMaskingInfo"]},{"text":"impl Freeze for INTR_MASKING_INFO","synthetic":true,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl<T> !Freeze for UPIntrFreeCell<T>","synthetic":true,"types":["os::sync::up::UPIntrFreeCell"]},{"text":"impl<'a, T> Freeze for UPIntrRefMut<'a, T>","synthetic":true,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl Freeze for TaskContext","synthetic":true,"types":["os::task::context::TaskContext"]},{"text":"impl Freeze for RecycleAllocator","synthetic":true,"types":["os::task::id::RecycleAllocator"]},{"text":"impl Freeze for PID_ALLOCATOR","synthetic":true,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl Freeze for KSTACK_ALLOCATOR","synthetic":true,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl Freeze for PidHandle","synthetic":true,"types":["os::task::id::PidHandle"]},{"text":"impl Freeze for KernelStack","synthetic":true,"types":["os::task::id::KernelStack"]},{"text":"impl Freeze for TaskUserRes","synthetic":true,"types":["os::task::id::TaskUserRes"]},{"text":"impl Freeze for TaskManager","synthetic":true,"types":["os::task::manager::TaskManager"]},{"text":"impl Freeze for TASK_MANAGER","synthetic":true,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl Freeze for PID2PCB","synthetic":true,"types":["os::task::manager::PID2PCB"]},{"text":"impl !Freeze for ProcessControlBlock","synthetic":true,"types":["os::task::process::ProcessControlBlock"]},{"text":"impl Freeze for ProcessControlBlockInner","synthetic":true,"types":["os::task::process::ProcessControlBlockInner"]},{"text":"impl Freeze for Processor","synthetic":true,"types":["os::task::processor::Processor"]},{"text":"impl Freeze for PROCESSOR","synthetic":true,"types":["os::task::processor::PROCESSOR"]},{"text":"impl Freeze for SignalFlags","synthetic":true,"types":["os::task::signal::SignalFlags"]},{"text":"impl !Freeze for TaskControlBlock","synthetic":true,"types":["os::task::task::TaskControlBlock"]},{"text":"impl Freeze for TaskControlBlockInner","synthetic":true,"types":["os::task::task::TaskControlBlockInner"]},{"text":"impl Freeze for TaskStatus","synthetic":true,"types":["os::task::task::TaskStatus"]},{"text":"impl Freeze for INITPROC","synthetic":true,"types":["os::task::INITPROC"]},{"text":"impl Freeze for TimerCondVar","synthetic":true,"types":["os::timer::TimerCondVar"]},{"text":"impl Freeze for TIMERS","synthetic":true,"types":["os::timer::TIMERS"]},{"text":"impl Freeze for TrapContext","synthetic":true,"types":["os::trap::context::TrapContext"]},{"text":"impl Freeze for DEV_NON_BLOCKING_ACCESS","synthetic":true,"types":["os::DEV_NON_BLOCKING_ACCESS"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/marker/trait.Send.js b/ch9-log/implementors/core/marker/trait.Send.js
new file mode 100644
index 00000000..48278931
--- /dev/null
+++ b/ch9-log/implementors/core/marker/trait.Send.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Send for Stdout","synthetic":true,"types":["os::console::Stdout"]},{"text":"impl Send for Kstdout","synthetic":true,"types":["os::console::Kstdout"]},{"text":"impl Send for VirtIOBlock","synthetic":true,"types":["os::drivers::block::virtio_blk::VirtIOBlock"]},{"text":"impl Send for QUEUE_FRAMES","synthetic":true,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl Send for BLOCK_DEVICE","synthetic":true,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl Send for IER","synthetic":true,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Send for LSR","synthetic":true,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Send for MCR","synthetic":true,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Send for ReadWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::ReadWithoutDLAB"]},{"text":"impl Send for WriteWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::WriteWithoutDLAB"]},{"text":"impl Send for NS16550aRaw","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aRaw"]},{"text":"impl Send for NS16550aInner","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aInner"]},{"text":"impl<const BASE_ADDR: usize> Send for NS16550a<BASE_ADDR>","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550a"]},{"text":"impl Send for UART","synthetic":true,"types":["os::drivers::chardev::UART"]},{"text":"impl Send for PLIC","synthetic":true,"types":["os::drivers::plic::PLIC"]},{"text":"impl Send for IntrTargetPriority","synthetic":true,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl Send for OSInode","synthetic":true,"types":["os::fs::inode::OSInode"]},{"text":"impl Send for OSInodeInner","synthetic":true,"types":["os::fs::inode::OSInodeInner"]},{"text":"impl Send for ROOT_INODE","synthetic":true,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl Send for OpenFlags","synthetic":true,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Send for Pipe","synthetic":true,"types":["os::fs::pipe::Pipe"]},{"text":"impl Send for RingBufferStatus","synthetic":true,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl Send for PipeRingBuffer","synthetic":true,"types":["os::fs::pipe::PipeRingBuffer"]},{"text":"impl Send for Stdin","synthetic":true,"types":["os::fs::stdio::Stdin"]},{"text":"impl Send for Stdout","synthetic":true,"types":["os::fs::stdio::Stdout"]},{"text":"impl Send for PhysAddr","synthetic":true,"types":["os::mm::address::PhysAddr"]},{"text":"impl Send for VirtAddr","synthetic":true,"types":["os::mm::address::VirtAddr"]},{"text":"impl Send for PhysPageNum","synthetic":true,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Send for VirtPageNum","synthetic":true,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T> Send for SimpleRange<T> where T: Send, ","synthetic":true,"types":["os::mm::address::SimpleRange"]},{"text":"impl<T> Send for SimpleRangeIterator<T> where T: Send, ","synthetic":true,"types":["os::mm::address::SimpleRangeIterator"]},{"text":"impl Send for FrameTracker","synthetic":true,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl Send for StackFrameAllocator","synthetic":true,"types":["os::mm::frame_allocator::StackFrameAllocator"]},{"text":"impl Send for FRAME_ALLOCATOR","synthetic":true,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl Send for KERNEL_SPACE","synthetic":true,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl Send for MemorySet","synthetic":true,"types":["os::mm::memory_set::MemorySet"]},{"text":"impl Send for MapArea","synthetic":true,"types":["os::mm::memory_set::MapArea"]},{"text":"impl Send for MapType","synthetic":true,"types":["os::mm::memory_set::MapType"]},{"text":"impl Send for MapPermission","synthetic":true,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Send for PTEFlags","synthetic":true,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Send for PageTableEntry","synthetic":true,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl Send for PageTable","synthetic":true,"types":["os::mm::page_table::PageTable"]},{"text":"impl Send for UserBuffer","synthetic":true,"types":["os::mm::page_table::UserBuffer"]},{"text":"impl Send for UserBufferIterator","synthetic":true,"types":["os::mm::page_table::UserBufferIterator"]},{"text":"impl Send for Condvar","synthetic":true,"types":["os::sync::condvar::Condvar"]},{"text":"impl Send for CondvarInner","synthetic":true,"types":["os::sync::condvar::CondvarInner"]},{"text":"impl Send for MutexSpin","synthetic":true,"types":["os::sync::mutex::MutexSpin"]},{"text":"impl Send for MutexBlocking","synthetic":true,"types":["os::sync::mutex::MutexBlocking"]},{"text":"impl Send for MutexBlockingInner","synthetic":true,"types":["os::sync::mutex::MutexBlockingInner"]},{"text":"impl Send for Semaphore","synthetic":true,"types":["os::sync::semaphore::Semaphore"]},{"text":"impl Send for SemaphoreInner","synthetic":true,"types":["os::sync::semaphore::SemaphoreInner"]},{"text":"impl<T> Send for UPSafeCellRaw<T> where T: Send, ","synthetic":true,"types":["os::sync::up::UPSafeCellRaw"]},{"text":"impl Send for IntrMaskingInfo","synthetic":true,"types":["os::sync::up::IntrMaskingInfo"]},{"text":"impl Send for INTR_MASKING_INFO","synthetic":true,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl<T> Send for UPIntrFreeCell<T> where T: Send, ","synthetic":true,"types":["os::sync::up::UPIntrFreeCell"]},{"text":"impl<'a, T> !Send for UPIntrRefMut<'a, T>","synthetic":true,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl Send for TaskContext","synthetic":true,"types":["os::task::context::TaskContext"]},{"text":"impl Send for RecycleAllocator","synthetic":true,"types":["os::task::id::RecycleAllocator"]},{"text":"impl Send for PID_ALLOCATOR","synthetic":true,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl Send for KSTACK_ALLOCATOR","synthetic":true,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl Send for PidHandle","synthetic":true,"types":["os::task::id::PidHandle"]},{"text":"impl Send for KernelStack","synthetic":true,"types":["os::task::id::KernelStack"]},{"text":"impl Send for TaskUserRes","synthetic":true,"types":["os::task::id::TaskUserRes"]},{"text":"impl Send for TaskManager","synthetic":true,"types":["os::task::manager::TaskManager"]},{"text":"impl Send for TASK_MANAGER","synthetic":true,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl Send for PID2PCB","synthetic":true,"types":["os::task::manager::PID2PCB"]},{"text":"impl Send for ProcessControlBlock","synthetic":true,"types":["os::task::process::ProcessControlBlock"]},{"text":"impl Send for ProcessControlBlockInner","synthetic":true,"types":["os::task::process::ProcessControlBlockInner"]},{"text":"impl Send for Processor","synthetic":true,"types":["os::task::processor::Processor"]},{"text":"impl Send for PROCESSOR","synthetic":true,"types":["os::task::processor::PROCESSOR"]},{"text":"impl Send for SignalFlags","synthetic":true,"types":["os::task::signal::SignalFlags"]},{"text":"impl Send for TaskControlBlock","synthetic":true,"types":["os::task::task::TaskControlBlock"]},{"text":"impl Send for TaskControlBlockInner","synthetic":true,"types":["os::task::task::TaskControlBlockInner"]},{"text":"impl Send for TaskStatus","synthetic":true,"types":["os::task::task::TaskStatus"]},{"text":"impl Send for INITPROC","synthetic":true,"types":["os::task::INITPROC"]},{"text":"impl Send for TimerCondVar","synthetic":true,"types":["os::timer::TimerCondVar"]},{"text":"impl Send for TIMERS","synthetic":true,"types":["os::timer::TIMERS"]},{"text":"impl Send for TrapContext","synthetic":true,"types":["os::trap::context::TrapContext"]},{"text":"impl Send for DEV_NON_BLOCKING_ACCESS","synthetic":true,"types":["os::DEV_NON_BLOCKING_ACCESS"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/marker/trait.StructuralEq.js b/ch9-log/implementors/core/marker/trait.StructuralEq.js
new file mode 100644
index 00000000..57250fbc
--- /dev/null
+++ b/ch9-log/implementors/core/marker/trait.StructuralEq.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl StructuralEq for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl StructuralEq for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl StructuralEq for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl StructuralEq for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl StructuralEq for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl StructuralEq for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl StructuralEq for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl StructuralEq for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl StructuralEq for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl StructuralEq for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl StructuralEq for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/marker/trait.StructuralPartialEq.js b/ch9-log/implementors/core/marker/trait.StructuralPartialEq.js
new file mode 100644
index 00000000..aa165a9f
--- /dev/null
+++ b/ch9-log/implementors/core/marker/trait.StructuralPartialEq.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl StructuralPartialEq for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl StructuralPartialEq for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl StructuralPartialEq for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl StructuralPartialEq for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl StructuralPartialEq for RingBufferStatus","synthetic":false,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl StructuralPartialEq for PhysAddr","synthetic":false,"types":["os::mm::address::PhysAddr"]},{"text":"impl StructuralPartialEq for VirtAddr","synthetic":false,"types":["os::mm::address::VirtAddr"]},{"text":"impl StructuralPartialEq for PhysPageNum","synthetic":false,"types":["os::mm::address::PhysPageNum"]},{"text":"impl StructuralPartialEq for VirtPageNum","synthetic":false,"types":["os::mm::address::VirtPageNum"]},{"text":"impl StructuralPartialEq for MapType","synthetic":false,"types":["os::mm::memory_set::MapType"]},{"text":"impl StructuralPartialEq for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl StructuralPartialEq for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl StructuralPartialEq for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]},{"text":"impl StructuralPartialEq for TaskStatus","synthetic":false,"types":["os::task::task::TaskStatus"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/marker/trait.Sync.js b/ch9-log/implementors/core/marker/trait.Sync.js
new file mode 100644
index 00000000..aea8df75
--- /dev/null
+++ b/ch9-log/implementors/core/marker/trait.Sync.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Sync for Stdout","synthetic":true,"types":["os::console::Stdout"]},{"text":"impl Sync for Kstdout","synthetic":true,"types":["os::console::Kstdout"]},{"text":"impl Sync for VirtIOBlock","synthetic":true,"types":["os::drivers::block::virtio_blk::VirtIOBlock"]},{"text":"impl Sync for QUEUE_FRAMES","synthetic":true,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl Sync for BLOCK_DEVICE","synthetic":true,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl Sync for IER","synthetic":true,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Sync for LSR","synthetic":true,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Sync for MCR","synthetic":true,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Sync for ReadWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::ReadWithoutDLAB"]},{"text":"impl Sync for WriteWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::WriteWithoutDLAB"]},{"text":"impl Sync for NS16550aRaw","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aRaw"]},{"text":"impl Sync for NS16550aInner","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aInner"]},{"text":"impl<const BASE_ADDR: usize> Sync for NS16550a<BASE_ADDR>","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550a"]},{"text":"impl Sync for UART","synthetic":true,"types":["os::drivers::chardev::UART"]},{"text":"impl Sync for PLIC","synthetic":true,"types":["os::drivers::plic::PLIC"]},{"text":"impl Sync for IntrTargetPriority","synthetic":true,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl Sync for OSInode","synthetic":true,"types":["os::fs::inode::OSInode"]},{"text":"impl Sync for OSInodeInner","synthetic":true,"types":["os::fs::inode::OSInodeInner"]},{"text":"impl Sync for ROOT_INODE","synthetic":true,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl Sync for OpenFlags","synthetic":true,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Sync for Pipe","synthetic":true,"types":["os::fs::pipe::Pipe"]},{"text":"impl Sync for RingBufferStatus","synthetic":true,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl Sync for PipeRingBuffer","synthetic":true,"types":["os::fs::pipe::PipeRingBuffer"]},{"text":"impl Sync for Stdin","synthetic":true,"types":["os::fs::stdio::Stdin"]},{"text":"impl Sync for Stdout","synthetic":true,"types":["os::fs::stdio::Stdout"]},{"text":"impl Sync for PhysAddr","synthetic":true,"types":["os::mm::address::PhysAddr"]},{"text":"impl Sync for VirtAddr","synthetic":true,"types":["os::mm::address::VirtAddr"]},{"text":"impl Sync for PhysPageNum","synthetic":true,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Sync for VirtPageNum","synthetic":true,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T> Sync for SimpleRange<T> where T: Sync, ","synthetic":true,"types":["os::mm::address::SimpleRange"]},{"text":"impl<T> Sync for SimpleRangeIterator<T> where T: Sync, ","synthetic":true,"types":["os::mm::address::SimpleRangeIterator"]},{"text":"impl Sync for FrameTracker","synthetic":true,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl Sync for StackFrameAllocator","synthetic":true,"types":["os::mm::frame_allocator::StackFrameAllocator"]},{"text":"impl Sync for FRAME_ALLOCATOR","synthetic":true,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl Sync for KERNEL_SPACE","synthetic":true,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl Sync for MemorySet","synthetic":true,"types":["os::mm::memory_set::MemorySet"]},{"text":"impl Sync for MapArea","synthetic":true,"types":["os::mm::memory_set::MapArea"]},{"text":"impl Sync for MapType","synthetic":true,"types":["os::mm::memory_set::MapType"]},{"text":"impl Sync for MapPermission","synthetic":true,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Sync for PTEFlags","synthetic":true,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Sync for PageTableEntry","synthetic":true,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl Sync for PageTable","synthetic":true,"types":["os::mm::page_table::PageTable"]},{"text":"impl Sync for UserBuffer","synthetic":true,"types":["os::mm::page_table::UserBuffer"]},{"text":"impl Sync for UserBufferIterator","synthetic":true,"types":["os::mm::page_table::UserBufferIterator"]},{"text":"impl Sync for Condvar","synthetic":true,"types":["os::sync::condvar::Condvar"]},{"text":"impl Sync for CondvarInner","synthetic":true,"types":["os::sync::condvar::CondvarInner"]},{"text":"impl Sync for MutexSpin","synthetic":true,"types":["os::sync::mutex::MutexSpin"]},{"text":"impl Sync for MutexBlocking","synthetic":true,"types":["os::sync::mutex::MutexBlocking"]},{"text":"impl Sync for MutexBlockingInner","synthetic":true,"types":["os::sync::mutex::MutexBlockingInner"]},{"text":"impl Sync for Semaphore","synthetic":true,"types":["os::sync::semaphore::Semaphore"]},{"text":"impl Sync for SemaphoreInner","synthetic":true,"types":["os::sync::semaphore::SemaphoreInner"]},{"text":"impl Sync for IntrMaskingInfo","synthetic":true,"types":["os::sync::up::IntrMaskingInfo"]},{"text":"impl Sync for INTR_MASKING_INFO","synthetic":true,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl<'a, T> !Sync for UPIntrRefMut<'a, T>","synthetic":true,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl Sync for TaskContext","synthetic":true,"types":["os::task::context::TaskContext"]},{"text":"impl Sync for RecycleAllocator","synthetic":true,"types":["os::task::id::RecycleAllocator"]},{"text":"impl Sync for PID_ALLOCATOR","synthetic":true,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl Sync for KSTACK_ALLOCATOR","synthetic":true,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl Sync for PidHandle","synthetic":true,"types":["os::task::id::PidHandle"]},{"text":"impl Sync for KernelStack","synthetic":true,"types":["os::task::id::KernelStack"]},{"text":"impl Sync for TaskUserRes","synthetic":true,"types":["os::task::id::TaskUserRes"]},{"text":"impl Sync for TaskManager","synthetic":true,"types":["os::task::manager::TaskManager"]},{"text":"impl Sync for TASK_MANAGER","synthetic":true,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl Sync for PID2PCB","synthetic":true,"types":["os::task::manager::PID2PCB"]},{"text":"impl Sync for ProcessControlBlock","synthetic":true,"types":["os::task::process::ProcessControlBlock"]},{"text":"impl Sync for ProcessControlBlockInner","synthetic":true,"types":["os::task::process::ProcessControlBlockInner"]},{"text":"impl Sync for Processor","synthetic":true,"types":["os::task::processor::Processor"]},{"text":"impl Sync for PROCESSOR","synthetic":true,"types":["os::task::processor::PROCESSOR"]},{"text":"impl Sync for SignalFlags","synthetic":true,"types":["os::task::signal::SignalFlags"]},{"text":"impl Sync for TaskControlBlock","synthetic":true,"types":["os::task::task::TaskControlBlock"]},{"text":"impl Sync for TaskControlBlockInner","synthetic":true,"types":["os::task::task::TaskControlBlockInner"]},{"text":"impl Sync for TaskStatus","synthetic":true,"types":["os::task::task::TaskStatus"]},{"text":"impl Sync for INITPROC","synthetic":true,"types":["os::task::INITPROC"]},{"text":"impl Sync for TimerCondVar","synthetic":true,"types":["os::timer::TimerCondVar"]},{"text":"impl Sync for TIMERS","synthetic":true,"types":["os::timer::TIMERS"]},{"text":"impl Sync for TrapContext","synthetic":true,"types":["os::trap::context::TrapContext"]},{"text":"impl Sync for DEV_NON_BLOCKING_ACCESS","synthetic":true,"types":["os::DEV_NON_BLOCKING_ACCESS"]},{"text":"impl<T> Sync for UPSafeCellRaw<T>","synthetic":false,"types":["os::sync::up::UPSafeCellRaw"]},{"text":"impl<T> Sync for UPIntrFreeCell<T>","synthetic":false,"types":["os::sync::up::UPIntrFreeCell"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/marker/trait.Unpin.js b/ch9-log/implementors/core/marker/trait.Unpin.js
new file mode 100644
index 00000000..b3e10ff9
--- /dev/null
+++ b/ch9-log/implementors/core/marker/trait.Unpin.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Unpin for Stdout","synthetic":true,"types":["os::console::Stdout"]},{"text":"impl Unpin for Kstdout","synthetic":true,"types":["os::console::Kstdout"]},{"text":"impl Unpin for VirtIOBlock","synthetic":true,"types":["os::drivers::block::virtio_blk::VirtIOBlock"]},{"text":"impl Unpin for QUEUE_FRAMES","synthetic":true,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl Unpin for BLOCK_DEVICE","synthetic":true,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl Unpin for IER","synthetic":true,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Unpin for LSR","synthetic":true,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Unpin for MCR","synthetic":true,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Unpin for ReadWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::ReadWithoutDLAB"]},{"text":"impl Unpin for WriteWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::WriteWithoutDLAB"]},{"text":"impl Unpin for NS16550aRaw","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aRaw"]},{"text":"impl Unpin for NS16550aInner","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aInner"]},{"text":"impl<const BASE_ADDR: usize> Unpin for NS16550a<BASE_ADDR>","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550a"]},{"text":"impl Unpin for UART","synthetic":true,"types":["os::drivers::chardev::UART"]},{"text":"impl Unpin for PLIC","synthetic":true,"types":["os::drivers::plic::PLIC"]},{"text":"impl Unpin for IntrTargetPriority","synthetic":true,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl Unpin for OSInode","synthetic":true,"types":["os::fs::inode::OSInode"]},{"text":"impl Unpin for OSInodeInner","synthetic":true,"types":["os::fs::inode::OSInodeInner"]},{"text":"impl Unpin for ROOT_INODE","synthetic":true,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl Unpin for OpenFlags","synthetic":true,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Unpin for Pipe","synthetic":true,"types":["os::fs::pipe::Pipe"]},{"text":"impl Unpin for RingBufferStatus","synthetic":true,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl Unpin for PipeRingBuffer","synthetic":true,"types":["os::fs::pipe::PipeRingBuffer"]},{"text":"impl Unpin for Stdin","synthetic":true,"types":["os::fs::stdio::Stdin"]},{"text":"impl Unpin for Stdout","synthetic":true,"types":["os::fs::stdio::Stdout"]},{"text":"impl Unpin for PhysAddr","synthetic":true,"types":["os::mm::address::PhysAddr"]},{"text":"impl Unpin for VirtAddr","synthetic":true,"types":["os::mm::address::VirtAddr"]},{"text":"impl Unpin for PhysPageNum","synthetic":true,"types":["os::mm::address::PhysPageNum"]},{"text":"impl Unpin for VirtPageNum","synthetic":true,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T> Unpin for SimpleRange<T> where T: Unpin, ","synthetic":true,"types":["os::mm::address::SimpleRange"]},{"text":"impl<T> Unpin for SimpleRangeIterator<T> where T: Unpin, ","synthetic":true,"types":["os::mm::address::SimpleRangeIterator"]},{"text":"impl Unpin for FrameTracker","synthetic":true,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl Unpin for StackFrameAllocator","synthetic":true,"types":["os::mm::frame_allocator::StackFrameAllocator"]},{"text":"impl Unpin for FRAME_ALLOCATOR","synthetic":true,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl Unpin for KERNEL_SPACE","synthetic":true,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl Unpin for MemorySet","synthetic":true,"types":["os::mm::memory_set::MemorySet"]},{"text":"impl Unpin for MapArea","synthetic":true,"types":["os::mm::memory_set::MapArea"]},{"text":"impl Unpin for MapType","synthetic":true,"types":["os::mm::memory_set::MapType"]},{"text":"impl Unpin for MapPermission","synthetic":true,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Unpin for PTEFlags","synthetic":true,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Unpin for PageTableEntry","synthetic":true,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl Unpin for PageTable","synthetic":true,"types":["os::mm::page_table::PageTable"]},{"text":"impl Unpin for UserBuffer","synthetic":true,"types":["os::mm::page_table::UserBuffer"]},{"text":"impl Unpin for UserBufferIterator","synthetic":true,"types":["os::mm::page_table::UserBufferIterator"]},{"text":"impl Unpin for Condvar","synthetic":true,"types":["os::sync::condvar::Condvar"]},{"text":"impl Unpin for CondvarInner","synthetic":true,"types":["os::sync::condvar::CondvarInner"]},{"text":"impl Unpin for MutexSpin","synthetic":true,"types":["os::sync::mutex::MutexSpin"]},{"text":"impl Unpin for MutexBlocking","synthetic":true,"types":["os::sync::mutex::MutexBlocking"]},{"text":"impl Unpin for MutexBlockingInner","synthetic":true,"types":["os::sync::mutex::MutexBlockingInner"]},{"text":"impl Unpin for Semaphore","synthetic":true,"types":["os::sync::semaphore::Semaphore"]},{"text":"impl Unpin for SemaphoreInner","synthetic":true,"types":["os::sync::semaphore::SemaphoreInner"]},{"text":"impl<T> Unpin for UPSafeCellRaw<T> where T: Unpin, ","synthetic":true,"types":["os::sync::up::UPSafeCellRaw"]},{"text":"impl Unpin for IntrMaskingInfo","synthetic":true,"types":["os::sync::up::IntrMaskingInfo"]},{"text":"impl Unpin for INTR_MASKING_INFO","synthetic":true,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl<T> Unpin for UPIntrFreeCell<T> where T: Unpin, ","synthetic":true,"types":["os::sync::up::UPIntrFreeCell"]},{"text":"impl<'a, T> Unpin for UPIntrRefMut<'a, T>","synthetic":true,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl Unpin for TaskContext","synthetic":true,"types":["os::task::context::TaskContext"]},{"text":"impl Unpin for RecycleAllocator","synthetic":true,"types":["os::task::id::RecycleAllocator"]},{"text":"impl Unpin for PID_ALLOCATOR","synthetic":true,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl Unpin for KSTACK_ALLOCATOR","synthetic":true,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl Unpin for PidHandle","synthetic":true,"types":["os::task::id::PidHandle"]},{"text":"impl Unpin for KernelStack","synthetic":true,"types":["os::task::id::KernelStack"]},{"text":"impl Unpin for TaskUserRes","synthetic":true,"types":["os::task::id::TaskUserRes"]},{"text":"impl Unpin for TaskManager","synthetic":true,"types":["os::task::manager::TaskManager"]},{"text":"impl Unpin for TASK_MANAGER","synthetic":true,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl Unpin for PID2PCB","synthetic":true,"types":["os::task::manager::PID2PCB"]},{"text":"impl Unpin for ProcessControlBlock","synthetic":true,"types":["os::task::process::ProcessControlBlock"]},{"text":"impl Unpin for ProcessControlBlockInner","synthetic":true,"types":["os::task::process::ProcessControlBlockInner"]},{"text":"impl Unpin for Processor","synthetic":true,"types":["os::task::processor::Processor"]},{"text":"impl Unpin for PROCESSOR","synthetic":true,"types":["os::task::processor::PROCESSOR"]},{"text":"impl Unpin for SignalFlags","synthetic":true,"types":["os::task::signal::SignalFlags"]},{"text":"impl Unpin for TaskControlBlock","synthetic":true,"types":["os::task::task::TaskControlBlock"]},{"text":"impl Unpin for TaskControlBlockInner","synthetic":true,"types":["os::task::task::TaskControlBlockInner"]},{"text":"impl Unpin for TaskStatus","synthetic":true,"types":["os::task::task::TaskStatus"]},{"text":"impl Unpin for INITPROC","synthetic":true,"types":["os::task::INITPROC"]},{"text":"impl Unpin for TimerCondVar","synthetic":true,"types":["os::timer::TimerCondVar"]},{"text":"impl Unpin for TIMERS","synthetic":true,"types":["os::timer::TIMERS"]},{"text":"impl Unpin for TrapContext","synthetic":true,"types":["os::trap::context::TrapContext"]},{"text":"impl Unpin for DEV_NON_BLOCKING_ACCESS","synthetic":true,"types":["os::DEV_NON_BLOCKING_ACCESS"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/arith/trait.Sub.js b/ch9-log/implementors/core/ops/arith/trait.Sub.js
new file mode 100644
index 00000000..e31a7592
--- /dev/null
+++ b/ch9-log/implementors/core/ops/arith/trait.Sub.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Sub<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Sub<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Sub<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Sub<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Sub<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Sub<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Sub<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/arith/trait.SubAssign.js b/ch9-log/implementors/core/ops/arith/trait.SubAssign.js
new file mode 100644
index 00000000..c60075bc
--- /dev/null
+++ b/ch9-log/implementors/core/ops/arith/trait.SubAssign.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl SubAssign<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl SubAssign<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl SubAssign<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl SubAssign<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl SubAssign<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl SubAssign<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl SubAssign<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/bit/trait.BitAnd.js b/ch9-log/implementors/core/ops/bit/trait.BitAnd.js
new file mode 100644
index 00000000..f0ac382d
--- /dev/null
+++ b/ch9-log/implementors/core/ops/bit/trait.BitAnd.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl BitAnd<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl BitAnd<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl BitAnd<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl BitAnd<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl BitAnd<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl BitAnd<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl BitAnd<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/bit/trait.BitAndAssign.js b/ch9-log/implementors/core/ops/bit/trait.BitAndAssign.js
new file mode 100644
index 00000000..08fa4fdf
--- /dev/null
+++ b/ch9-log/implementors/core/ops/bit/trait.BitAndAssign.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl BitAndAssign<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl BitAndAssign<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl BitAndAssign<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl BitAndAssign<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl BitAndAssign<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl BitAndAssign<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl BitAndAssign<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/bit/trait.BitOr.js b/ch9-log/implementors/core/ops/bit/trait.BitOr.js
new file mode 100644
index 00000000..dd64936b
--- /dev/null
+++ b/ch9-log/implementors/core/ops/bit/trait.BitOr.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl BitOr<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl BitOr<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl BitOr<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl BitOr<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl BitOr<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl BitOr<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl BitOr<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/bit/trait.BitOrAssign.js b/ch9-log/implementors/core/ops/bit/trait.BitOrAssign.js
new file mode 100644
index 00000000..fca08d52
--- /dev/null
+++ b/ch9-log/implementors/core/ops/bit/trait.BitOrAssign.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl BitOrAssign<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl BitOrAssign<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl BitOrAssign<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl BitOrAssign<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl BitOrAssign<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl BitOrAssign<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl BitOrAssign<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/bit/trait.BitXor.js b/ch9-log/implementors/core/ops/bit/trait.BitXor.js
new file mode 100644
index 00000000..aee7be0c
--- /dev/null
+++ b/ch9-log/implementors/core/ops/bit/trait.BitXor.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl BitXor<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl BitXor<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl BitXor<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl BitXor<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl BitXor<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl BitXor<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl BitXor<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/bit/trait.BitXorAssign.js b/ch9-log/implementors/core/ops/bit/trait.BitXorAssign.js
new file mode 100644
index 00000000..b6561ab0
--- /dev/null
+++ b/ch9-log/implementors/core/ops/bit/trait.BitXorAssign.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl BitXorAssign<IER> for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl BitXorAssign<LSR> for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl BitXorAssign<MCR> for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl BitXorAssign<OpenFlags> for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl BitXorAssign<MapPermission> for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl BitXorAssign<PTEFlags> for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl BitXorAssign<SignalFlags> for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/bit/trait.Not.js b/ch9-log/implementors/core/ops/bit/trait.Not.js
new file mode 100644
index 00000000..cb671047
--- /dev/null
+++ b/ch9-log/implementors/core/ops/bit/trait.Not.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Not for IER","synthetic":false,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl Not for LSR","synthetic":false,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl Not for MCR","synthetic":false,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl Not for OpenFlags","synthetic":false,"types":["os::fs::inode::OpenFlags"]},{"text":"impl Not for MapPermission","synthetic":false,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl Not for PTEFlags","synthetic":false,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl Not for SignalFlags","synthetic":false,"types":["os::task::signal::SignalFlags"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/deref/trait.Deref.js b/ch9-log/implementors/core/ops/deref/trait.Deref.js
new file mode 100644
index 00000000..4a1623e7
--- /dev/null
+++ b/ch9-log/implementors/core/ops/deref/trait.Deref.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Deref for QUEUE_FRAMES","synthetic":false,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl Deref for BLOCK_DEVICE","synthetic":false,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl Deref for UART","synthetic":false,"types":["os::drivers::chardev::UART"]},{"text":"impl Deref for ROOT_INODE","synthetic":false,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl Deref for FRAME_ALLOCATOR","synthetic":false,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl Deref for KERNEL_SPACE","synthetic":false,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl Deref for INTR_MASKING_INFO","synthetic":false,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl<'a, T> Deref for UPIntrRefMut<'a, T>","synthetic":false,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl Deref for PID_ALLOCATOR","synthetic":false,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl Deref for KSTACK_ALLOCATOR","synthetic":false,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl Deref for TASK_MANAGER","synthetic":false,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl Deref for PID2PCB","synthetic":false,"types":["os::task::manager::PID2PCB"]},{"text":"impl Deref for PROCESSOR","synthetic":false,"types":["os::task::processor::PROCESSOR"]},{"text":"impl Deref for INITPROC","synthetic":false,"types":["os::task::INITPROC"]},{"text":"impl Deref for TIMERS","synthetic":false,"types":["os::timer::TIMERS"]},{"text":"impl Deref for DEV_NON_BLOCKING_ACCESS","synthetic":false,"types":["os::DEV_NON_BLOCKING_ACCESS"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/deref/trait.DerefMut.js b/ch9-log/implementors/core/ops/deref/trait.DerefMut.js
new file mode 100644
index 00000000..764822db
--- /dev/null
+++ b/ch9-log/implementors/core/ops/deref/trait.DerefMut.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl<'a, T> DerefMut for UPIntrRefMut<'a, T>","synthetic":false,"types":["os::sync::up::UPIntrRefMut"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/ops/drop/trait.Drop.js b/ch9-log/implementors/core/ops/drop/trait.Drop.js
new file mode 100644
index 00000000..27321f26
--- /dev/null
+++ b/ch9-log/implementors/core/ops/drop/trait.Drop.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl Drop for FrameTracker","synthetic":false,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl<'a, T> Drop for UPIntrRefMut<'a, T>","synthetic":false,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl Drop for PidHandle","synthetic":false,"types":["os::task::id::PidHandle"]},{"text":"impl Drop for KernelStack","synthetic":false,"types":["os::task::id::KernelStack"]},{"text":"impl Drop for TaskUserRes","synthetic":false,"types":["os::task::id::TaskUserRes"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/panic/unwind_safe/trait.RefUnwindSafe.js b/ch9-log/implementors/core/panic/unwind_safe/trait.RefUnwindSafe.js
new file mode 100644
index 00000000..39088268
--- /dev/null
+++ b/ch9-log/implementors/core/panic/unwind_safe/trait.RefUnwindSafe.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl RefUnwindSafe for Stdout","synthetic":true,"types":["os::console::Stdout"]},{"text":"impl RefUnwindSafe for Kstdout","synthetic":true,"types":["os::console::Kstdout"]},{"text":"impl !RefUnwindSafe for VirtIOBlock","synthetic":true,"types":["os::drivers::block::virtio_blk::VirtIOBlock"]},{"text":"impl RefUnwindSafe for QUEUE_FRAMES","synthetic":true,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl RefUnwindSafe for BLOCK_DEVICE","synthetic":true,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl RefUnwindSafe for IER","synthetic":true,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl RefUnwindSafe for LSR","synthetic":true,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl RefUnwindSafe for MCR","synthetic":true,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl RefUnwindSafe for ReadWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::ReadWithoutDLAB"]},{"text":"impl RefUnwindSafe for WriteWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::WriteWithoutDLAB"]},{"text":"impl RefUnwindSafe for NS16550aRaw","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aRaw"]},{"text":"impl RefUnwindSafe for NS16550aInner","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aInner"]},{"text":"impl<const BASE_ADDR: usize> !RefUnwindSafe for NS16550a<BASE_ADDR>","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550a"]},{"text":"impl RefUnwindSafe for UART","synthetic":true,"types":["os::drivers::chardev::UART"]},{"text":"impl RefUnwindSafe for PLIC","synthetic":true,"types":["os::drivers::plic::PLIC"]},{"text":"impl RefUnwindSafe for IntrTargetPriority","synthetic":true,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl !RefUnwindSafe for OSInode","synthetic":true,"types":["os::fs::inode::OSInode"]},{"text":"impl !RefUnwindSafe for OSInodeInner","synthetic":true,"types":["os::fs::inode::OSInodeInner"]},{"text":"impl RefUnwindSafe for ROOT_INODE","synthetic":true,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl RefUnwindSafe for OpenFlags","synthetic":true,"types":["os::fs::inode::OpenFlags"]},{"text":"impl !RefUnwindSafe for Pipe","synthetic":true,"types":["os::fs::pipe::Pipe"]},{"text":"impl RefUnwindSafe for RingBufferStatus","synthetic":true,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl !RefUnwindSafe for PipeRingBuffer","synthetic":true,"types":["os::fs::pipe::PipeRingBuffer"]},{"text":"impl RefUnwindSafe for Stdin","synthetic":true,"types":["os::fs::stdio::Stdin"]},{"text":"impl RefUnwindSafe for Stdout","synthetic":true,"types":["os::fs::stdio::Stdout"]},{"text":"impl RefUnwindSafe for PhysAddr","synthetic":true,"types":["os::mm::address::PhysAddr"]},{"text":"impl RefUnwindSafe for VirtAddr","synthetic":true,"types":["os::mm::address::VirtAddr"]},{"text":"impl RefUnwindSafe for PhysPageNum","synthetic":true,"types":["os::mm::address::PhysPageNum"]},{"text":"impl RefUnwindSafe for VirtPageNum","synthetic":true,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T> RefUnwindSafe for SimpleRange<T> where T: RefUnwindSafe, ","synthetic":true,"types":["os::mm::address::SimpleRange"]},{"text":"impl<T> RefUnwindSafe for SimpleRangeIterator<T> where T: RefUnwindSafe, ","synthetic":true,"types":["os::mm::address::SimpleRangeIterator"]},{"text":"impl RefUnwindSafe for FrameTracker","synthetic":true,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl RefUnwindSafe for StackFrameAllocator","synthetic":true,"types":["os::mm::frame_allocator::StackFrameAllocator"]},{"text":"impl RefUnwindSafe for FRAME_ALLOCATOR","synthetic":true,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl RefUnwindSafe for KERNEL_SPACE","synthetic":true,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl RefUnwindSafe for MemorySet","synthetic":true,"types":["os::mm::memory_set::MemorySet"]},{"text":"impl RefUnwindSafe for MapArea","synthetic":true,"types":["os::mm::memory_set::MapArea"]},{"text":"impl RefUnwindSafe for MapType","synthetic":true,"types":["os::mm::memory_set::MapType"]},{"text":"impl RefUnwindSafe for MapPermission","synthetic":true,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl RefUnwindSafe for PTEFlags","synthetic":true,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl RefUnwindSafe for PageTableEntry","synthetic":true,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl RefUnwindSafe for PageTable","synthetic":true,"types":["os::mm::page_table::PageTable"]},{"text":"impl RefUnwindSafe for UserBuffer","synthetic":true,"types":["os::mm::page_table::UserBuffer"]},{"text":"impl RefUnwindSafe for UserBufferIterator","synthetic":true,"types":["os::mm::page_table::UserBufferIterator"]},{"text":"impl !RefUnwindSafe for Condvar","synthetic":true,"types":["os::sync::condvar::Condvar"]},{"text":"impl !RefUnwindSafe for CondvarInner","synthetic":true,"types":["os::sync::condvar::CondvarInner"]},{"text":"impl !RefUnwindSafe for MutexSpin","synthetic":true,"types":["os::sync::mutex::MutexSpin"]},{"text":"impl !RefUnwindSafe for MutexBlocking","synthetic":true,"types":["os::sync::mutex::MutexBlocking"]},{"text":"impl !RefUnwindSafe for MutexBlockingInner","synthetic":true,"types":["os::sync::mutex::MutexBlockingInner"]},{"text":"impl !RefUnwindSafe for Semaphore","synthetic":true,"types":["os::sync::semaphore::Semaphore"]},{"text":"impl !RefUnwindSafe for SemaphoreInner","synthetic":true,"types":["os::sync::semaphore::SemaphoreInner"]},{"text":"impl<T> !RefUnwindSafe for UPSafeCellRaw<T>","synthetic":true,"types":["os::sync::up::UPSafeCellRaw"]},{"text":"impl RefUnwindSafe for IntrMaskingInfo","synthetic":true,"types":["os::sync::up::IntrMaskingInfo"]},{"text":"impl RefUnwindSafe for INTR_MASKING_INFO","synthetic":true,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl<T> !RefUnwindSafe for UPIntrFreeCell<T>","synthetic":true,"types":["os::sync::up::UPIntrFreeCell"]},{"text":"impl<'a, T> !RefUnwindSafe for UPIntrRefMut<'a, T>","synthetic":true,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl RefUnwindSafe for TaskContext","synthetic":true,"types":["os::task::context::TaskContext"]},{"text":"impl RefUnwindSafe for RecycleAllocator","synthetic":true,"types":["os::task::id::RecycleAllocator"]},{"text":"impl RefUnwindSafe for PID_ALLOCATOR","synthetic":true,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl RefUnwindSafe for KSTACK_ALLOCATOR","synthetic":true,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl RefUnwindSafe for PidHandle","synthetic":true,"types":["os::task::id::PidHandle"]},{"text":"impl RefUnwindSafe for KernelStack","synthetic":true,"types":["os::task::id::KernelStack"]},{"text":"impl !RefUnwindSafe for TaskUserRes","synthetic":true,"types":["os::task::id::TaskUserRes"]},{"text":"impl !RefUnwindSafe for TaskManager","synthetic":true,"types":["os::task::manager::TaskManager"]},{"text":"impl RefUnwindSafe for TASK_MANAGER","synthetic":true,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl RefUnwindSafe for PID2PCB","synthetic":true,"types":["os::task::manager::PID2PCB"]},{"text":"impl !RefUnwindSafe for ProcessControlBlock","synthetic":true,"types":["os::task::process::ProcessControlBlock"]},{"text":"impl !RefUnwindSafe for ProcessControlBlockInner","synthetic":true,"types":["os::task::process::ProcessControlBlockInner"]},{"text":"impl !RefUnwindSafe for Processor","synthetic":true,"types":["os::task::processor::Processor"]},{"text":"impl RefUnwindSafe for PROCESSOR","synthetic":true,"types":["os::task::processor::PROCESSOR"]},{"text":"impl RefUnwindSafe for SignalFlags","synthetic":true,"types":["os::task::signal::SignalFlags"]},{"text":"impl !RefUnwindSafe for TaskControlBlock","synthetic":true,"types":["os::task::task::TaskControlBlock"]},{"text":"impl !RefUnwindSafe for TaskControlBlockInner","synthetic":true,"types":["os::task::task::TaskControlBlockInner"]},{"text":"impl RefUnwindSafe for TaskStatus","synthetic":true,"types":["os::task::task::TaskStatus"]},{"text":"impl RefUnwindSafe for INITPROC","synthetic":true,"types":["os::task::INITPROC"]},{"text":"impl !RefUnwindSafe for TimerCondVar","synthetic":true,"types":["os::timer::TimerCondVar"]},{"text":"impl RefUnwindSafe for TIMERS","synthetic":true,"types":["os::timer::TIMERS"]},{"text":"impl RefUnwindSafe for TrapContext","synthetic":true,"types":["os::trap::context::TrapContext"]},{"text":"impl RefUnwindSafe for DEV_NON_BLOCKING_ACCESS","synthetic":true,"types":["os::DEV_NON_BLOCKING_ACCESS"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/core/panic/unwind_safe/trait.UnwindSafe.js b/ch9-log/implementors/core/panic/unwind_safe/trait.UnwindSafe.js
new file mode 100644
index 00000000..f42f1811
--- /dev/null
+++ b/ch9-log/implementors/core/panic/unwind_safe/trait.UnwindSafe.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl UnwindSafe for Stdout","synthetic":true,"types":["os::console::Stdout"]},{"text":"impl UnwindSafe for Kstdout","synthetic":true,"types":["os::console::Kstdout"]},{"text":"impl !UnwindSafe for VirtIOBlock","synthetic":true,"types":["os::drivers::block::virtio_blk::VirtIOBlock"]},{"text":"impl UnwindSafe for QUEUE_FRAMES","synthetic":true,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl UnwindSafe for BLOCK_DEVICE","synthetic":true,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl UnwindSafe for IER","synthetic":true,"types":["os::drivers::chardev::ns16550a::IER"]},{"text":"impl UnwindSafe for LSR","synthetic":true,"types":["os::drivers::chardev::ns16550a::LSR"]},{"text":"impl UnwindSafe for MCR","synthetic":true,"types":["os::drivers::chardev::ns16550a::MCR"]},{"text":"impl UnwindSafe for ReadWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::ReadWithoutDLAB"]},{"text":"impl UnwindSafe for WriteWithoutDLAB","synthetic":true,"types":["os::drivers::chardev::ns16550a::WriteWithoutDLAB"]},{"text":"impl UnwindSafe for NS16550aRaw","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aRaw"]},{"text":"impl UnwindSafe for NS16550aInner","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550aInner"]},{"text":"impl<const BASE_ADDR: usize> !UnwindSafe for NS16550a<BASE_ADDR>","synthetic":true,"types":["os::drivers::chardev::ns16550a::NS16550a"]},{"text":"impl UnwindSafe for UART","synthetic":true,"types":["os::drivers::chardev::UART"]},{"text":"impl UnwindSafe for PLIC","synthetic":true,"types":["os::drivers::plic::PLIC"]},{"text":"impl UnwindSafe for IntrTargetPriority","synthetic":true,"types":["os::drivers::plic::IntrTargetPriority"]},{"text":"impl !UnwindSafe for OSInode","synthetic":true,"types":["os::fs::inode::OSInode"]},{"text":"impl !UnwindSafe for OSInodeInner","synthetic":true,"types":["os::fs::inode::OSInodeInner"]},{"text":"impl UnwindSafe for ROOT_INODE","synthetic":true,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl UnwindSafe for OpenFlags","synthetic":true,"types":["os::fs::inode::OpenFlags"]},{"text":"impl !UnwindSafe for Pipe","synthetic":true,"types":["os::fs::pipe::Pipe"]},{"text":"impl UnwindSafe for RingBufferStatus","synthetic":true,"types":["os::fs::pipe::RingBufferStatus"]},{"text":"impl !UnwindSafe for PipeRingBuffer","synthetic":true,"types":["os::fs::pipe::PipeRingBuffer"]},{"text":"impl UnwindSafe for Stdin","synthetic":true,"types":["os::fs::stdio::Stdin"]},{"text":"impl UnwindSafe for Stdout","synthetic":true,"types":["os::fs::stdio::Stdout"]},{"text":"impl UnwindSafe for PhysAddr","synthetic":true,"types":["os::mm::address::PhysAddr"]},{"text":"impl UnwindSafe for VirtAddr","synthetic":true,"types":["os::mm::address::VirtAddr"]},{"text":"impl UnwindSafe for PhysPageNum","synthetic":true,"types":["os::mm::address::PhysPageNum"]},{"text":"impl UnwindSafe for VirtPageNum","synthetic":true,"types":["os::mm::address::VirtPageNum"]},{"text":"impl<T> UnwindSafe for SimpleRange<T> where T: UnwindSafe, ","synthetic":true,"types":["os::mm::address::SimpleRange"]},{"text":"impl<T> UnwindSafe for SimpleRangeIterator<T> where T: UnwindSafe, ","synthetic":true,"types":["os::mm::address::SimpleRangeIterator"]},{"text":"impl UnwindSafe for FrameTracker","synthetic":true,"types":["os::mm::frame_allocator::FrameTracker"]},{"text":"impl UnwindSafe for StackFrameAllocator","synthetic":true,"types":["os::mm::frame_allocator::StackFrameAllocator"]},{"text":"impl UnwindSafe for FRAME_ALLOCATOR","synthetic":true,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl UnwindSafe for KERNEL_SPACE","synthetic":true,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl UnwindSafe for MemorySet","synthetic":true,"types":["os::mm::memory_set::MemorySet"]},{"text":"impl UnwindSafe for MapArea","synthetic":true,"types":["os::mm::memory_set::MapArea"]},{"text":"impl UnwindSafe for MapType","synthetic":true,"types":["os::mm::memory_set::MapType"]},{"text":"impl UnwindSafe for MapPermission","synthetic":true,"types":["os::mm::memory_set::MapPermission"]},{"text":"impl UnwindSafe for PTEFlags","synthetic":true,"types":["os::mm::page_table::PTEFlags"]},{"text":"impl UnwindSafe for PageTableEntry","synthetic":true,"types":["os::mm::page_table::PageTableEntry"]},{"text":"impl UnwindSafe for PageTable","synthetic":true,"types":["os::mm::page_table::PageTable"]},{"text":"impl !UnwindSafe for UserBuffer","synthetic":true,"types":["os::mm::page_table::UserBuffer"]},{"text":"impl !UnwindSafe for UserBufferIterator","synthetic":true,"types":["os::mm::page_table::UserBufferIterator"]},{"text":"impl !UnwindSafe for Condvar","synthetic":true,"types":["os::sync::condvar::Condvar"]},{"text":"impl !UnwindSafe for CondvarInner","synthetic":true,"types":["os::sync::condvar::CondvarInner"]},{"text":"impl UnwindSafe for MutexSpin","synthetic":true,"types":["os::sync::mutex::MutexSpin"]},{"text":"impl !UnwindSafe for MutexBlocking","synthetic":true,"types":["os::sync::mutex::MutexBlocking"]},{"text":"impl !UnwindSafe for MutexBlockingInner","synthetic":true,"types":["os::sync::mutex::MutexBlockingInner"]},{"text":"impl !UnwindSafe for Semaphore","synthetic":true,"types":["os::sync::semaphore::Semaphore"]},{"text":"impl !UnwindSafe for SemaphoreInner","synthetic":true,"types":["os::sync::semaphore::SemaphoreInner"]},{"text":"impl<T> UnwindSafe for UPSafeCellRaw<T> where T: UnwindSafe, ","synthetic":true,"types":["os::sync::up::UPSafeCellRaw"]},{"text":"impl UnwindSafe for IntrMaskingInfo","synthetic":true,"types":["os::sync::up::IntrMaskingInfo"]},{"text":"impl UnwindSafe for INTR_MASKING_INFO","synthetic":true,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl<T> UnwindSafe for UPIntrFreeCell<T> where T: UnwindSafe, ","synthetic":true,"types":["os::sync::up::UPIntrFreeCell"]},{"text":"impl<'a, T> !UnwindSafe for UPIntrRefMut<'a, T>","synthetic":true,"types":["os::sync::up::UPIntrRefMut"]},{"text":"impl UnwindSafe for TaskContext","synthetic":true,"types":["os::task::context::TaskContext"]},{"text":"impl UnwindSafe for RecycleAllocator","synthetic":true,"types":["os::task::id::RecycleAllocator"]},{"text":"impl UnwindSafe for PID_ALLOCATOR","synthetic":true,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl UnwindSafe for KSTACK_ALLOCATOR","synthetic":true,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl UnwindSafe for PidHandle","synthetic":true,"types":["os::task::id::PidHandle"]},{"text":"impl UnwindSafe for KernelStack","synthetic":true,"types":["os::task::id::KernelStack"]},{"text":"impl !UnwindSafe for TaskUserRes","synthetic":true,"types":["os::task::id::TaskUserRes"]},{"text":"impl !UnwindSafe for TaskManager","synthetic":true,"types":["os::task::manager::TaskManager"]},{"text":"impl UnwindSafe for TASK_MANAGER","synthetic":true,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl UnwindSafe for PID2PCB","synthetic":true,"types":["os::task::manager::PID2PCB"]},{"text":"impl !UnwindSafe for ProcessControlBlock","synthetic":true,"types":["os::task::process::ProcessControlBlock"]},{"text":"impl !UnwindSafe for ProcessControlBlockInner","synthetic":true,"types":["os::task::process::ProcessControlBlockInner"]},{"text":"impl !UnwindSafe for Processor","synthetic":true,"types":["os::task::processor::Processor"]},{"text":"impl UnwindSafe for PROCESSOR","synthetic":true,"types":["os::task::processor::PROCESSOR"]},{"text":"impl UnwindSafe for SignalFlags","synthetic":true,"types":["os::task::signal::SignalFlags"]},{"text":"impl !UnwindSafe for TaskControlBlock","synthetic":true,"types":["os::task::task::TaskControlBlock"]},{"text":"impl !UnwindSafe for TaskControlBlockInner","synthetic":true,"types":["os::task::task::TaskControlBlockInner"]},{"text":"impl UnwindSafe for TaskStatus","synthetic":true,"types":["os::task::task::TaskStatus"]},{"text":"impl UnwindSafe for INITPROC","synthetic":true,"types":["os::task::INITPROC"]},{"text":"impl !UnwindSafe for TimerCondVar","synthetic":true,"types":["os::timer::TimerCondVar"]},{"text":"impl UnwindSafe for TIMERS","synthetic":true,"types":["os::timer::TIMERS"]},{"text":"impl UnwindSafe for TrapContext","synthetic":true,"types":["os::trap::context::TrapContext"]},{"text":"impl UnwindSafe for DEV_NON_BLOCKING_ACCESS","synthetic":true,"types":["os::DEV_NON_BLOCKING_ACCESS"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/easy_fs/block_dev/trait.BlockDevice.js b/ch9-log/implementors/easy_fs/block_dev/trait.BlockDevice.js
new file mode 100644
index 00000000..41803dde
--- /dev/null
+++ b/ch9-log/implementors/easy_fs/block_dev/trait.BlockDevice.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl BlockDevice for VirtIOBlock","synthetic":false,"types":["os::drivers::block::virtio_blk::VirtIOBlock"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/lazy_static/trait.LazyStatic.js b/ch9-log/implementors/lazy_static/trait.LazyStatic.js
new file mode 100644
index 00000000..66313c01
--- /dev/null
+++ b/ch9-log/implementors/lazy_static/trait.LazyStatic.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [{"text":"impl LazyStatic for QUEUE_FRAMES","synthetic":false,"types":["os::drivers::block::virtio_blk::QUEUE_FRAMES"]},{"text":"impl LazyStatic for BLOCK_DEVICE","synthetic":false,"types":["os::drivers::block::BLOCK_DEVICE"]},{"text":"impl LazyStatic for UART","synthetic":false,"types":["os::drivers::chardev::UART"]},{"text":"impl LazyStatic for ROOT_INODE","synthetic":false,"types":["os::fs::inode::ROOT_INODE"]},{"text":"impl LazyStatic for FRAME_ALLOCATOR","synthetic":false,"types":["os::mm::frame_allocator::FRAME_ALLOCATOR"]},{"text":"impl LazyStatic for KERNEL_SPACE","synthetic":false,"types":["os::mm::memory_set::KERNEL_SPACE"]},{"text":"impl LazyStatic for INTR_MASKING_INFO","synthetic":false,"types":["os::sync::up::INTR_MASKING_INFO"]},{"text":"impl LazyStatic for PID_ALLOCATOR","synthetic":false,"types":["os::task::id::PID_ALLOCATOR"]},{"text":"impl LazyStatic for KSTACK_ALLOCATOR","synthetic":false,"types":["os::task::id::KSTACK_ALLOCATOR"]},{"text":"impl LazyStatic for TASK_MANAGER","synthetic":false,"types":["os::task::manager::TASK_MANAGER"]},{"text":"impl LazyStatic for PID2PCB","synthetic":false,"types":["os::task::manager::PID2PCB"]},{"text":"impl LazyStatic for PROCESSOR","synthetic":false,"types":["os::task::processor::PROCESSOR"]},{"text":"impl LazyStatic for INITPROC","synthetic":false,"types":["os::task::INITPROC"]},{"text":"impl LazyStatic for TIMERS","synthetic":false,"types":["os::timer::TIMERS"]},{"text":"impl LazyStatic for DEV_NON_BLOCKING_ACCESS","synthetic":false,"types":["os::DEV_NON_BLOCKING_ACCESS"]}];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/os/drivers/chardev/trait.CharDevice.js b/ch9-log/implementors/os/drivers/chardev/trait.CharDevice.js
new file mode 100644
index 00000000..34fffcbd
--- /dev/null
+++ b/ch9-log/implementors/os/drivers/chardev/trait.CharDevice.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/os/fs/trait.File.js b/ch9-log/implementors/os/fs/trait.File.js
new file mode 100644
index 00000000..34fffcbd
--- /dev/null
+++ b/ch9-log/implementors/os/fs/trait.File.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/os/mm/address/trait.StepByOne.js b/ch9-log/implementors/os/mm/address/trait.StepByOne.js
new file mode 100644
index 00000000..34fffcbd
--- /dev/null
+++ b/ch9-log/implementors/os/mm/address/trait.StepByOne.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/os/mm/frame_allocator/trait.FrameAllocator.js b/ch9-log/implementors/os/mm/frame_allocator/trait.FrameAllocator.js
new file mode 100644
index 00000000..34fffcbd
--- /dev/null
+++ b/ch9-log/implementors/os/mm/frame_allocator/trait.FrameAllocator.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/implementors/os/sync/mutex/trait.Mutex.js b/ch9-log/implementors/os/sync/mutex/trait.Mutex.js
new file mode 100644
index 00000000..34fffcbd
--- /dev/null
+++ b/ch9-log/implementors/os/sync/mutex/trait.Mutex.js
@@ -0,0 +1,3 @@
+(function() {var implementors = {};
+implementors["os"] = [];
+if (window.register_implementors) {window.register_implementors(implementors);} else {window.pending_implementors = implementors;}})()
\ No newline at end of file
diff --git a/ch9-log/light.css b/ch9-log/light.css
new file mode 100644
index 00000000..e8cf0741
--- /dev/null
+++ b/ch9-log/light.css
@@ -0,0 +1 @@
+ body{background-color:white;color:black;}h1,h2,h3,h4{color:black;}h1.fqn{border-bottom-color:#DDDDDD;}h2,h3,h4{border-bottom-color:#DDDDDD;}.in-band{background-color:white;}.invisible{background:rgba(0,0,0,0);}.docblock code,.docblock-short code{background-color:#F5F5F5;}pre,.rustdoc.source .example-wrap{background-color:#F5F5F5;}.sidebar{background-color:#F5F5F5;}*{scrollbar-color:rgba(36,37,39,0.6) #e6e6e6;}.sidebar{scrollbar-color:rgba(36,37,39,0.6) #d9d9d9;}.rust-logo{}::-webkit-scrollbar-track{background-color:#ecebeb;}::-webkit-scrollbar-thumb{background-color:rgba(36,37,39,0.6);}.sidebar::-webkit-scrollbar-track{background-color:#dcdcdc;}.sidebar::-webkit-scrollbar-thumb{background-color:rgba(36,37,39,0.6);}.sidebar .current{background-color:#fff;}.source .sidebar{background-color:#f1f1f1;}.sidebar .location{border-color:#000;background-color:#fff;color:#333;}.sidebar .version{border-bottom-color:#DDD;}.sidebar-title{border-top-color:#777;border-bottom-color:#777;}.block a:hover{background:#F5F5F5;}.line-numbers span{color:#c67e2d;}.line-numbers .line-highlighted{background-color:#FDFFD3 !important;}.docblock h1,.docblock h2,.docblock h3,.docblock h4,.docblock h5,.docblock h6{border-bottom-color:#ddd;}.docblock table td,.docblock table th{border-color:#ddd;}.content .method .where,.content .fn .where,.content .where.fmt-newline{color:#4E4C4C;}.search-results a:hover{background-color:#ddd;}.search-results a:focus{color:#000 !important;background-color:#ccc;}.search-results a:focus span{color:#000 !important;}a.result-trait:focus{background-color:#c7b6ff;}a.result-traitalias:focus{background-color:#c7b6ff;}a.result-mod:focus,a.result-externcrate:focus{background-color:#afc6e4;}a.result-enum:focus{background-color:#e7b1a0;}a.result-struct:focus{background-color:#e7b1a0;}a.result-union:focus{background-color:#e7b1a0;}a.result-fn:focus,a.result-method:focus,a.result-tymethod:focus{background-color:#c6afb3;}a.result-type:focus{background-color:#e7b1a0;}a.result-associatedtype:focus{background-color:#afc6e4;}a.result-foreigntype:focus{background-color:#e7b1a0;}a.result-attr:focus,a.result-derive:focus,a.result-macro:focus{background-color:#8ce488;}a.result-constant:focus,a.result-static:focus{background-color:#afc6e4;}a.result-primitive:focus{background-color:#e7b1a0;}a.result-keyword:focus{background-color:#afc6e4;}.content .item-info::before{color:#ccc;}.content span.enum,.content a.enum,.block a.current.enum{color:#AD378A;}.content span.struct,.content a.struct,.block a.current.struct{color:#AD378A;}.content span.type,.content a.type,.block a.current.type{color:#AD378A;}.content span.foreigntype,.content a.foreigntype,.block a.current.foreigntype{color:#3873AD;}.content span.associatedtype,.content a.associatedtype,.block a.current.associatedtype{color:#3873AD;}.content span.attr,.content a.attr,.block a.current.attr,.content span.derive,.content a.derive,.block a.current.derive,.content span.macro,.content a.macro,.block a.current.macro{color:#068000;}.content span.union,.content a.union,.block a.current.union{color:#AD378A;}.content span.constant,.content a.constant,.block a.current.constant,.content span.static,.content a.static,.block a.current.static{color:#3873AD;}.content span.primitive,.content a.primitive,.block a.current.primitive{color:#AD378A;}.content span.externcrate,.content span.mod,.content a.mod,.block a.current.mod{color:#3873AD;}.content span.trait,.content a.trait,.block a.current.trait{color:#6E4FC9;}.content span.traitalias,.content a.traitalias,.block a.current.traitalias{color:#5137AD;}.content span.fn,.content a.fn,.block a.current.fn,.content span.method,.content a.method,.block a.current.method,.content span.tymethod,.content a.tymethod,.block a.current.tymethod,.content .fnname{color:#AD7C37;}.content span.keyword,.content a.keyword,.block a.current.keyword{color:#3873AD;}nav:not(.sidebar){border-bottom-color:#e0e0e0;}nav.main .current{border-top-color:#000;border-bottom-color:#000;}nav.main .separator{border:1px solid #000;}a{color:#3873AD;}a#toggle-all-docs,a.anchor,.small-section-header a,#source-sidebar a,pre.rust a,.sidebar a,.in-band a{color:#000;}.search-results a{color:initial;}a.test-arrow{color:#f5f5f5;}body.source .example-wrap pre.rust a{background:#eee;}details.rustdoc-toggle>summary.hideme>span,details.rustdoc-toggle>summary::before,details.undocumented>summary::before{color:#999;}#crate-search{color:#555;background-color:white;border-color:#e0e0e0;box-shadow:0 0 0 1px #e0e0e0,0 0 0 2px transparent;}.search-input{color:#555;background-color:white;box-shadow:0 0 0 1px #e0e0e0,0 0 0 2px transparent;}.search-input:focus{border-color:#66afe9;}#crate-search+.search-input:focus{box-shadow:0 0 8px #078dd8;}.module-item .stab,.import-item .stab{color:#000;}.stab.unstable{background:#FFF5D6;border-color:#FFC600;}.stab.deprecated{background:#ffc4c4;border-color:#db7b7b;}.stab.portability{background:#F3DFFF;border-color:#b07bdb;}.stab.portability>code{background:none;}#help>div{background:#e9e9e9;border-color:#bfbfbf;}#help span.bottom,#help span.top{border-color:#bfbfbf;}.rightside,.out-of-band{color:grey;}.result-name .primitive>i,.result-name .keyword>i{color:black;}.line-numbers :target{background-color:transparent;}pre.rust .kw{color:#8959A8;}pre.rust .kw-2,pre.rust .prelude-ty{color:#4271AE;}pre.rust .number,pre.rust .string{color:#718C00;}pre.rust .self,pre.rust .bool-val,pre.rust .prelude-val,pre.rust .attribute,pre.rust .attribute .ident{color:#C82829;}pre.rust .comment{color:#8E908C;}pre.rust .doccomment{color:#4D4D4C;}pre.rust .macro,pre.rust .macro-nonterminal{color:#3E999F;}pre.rust .lifetime{color:#B76514;}pre.rust .question-mark{color:#ff9011;}.example-wrap>pre.line-number{border-color:#c7c7c7;}a.test-arrow{background-color:rgb(78,139,202,0.2);}a.test-arrow:hover{background-color:#4e8bca;}.toggle-label,.code-attribute{color:#999;}:target{background:#FDFFD3;border-right:3px solid #AD7C37;}pre.compile_fail{border-left:2px solid rgba(255,0,0,.5);}pre.compile_fail:hover,.information:hover+pre.compile_fail{border-left:2px solid #f00;}pre.should_panic{border-left:2px solid rgba(255,0,0,.5);}pre.should_panic:hover,.information:hover+pre.should_panic{border-left:2px solid #f00;}pre.ignore{border-left:2px solid rgba(255,142,0,.6);}pre.ignore:hover,.information:hover+pre.ignore{border-left:2px solid #ff9200;}.tooltip.compile_fail{color:rgba(255,0,0,.5);}.information>.compile_fail:hover{color:#f00;}.tooltip.should_panic{color:rgba(255,0,0,.5);}.information>.should_panic:hover{color:#f00;}.tooltip.ignore{color:rgba(255,142,0,.6);}.information>.ignore:hover{color:#ff9200;}.search-failed a{color:#3873AD;}.tooltip::after{background-color:#000;color:#fff;}.tooltip::before{border-color:transparent black transparent transparent;}.notable-traits-tooltiptext{background-color:#eee;border-color:#999;}.notable-traits-tooltiptext .notable{border-bottom-color:#DDDDDD;}#titles>button:not(.selected){background-color:#e6e6e6;border-top-color:#e6e6e6;}#titles>button:hover,#titles>button.selected{background-color:#ffffff;border-top-color:#0089ff;}#titles>button>div.count{color:#888;}@media (max-width:700px){.sidebar-menu{background-color:#F5F5F5;border-bottom-color:#e0e0e0;border-right-color:#e0e0e0;}.sidebar-elems{background-color:#F5F5F5;border-right-color:#000;}#sidebar-filler{background-color:#F5F5F5;border-bottom-color:#e0e0e0;}}kbd{color:#000;background-color:#fafbfc;border-color:#d1d5da;border-bottom-color:#c6cbd1;box-shadow-color:#c6cbd1;}#theme-picker,#settings-menu,#help-button{border-color:#e0e0e0;background-color:#fff;}#theme-picker:hover,#theme-picker:focus,#settings-menu:hover,#settings-menu:focus,#help-button:hover,#help-button:focus{border-color:#717171;}#copy-path{color:#999;}#copy-path>img{filter:invert(50%);}#copy-path:hover>img{filter:invert(35%);}#theme-choices{border-color:#ccc;background-color:#fff;}#theme-choices>button:not(:first-child){border-top-color:#e0e0e0;}#theme-choices>button:hover,#theme-choices>button:focus{background-color:#eee;}@media (max-width:700px){#theme-picker{background:#fff;}}#all-types{background-color:#fff;}#all-types:hover{background-color:#f9f9f9;}.search-results .result-name span.alias{color:#000;}.search-results .result-name span.grey{color:#999;}#sidebar-toggle{background-color:#F5F5F5;}#sidebar-toggle:hover{background-color:#E0E0E0;}#source-sidebar{background-color:#F5F5F5;}#source-sidebar>.title{border-bottom-color:#ccc;}div.files>a:hover,div.name:hover{background-color:#E0E0E0;}div.files>.selected{background-color:#fff;}.setting-line>.title{border-bottom-color:#D5D5D5;}
\ No newline at end of file
diff --git a/ch9-log/main.js b/ch9-log/main.js
new file mode 100644
index 00000000..3a235b2a
--- /dev/null
+++ b/ch9-log/main.js
@@ -0,0 +1,8 @@
+if(!String.prototype.startsWith){String.prototype.startsWith=function(searchString,position){position=position||0;return this.indexOf(searchString,position)===position}}if(!String.prototype.endsWith){String.prototype.endsWith=function(suffix,length){var l=length||this.length;return this.indexOf(suffix,l-suffix.length)!==-1}}if(!DOMTokenList.prototype.add){DOMTokenList.prototype.add=function(className){if(className&&!hasClass(this,className)){if(this.className&&this.className.length>0){this.className+=" "+className}else{this.className=className}}}}if(!DOMTokenList.prototype.remove){DOMTokenList.prototype.remove=function(className){if(className&&this.className){this.className=(" "+this.className+" ").replace(" "+className+" "," ").trim()}}}function getVar(name){var el=document.getElementById("rustdoc-vars");if(el){return el.attributes["data-"+name].value}else{return null}}function resourcePath(basename,extension){return getVar("root-path")+basename+getVar("resource-suffix")+extension}(function(){window.rootPath=getVar("root-path");window.currentCrate=getVar("current-crate");window.searchJS=resourcePath("search",".js");window.searchIndexJS=resourcePath("search-index",".js");var sidebarVars=document.getElementById("sidebar-vars");if(sidebarVars){window.sidebarCurrent={name:sidebarVars.attributes["data-name"].value,ty:sidebarVars.attributes["data-ty"].value,relpath:sidebarVars.attributes["data-relpath"].value,}}}());function getVirtualKey(ev){if("key"in ev&&typeof ev.key!="undefined"){return ev.key}var c=ev.charCode||ev.keyCode;if(c==27){return"Escape"}return String.fromCharCode(c)}var THEME_PICKER_ELEMENT_ID="theme-picker";var THEMES_ELEMENT_ID="theme-choices";var MAIN_ID="main-content";function getThemesElement(){return document.getElementById(THEMES_ELEMENT_ID)}function getThemePickerElement(){return document.getElementById(THEME_PICKER_ELEMENT_ID)}function getNakedUrl(){return window.location.href.split("?")[0].split("#")[0]}function showThemeButtonState(){var themePicker=getThemePickerElement();var themeChoices=getThemesElement();themeChoices.style.display="block";themePicker.style.borderBottomRightRadius="0";themePicker.style.borderBottomLeftRadius="0"}function hideThemeButtonState(){var themePicker=getThemePickerElement();var themeChoices=getThemesElement();themeChoices.style.display="none";themePicker.style.borderBottomRightRadius="3px";themePicker.style.borderBottomLeftRadius="3px"}(function(){if(!document.location.href.startsWith("file:///")){return}var themeChoices=getThemesElement();var themePicker=getThemePickerElement();var availableThemes=getVar("themes").split(",");removeClass(themeChoices.parentElement,"hidden");function switchThemeButtonState(){if(themeChoices.style.display==="block"){hideThemeButtonState()}else{showThemeButtonState()}}function handleThemeButtonsBlur(e){var active=document.activeElement;var related=e.relatedTarget;if(active.id!==THEME_PICKER_ELEMENT_ID&&(!active.parentNode||active.parentNode.id!==THEMES_ELEMENT_ID)&&(!related||(related.id!==THEME_PICKER_ELEMENT_ID&&(!related.parentNode||related.parentNode.id!==THEMES_ELEMENT_ID)))){hideThemeButtonState()}}themePicker.onclick=switchThemeButtonState;themePicker.onblur=handleThemeButtonsBlur;availableThemes.forEach(function(item){var but=document.createElement("button");but.textContent=item;but.onclick=function(){switchTheme(window.currentTheme,window.mainTheme,item,true);useSystemTheme(false)};but.onblur=handleThemeButtonsBlur;themeChoices.appendChild(but)})}());(function(){"use strict";window.searchState={loadingText:"Loading search results...",input:document.getElementsByClassName("search-input")[0],outputElement:function(){return document.getElementById("search")},title:document.title,titleBeforeSearch:document.title,timeout:null,currentTab:0,focusedByTab:[null,null,null],clearInputTimeout:function(){if(searchState.timeout!==null){clearTimeout(searchState.timeout);searchState.timeout=null}},focus:function(){searchState.input.focus()},defocus:function(){searchState.input.blur()},showResults:function(search){if(search===null||typeof search==='undefined'){search=searchState.outputElement()}addClass(main,"hidden");removeClass(search,"hidden");searchState.mouseMovedAfterSearch=false;document.title=searchState.title},hideResults:function(search){if(search===null||typeof search==='undefined'){search=searchState.outputElement()}addClass(search,"hidden");removeClass(main,"hidden");document.title=searchState.titleBeforeSearch;if(searchState.browserSupportsHistoryApi()){history.replaceState("",window.currentCrate+" - Rust",getNakedUrl()+window.location.hash)}},getQueryStringParams:function(){var params={};window.location.search.substring(1).split("&").map(function(s){var pair=s.split("=");params[decodeURIComponent(pair[0])]=typeof pair[1]==="undefined"?null:decodeURIComponent(pair[1])});return params},putBackSearch:function(search_input){var search=searchState.outputElement();if(search_input.value!==""&&hasClass(search,"hidden")){searchState.showResults(search);if(searchState.browserSupportsHistoryApi()){var extra="?search="+encodeURIComponent(search_input.value);history.replaceState(search_input.value,"",getNakedUrl()+extra+window.location.hash)}document.title=searchState.title}},browserSupportsHistoryApi:function(){return window.history&&typeof window.history.pushState==="function"},setup:function(){var search_input=searchState.input;if(!searchState.input){return}function loadScript(url){var script=document.createElement('script');script.src=url;document.head.append(script)}var searchLoaded=false;function loadSearch(){if(!searchLoaded){searchLoaded=true;loadScript(window.searchJS);loadScript(window.searchIndexJS)}}search_input.addEventListener("focus",function(){searchState.putBackSearch(this);search_input.origPlaceholder=searchState.input.placeholder;search_input.placeholder="Type your search here.";loadSearch()});search_input.addEventListener("blur",function(){search_input.placeholder=searchState.input.origPlaceholder});if(search_input.value!=''){loadSearch()}var params=searchState.getQueryStringParams();if(params.search!==undefined){var search=searchState.outputElement();search.innerHTML="
"+searchState.loadingText+"
";searchState.showResults(search);loadSearch()}},};function getPageId(){if(window.location.hash){var tmp=window.location.hash.replace(/^#/,"");if(tmp.length>0){return tmp}}return null}function showSidebar(){var elems=document.getElementsByClassName("sidebar-elems")[0];if(elems){addClass(elems,"show-it")}var sidebar=document.getElementsByClassName("sidebar")[0];if(sidebar){addClass(sidebar,"mobile");var filler=document.getElementById("sidebar-filler");if(!filler){var div=document.createElement("div");div.id="sidebar-filler";sidebar.appendChild(div)}}}function hideSidebar(){var elems=document.getElementsByClassName("sidebar-elems")[0];if(elems){removeClass(elems,"show-it")}var sidebar=document.getElementsByClassName("sidebar")[0];removeClass(sidebar,"mobile");var filler=document.getElementById("sidebar-filler");if(filler){filler.remove()}document.getElementsByTagName("body")[0].style.marginTop=""}var toggleAllDocsId="toggle-all-docs";var main=document.getElementById(MAIN_ID);var savedHash="";function handleHashes(ev){var elem;var search=searchState.outputElement();if(ev!==null&&search&&!hasClass(search,"hidden")&&ev.newURL){searchState.hideResults(search);var hash=ev.newURL.slice(ev.newURL.indexOf("#")+1);if(searchState.browserSupportsHistoryApi()){history.replaceState(hash,"",getNakedUrl()+window.location.search+"#"+hash)}elem=document.getElementById(hash);if(elem){elem.scrollIntoView()}}if(savedHash!==window.location.hash){savedHash=window.location.hash;if(savedHash.length===0){return}expandSection(savedHash.slice(1))}}function onHashChange(ev){hideSidebar();handleHashes(ev)}function openParentDetails(elem){while(elem){if(elem.tagName==="DETAILS"){elem.open=true}elem=elem.parentNode}}function expandSection(id){openParentDetails(document.getElementById(id))}function getHelpElement(build){if(build){buildHelperPopup()}return document.getElementById("help")}function displayHelp(display,ev,help){if(display){help=help?help:getHelpElement(true);if(hasClass(help,"hidden")){ev.preventDefault();removeClass(help,"hidden");addClass(document.body,"blur")}}else{help=help?help:getHelpElement(false);if(help&&!hasClass(help,"hidden")){ev.preventDefault();addClass(help,"hidden");removeClass(document.body,"blur")}}}function handleEscape(ev){var help=getHelpElement(false);var search=searchState.outputElement();if(help&&!hasClass(help,"hidden")){displayHelp(false,ev,help)}else if(search&&!hasClass(search,"hidden")){searchState.clearInputTimeout();ev.preventDefault();searchState.hideResults(search)}searchState.defocus();hideThemeButtonState()}var disableShortcuts=getSettingValue("disable-shortcuts")==="true";function handleShortcut(ev){if(ev.ctrlKey||ev.altKey||ev.metaKey||disableShortcuts){return}if(document.activeElement.tagName==="INPUT"){switch(getVirtualKey(ev)){case"Escape":handleEscape(ev);break}}else{switch(getVirtualKey(ev)){case"Escape":handleEscape(ev);break;case"s":case"S":displayHelp(false,ev);ev.preventDefault();searchState.focus();break;case"+":case"-":ev.preventDefault();toggleAllDocs();break;case"?":displayHelp(true,ev);break;case"t":case"T":displayHelp(false,ev);ev.preventDefault();var themePicker=getThemePickerElement();themePicker.click();themePicker.focus();break;default:if(getThemePickerElement().parentNode.contains(ev.target)){handleThemeKeyDown(ev)}}}}function handleThemeKeyDown(ev){var active=document.activeElement;var themes=getThemesElement();switch(getVirtualKey(ev)){case"ArrowUp":ev.preventDefault();if(active.previousElementSibling&&ev.target.id!==THEME_PICKER_ELEMENT_ID){active.previousElementSibling.focus()}else{showThemeButtonState();themes.lastElementChild.focus()}break;case"ArrowDown":ev.preventDefault();if(active.nextElementSibling&&ev.target.id!==THEME_PICKER_ELEMENT_ID){active.nextElementSibling.focus()}else{showThemeButtonState();themes.firstElementChild.focus()}break;case"Enter":case"Return":case"Space":if(ev.target.id===THEME_PICKER_ELEMENT_ID&&themes.style.display==="none"){ev.preventDefault();showThemeButtonState();themes.firstElementChild.focus()}break;case"Home":ev.preventDefault();themes.firstElementChild.focus();break;case"End":ev.preventDefault();themes.lastElementChild.focus();break}}document.addEventListener("keypress",handleShortcut);document.addEventListener("keydown",handleShortcut);(function(){var x=document.getElementsByClassName("version-selector");if(x.length>0){x[0].onchange=function(){var i,match,url=document.location.href,stripped="",len=window.rootPath.match(/\.\.\//g).length+1;for(i=0;iCrates";var ul=document.createElement("ul");div.appendChild(ul);for(var i=0;i .in-band > .trait").textContent;var baseIdName="impl-"+traitName+"-";var libs=Object.getOwnPropertyNames(imp);for(var i=0,llength=libs.length;i summary:not(.hideme)"),function(el){el.addEventListener("click",function(e){if(e.target.tagName!="SUMMARY"&&e.target.tagName!="A"){e.preventDefault()}})});onEachLazy(document.getElementsByClassName("notable-traits"),function(e){e.onclick=function(){this.getElementsByClassName('notable-traits-tooltiptext')[0].classList.toggle("force-tooltip")}});var sidebar_menu=document.getElementsByClassName("sidebar-menu")[0];if(sidebar_menu){sidebar_menu.onclick=function(){var sidebar=document.getElementsByClassName("sidebar")[0];if(hasClass(sidebar,"mobile")){hideSidebar()}else{showSidebar()}}}var buildHelperPopup=function(){var popup=document.createElement("aside");addClass(popup,"hidden");popup.id="help";popup.addEventListener("click",function(ev){if(ev.target===popup){displayHelp(false,ev)}});var book_info=document.createElement("span");book_info.className="top";book_info.innerHTML="You can find more information in \
+ the rustdoc book.";var container=document.createElement("div");var shortcuts=[["?","Show this help dialog"],["S","Focus the search field"],["T","Focus the theme picker menu"],["↑","Move up in search results"],["↓","Move down in search results"],["← / →","Switch result tab (when results focused)"],["⏎","Go to active search result"],["+","Expand all sections"],["-","Collapse all sections"],].map(function(x){return"
";var infos=["Prefix searches with a type followed by a colon (e.g., fn:) to \
+ restrict the search to a given item kind.","Accepted kinds are: fn, mod, struct, \
+ enum, trait, type, macro, \
+ and const.","Search functions by type signature (e.g., vec -> usize or \
+ * -> vec)","Search multiple things at once by splitting your query with comma (e.g., \
+ str,u8 or String,struct:Vec,test)","You can look for items with an exact name by putting double quotes around \
+ your request: \"string\"","Look for items inside another one by searching for a path: vec::Vec",].map(function(x){return"
"+infos;container.appendChild(book_info);container.appendChild(div_shortcuts);container.appendChild(div_infos);var rustdoc_version=document.createElement("span");rustdoc_version.className="bottom";var rustdoc_version_code=document.createElement("code");rustdoc_version_code.innerText="rustdoc "+getVar("rustdoc-version");rustdoc_version.appendChild(rustdoc_version_code);container.appendChild(rustdoc_version);popup.appendChild(container);insertAfter(popup,document.querySelector("main"));buildHelperPopup=function(){}};onHashChange(null);window.addEventListener("hashchange",onHashChange);searchState.setup()}());(function(){var reset_button_timeout=null;window.copy_path=function(but){var parent=but.parentElement;var path=[];onEach(parent.childNodes,function(child){if(child.tagName==='A'){path.push(child.textContent)}});var el=document.createElement('textarea');el.value=path.join('::');el.setAttribute('readonly','');el.style.position='absolute';el.style.left='-9999px';document.body.appendChild(el);el.select();document.execCommand('copy');document.body.removeChild(el);but.children[0].style.display='none';var tmp;if(but.childNodes.length<2){tmp=document.createTextNode('✓');but.appendChild(tmp)}else{onEachLazy(but.childNodes,function(e){if(e.nodeType===Node.TEXT_NODE){tmp=e;return true}});tmp.textContent='✓'}if(reset_button_timeout!==null){window.clearTimeout(reset_button_timeout)}function reset_button(){tmp.textContent='';reset_button_timeout=null;but.children[0].style.display=""}reset_button_timeout=window.setTimeout(reset_button,1000)}}())
\ No newline at end of file
diff --git a/ch9-log/normalize.css b/ch9-log/normalize.css
new file mode 100644
index 00000000..469959f1
--- /dev/null
+++ b/ch9-log/normalize.css
@@ -0,0 +1,2 @@
+ /*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
+html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type="button"],[type="reset"],[type="submit"],button{-webkit-appearance:button}[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}
\ No newline at end of file
diff --git a/ch9-log/noscript.css b/ch9-log/noscript.css
new file mode 100644
index 00000000..8ad88640
--- /dev/null
+++ b/ch9-log/noscript.css
@@ -0,0 +1 @@
+ #main-content .attributes{margin-left:0 !important;}#copy-path{display:none;}.sub{display:none;}#theme-picker{display:none;}
\ No newline at end of file
diff --git a/ch9-log/os/all.html b/ch9-log/os/all.html
new file mode 100644
index 00000000..03da9e1c
--- /dev/null
+++ b/ch9-log/os/all.html
@@ -0,0 +1,5 @@
+List of all items in this crate
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/constant.CLOCK_FREQ.html b/ch9-log/os/board/constant.CLOCK_FREQ.html
new file mode 100644
index 00000000..631f6595
--- /dev/null
+++ b/ch9-log/os/board/constant.CLOCK_FREQ.html
@@ -0,0 +1,6 @@
+CLOCK_FREQ in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/constant.MMIO.html b/ch9-log/os/board/constant.MMIO.html
new file mode 100644
index 00000000..51f39f8b
--- /dev/null
+++ b/ch9-log/os/board/constant.MMIO.html
@@ -0,0 +1,6 @@
+MMIO in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/constant.VIRT_PLIC.html b/ch9-log/os/board/constant.VIRT_PLIC.html
new file mode 100644
index 00000000..152e2c1b
--- /dev/null
+++ b/ch9-log/os/board/constant.VIRT_PLIC.html
@@ -0,0 +1,6 @@
+VIRT_PLIC in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/constant.VIRT_UART.html b/ch9-log/os/board/constant.VIRT_UART.html
new file mode 100644
index 00000000..bd9e5456
--- /dev/null
+++ b/ch9-log/os/board/constant.VIRT_UART.html
@@ -0,0 +1,6 @@
+VIRT_UART in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/fn.device_init.html b/ch9-log/os/board/fn.device_init.html
new file mode 100644
index 00000000..17171971
--- /dev/null
+++ b/ch9-log/os/board/fn.device_init.html
@@ -0,0 +1,6 @@
+device_init in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/fn.irq_handler.html b/ch9-log/os/board/fn.irq_handler.html
new file mode 100644
index 00000000..2a519e46
--- /dev/null
+++ b/ch9-log/os/board/fn.irq_handler.html
@@ -0,0 +1,6 @@
+irq_handler in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/index.html b/ch9-log/os/board/index.html
new file mode 100644
index 00000000..ad242f82
--- /dev/null
+++ b/ch9-log/os/board/index.html
@@ -0,0 +1,9 @@
+os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/sidebar-items.js b/ch9-log/os/board/sidebar-items.js
new file mode 100644
index 00000000..72111b17
--- /dev/null
+++ b/ch9-log/os/board/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["CLOCK_FREQ",""],["MMIO",""],["VIRT_PLIC",""],["VIRT_UART",""]],"fn":[["device_init",""],["irq_handler",""]],"type":[["BlockDeviceImpl",""],["CharDeviceImpl",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/board/type.BlockDeviceImpl.html b/ch9-log/os/board/type.BlockDeviceImpl.html
new file mode 100644
index 00000000..59b6390d
--- /dev/null
+++ b/ch9-log/os/board/type.BlockDeviceImpl.html
@@ -0,0 +1,6 @@
+BlockDeviceImpl in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/board/type.CharDeviceImpl.html b/ch9-log/os/board/type.CharDeviceImpl.html
new file mode 100644
index 00000000..6c541364
--- /dev/null
+++ b/ch9-log/os/board/type.CharDeviceImpl.html
@@ -0,0 +1,6 @@
+CharDeviceImpl in os::board - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.KERNEL_HEAP_SIZE.html b/ch9-log/os/config/constant.KERNEL_HEAP_SIZE.html
new file mode 100644
index 00000000..37fbf1ef
--- /dev/null
+++ b/ch9-log/os/config/constant.KERNEL_HEAP_SIZE.html
@@ -0,0 +1,6 @@
+KERNEL_HEAP_SIZE in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.KERNEL_STACK_SIZE.html b/ch9-log/os/config/constant.KERNEL_STACK_SIZE.html
new file mode 100644
index 00000000..0870895a
--- /dev/null
+++ b/ch9-log/os/config/constant.KERNEL_STACK_SIZE.html
@@ -0,0 +1,6 @@
+KERNEL_STACK_SIZE in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.MEMORY_END.html b/ch9-log/os/config/constant.MEMORY_END.html
new file mode 100644
index 00000000..50a51128
--- /dev/null
+++ b/ch9-log/os/config/constant.MEMORY_END.html
@@ -0,0 +1,6 @@
+MEMORY_END in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.PAGE_SIZE.html b/ch9-log/os/config/constant.PAGE_SIZE.html
new file mode 100644
index 00000000..6a65de1f
--- /dev/null
+++ b/ch9-log/os/config/constant.PAGE_SIZE.html
@@ -0,0 +1,6 @@
+PAGE_SIZE in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.PAGE_SIZE_BITS.html b/ch9-log/os/config/constant.PAGE_SIZE_BITS.html
new file mode 100644
index 00000000..5356ad2d
--- /dev/null
+++ b/ch9-log/os/config/constant.PAGE_SIZE_BITS.html
@@ -0,0 +1,6 @@
+PAGE_SIZE_BITS in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.TRAMPOLINE.html b/ch9-log/os/config/constant.TRAMPOLINE.html
new file mode 100644
index 00000000..306d3252
--- /dev/null
+++ b/ch9-log/os/config/constant.TRAMPOLINE.html
@@ -0,0 +1,6 @@
+TRAMPOLINE in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.TRAP_CONTEXT_BASE.html b/ch9-log/os/config/constant.TRAP_CONTEXT_BASE.html
new file mode 100644
index 00000000..a7375a83
--- /dev/null
+++ b/ch9-log/os/config/constant.TRAP_CONTEXT_BASE.html
@@ -0,0 +1,6 @@
+TRAP_CONTEXT_BASE in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/constant.USER_STACK_SIZE.html b/ch9-log/os/config/constant.USER_STACK_SIZE.html
new file mode 100644
index 00000000..7b13b4aa
--- /dev/null
+++ b/ch9-log/os/config/constant.USER_STACK_SIZE.html
@@ -0,0 +1,6 @@
+USER_STACK_SIZE in os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/index.html b/ch9-log/os/config/index.html
new file mode 100644
index 00000000..d16899fd
--- /dev/null
+++ b/ch9-log/os/config/index.html
@@ -0,0 +1,8 @@
+os::config - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/config/sidebar-items.js b/ch9-log/os/config/sidebar-items.js
new file mode 100644
index 00000000..82162e6c
--- /dev/null
+++ b/ch9-log/os/config/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["KERNEL_HEAP_SIZE",""],["KERNEL_STACK_SIZE",""],["MEMORY_END",""],["PAGE_SIZE",""],["PAGE_SIZE_BITS",""],["TRAMPOLINE",""],["TRAP_CONTEXT_BASE",""],["USER_STACK_SIZE",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/console/fn.kprint.html b/ch9-log/os/console/fn.kprint.html
new file mode 100644
index 00000000..eb795cc0
--- /dev/null
+++ b/ch9-log/os/console/fn.kprint.html
@@ -0,0 +1,6 @@
+kprint in os::console - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/console/fn.print.html b/ch9-log/os/console/fn.print.html
new file mode 100644
index 00000000..11eb46a6
--- /dev/null
+++ b/ch9-log/os/console/fn.print.html
@@ -0,0 +1,6 @@
+print in os::console - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/console/index.html b/ch9-log/os/console/index.html
new file mode 100644
index 00000000..132af462
--- /dev/null
+++ b/ch9-log/os/console/index.html
@@ -0,0 +1,8 @@
+os::console - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/console/sidebar-items.js b/ch9-log/os/console/sidebar-items.js
new file mode 100644
index 00000000..243e9aa7
--- /dev/null
+++ b/ch9-log/os/console/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["kprint",""],["print",""]],"struct":[["Kstdout",""],["Stdout",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/console/struct.Kstdout.html b/ch9-log/os/console/struct.Kstdout.html
new file mode 100644
index 00000000..585add39
--- /dev/null
+++ b/ch9-log/os/console/struct.Kstdout.html
@@ -0,0 +1,19 @@
+Kstdout in os::console - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/console/struct.Stdout.html b/ch9-log/os/console/struct.Stdout.html
new file mode 100644
index 00000000..aacab1d0
--- /dev/null
+++ b/ch9-log/os/console/struct.Stdout.html
@@ -0,0 +1,19 @@
+Stdout in os::console - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/fn.block_device_test.html b/ch9-log/os/drivers/block/fn.block_device_test.html
new file mode 100644
index 00000000..d5273e9f
--- /dev/null
+++ b/ch9-log/os/drivers/block/fn.block_device_test.html
@@ -0,0 +1,6 @@
+block_device_test in os::drivers::block - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/index.html b/ch9-log/os/drivers/block/index.html
new file mode 100644
index 00000000..28752346
--- /dev/null
+++ b/ch9-log/os/drivers/block/index.html
@@ -0,0 +1,10 @@
+os::drivers::block - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/sidebar-items.js b/ch9-log/os/drivers/block/sidebar-items.js
new file mode 100644
index 00000000..fc24d518
--- /dev/null
+++ b/ch9-log/os/drivers/block/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["block_device_test",""]],"mod":[["virtio_blk",""]],"struct":[["BLOCK_DEVICE",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/struct.BLOCK_DEVICE.html b/ch9-log/os/drivers/block/struct.BLOCK_DEVICE.html
new file mode 100644
index 00000000..14fce12c
--- /dev/null
+++ b/ch9-log/os/drivers/block/struct.BLOCK_DEVICE.html
@@ -0,0 +1,19 @@
+BLOCK_DEVICE in os::drivers::block - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/constant.VIRTIO0.html b/ch9-log/os/drivers/block/virtio_blk/constant.VIRTIO0.html
new file mode 100644
index 00000000..6247ce49
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/constant.VIRTIO0.html
@@ -0,0 +1,6 @@
+VIRTIO0 in os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/fn.virtio_dma_alloc.html b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_dma_alloc.html
new file mode 100644
index 00000000..4ad011d5
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_dma_alloc.html
@@ -0,0 +1,7 @@
+virtio_dma_alloc in os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/fn.virtio_dma_dealloc.html b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_dma_dealloc.html
new file mode 100644
index 00000000..ce86101e
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_dma_dealloc.html
@@ -0,0 +1,7 @@
+virtio_dma_dealloc in os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/fn.virtio_phys_to_virt.html b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_phys_to_virt.html
new file mode 100644
index 00000000..16a6b413
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_phys_to_virt.html
@@ -0,0 +1,7 @@
+virtio_phys_to_virt in os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/fn.virtio_virt_to_phys.html b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_virt_to_phys.html
new file mode 100644
index 00000000..c29876d6
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/fn.virtio_virt_to_phys.html
@@ -0,0 +1,7 @@
+virtio_virt_to_phys in os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/index.html b/ch9-log/os/drivers/block/virtio_blk/index.html
new file mode 100644
index 00000000..9457b6c2
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/index.html
@@ -0,0 +1,9 @@
+os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/sidebar-items.js b/ch9-log/os/drivers/block/virtio_blk/sidebar-items.js
new file mode 100644
index 00000000..06229704
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["VIRTIO0",""]],"fn":[["virtio_dma_alloc",""],["virtio_dma_dealloc",""],["virtio_phys_to_virt",""],["virtio_virt_to_phys",""]],"struct":[["QUEUE_FRAMES",""],["VirtIOBlock",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/struct.QUEUE_FRAMES.html b/ch9-log/os/drivers/block/virtio_blk/struct.QUEUE_FRAMES.html
new file mode 100644
index 00000000..b9fe397d
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/struct.QUEUE_FRAMES.html
@@ -0,0 +1,20 @@
+QUEUE_FRAMES in os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/block/virtio_blk/struct.VirtIOBlock.html b/ch9-log/os/drivers/block/virtio_blk/struct.VirtIOBlock.html
new file mode 100644
index 00000000..895bcdf3
--- /dev/null
+++ b/ch9-log/os/drivers/block/virtio_blk/struct.VirtIOBlock.html
@@ -0,0 +1,18 @@
+VirtIOBlock in os::drivers::block::virtio_blk - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/index.html b/ch9-log/os/drivers/chardev/index.html
new file mode 100644
index 00000000..2ca36478
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/index.html
@@ -0,0 +1,10 @@
+os::drivers::chardev - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/index.html b/ch9-log/os/drivers/chardev/ns16550a/index.html
new file mode 100644
index 00000000..b25fb58d
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/index.html
@@ -0,0 +1,10 @@
+os::drivers::chardev::ns16550a - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/sidebar-items.js b/ch9-log/os/drivers/chardev/ns16550a/sidebar-items.js
new file mode 100644
index 00000000..ba696843
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["IER","InterruptEnableRegister"],["LSR","LineStatusRegister"],["MCR","Model Control Register"],["NS16550a",""],["NS16550aInner",""],["NS16550aRaw",""],["ReadWithoutDLAB",""],["WriteWithoutDLAB",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.IER.html b/ch9-log/os/drivers/chardev/ns16550a/struct.IER.html
new file mode 100644
index 00000000..a983e4d0
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.IER.html
@@ -0,0 +1,120 @@
+IER in os::drivers::chardev::ns16550a - Rust
+
Returns the union of between the flags in self and other.
+
Specifically, the returned set contains all flags which are
+present in eitherselforother, including any which are
+present in both (see Self::symmetric_difference if that
+is undesirable).
+
This is equivalent to using the | operator (e.g.
+ops::BitOr), as in flags | other.
Specifically, the returned set contains the flags present which
+are present in self or other, but that are not present in
+both. Equivalently, it contains the flags present in exactly
+one of the sets self and other.
+
This is equivalent to using the ^ operator (e.g.
+ops::BitXor), as in flags ^ other.
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.LSR.html b/ch9-log/os/drivers/chardev/ns16550a/struct.LSR.html
new file mode 100644
index 00000000..814c861a
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.LSR.html
@@ -0,0 +1,120 @@
+LSR in os::drivers::chardev::ns16550a - Rust
+
Returns the union of between the flags in self and other.
+
Specifically, the returned set contains all flags which are
+present in eitherselforother, including any which are
+present in both (see Self::symmetric_difference if that
+is undesirable).
+
This is equivalent to using the | operator (e.g.
+ops::BitOr), as in flags | other.
Specifically, the returned set contains the flags present which
+are present in self or other, but that are not present in
+both. Equivalently, it contains the flags present in exactly
+one of the sets self and other.
+
This is equivalent to using the ^ operator (e.g.
+ops::BitXor), as in flags ^ other.
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.MCR.html b/ch9-log/os/drivers/chardev/ns16550a/struct.MCR.html
new file mode 100644
index 00000000..752a2a19
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.MCR.html
@@ -0,0 +1,120 @@
+MCR in os::drivers::chardev::ns16550a - Rust
+
Returns the union of between the flags in self and other.
+
Specifically, the returned set contains all flags which are
+present in eitherselforother, including any which are
+present in both (see Self::symmetric_difference if that
+is undesirable).
+
This is equivalent to using the | operator (e.g.
+ops::BitOr), as in flags | other.
Specifically, the returned set contains the flags present which
+are present in self or other, but that are not present in
+both. Equivalently, it contains the flags present in exactly
+one of the sets self and other.
+
This is equivalent to using the ^ operator (e.g.
+ops::BitXor), as in flags ^ other.
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550a.html b/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550a.html
new file mode 100644
index 00000000..b5297a0a
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550a.html
@@ -0,0 +1,18 @@
+NS16550a in os::drivers::chardev::ns16550a - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550aInner.html b/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550aInner.html
new file mode 100644
index 00000000..6ee2f418
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550aInner.html
@@ -0,0 +1,18 @@
+NS16550aInner in os::drivers::chardev::ns16550a - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550aRaw.html b/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550aRaw.html
new file mode 100644
index 00000000..4c3ad1d7
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.NS16550aRaw.html
@@ -0,0 +1,17 @@
+NS16550aRaw in os::drivers::chardev::ns16550a - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.ReadWithoutDLAB.html b/ch9-log/os/drivers/chardev/ns16550a/struct.ReadWithoutDLAB.html
new file mode 100644
index 00000000..a6c55c34
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.ReadWithoutDLAB.html
@@ -0,0 +1,32 @@
+ReadWithoutDLAB in os::drivers::chardev::ns16550a - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/ns16550a/struct.WriteWithoutDLAB.html b/ch9-log/os/drivers/chardev/ns16550a/struct.WriteWithoutDLAB.html
new file mode 100644
index 00000000..339bea30
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/ns16550a/struct.WriteWithoutDLAB.html
@@ -0,0 +1,30 @@
+WriteWithoutDLAB in os::drivers::chardev::ns16550a - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/sidebar-items.js b/ch9-log/os/drivers/chardev/sidebar-items.js
new file mode 100644
index 00000000..8b19d02e
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"mod":[["ns16550a",""]],"struct":[["UART",""]],"trait":[["CharDevice",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/struct.UART.html b/ch9-log/os/drivers/chardev/struct.UART.html
new file mode 100644
index 00000000..1bb75419
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/struct.UART.html
@@ -0,0 +1,19 @@
+UART in os::drivers::chardev - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/chardev/trait.CharDevice.html b/ch9-log/os/drivers/chardev/trait.CharDevice.html
new file mode 100644
index 00000000..bb9f6150
--- /dev/null
+++ b/ch9-log/os/drivers/chardev/trait.CharDevice.html
@@ -0,0 +1,10 @@
+CharDevice in os::drivers::chardev - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/index.html b/ch9-log/os/drivers/index.html
new file mode 100644
index 00000000..23b95870
--- /dev/null
+++ b/ch9-log/os/drivers/index.html
@@ -0,0 +1,8 @@
+os::drivers - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/plic/enum.IntrTargetPriority.html b/ch9-log/os/drivers/plic/enum.IntrTargetPriority.html
new file mode 100644
index 00000000..019f01b6
--- /dev/null
+++ b/ch9-log/os/drivers/plic/enum.IntrTargetPriority.html
@@ -0,0 +1,23 @@
+IntrTargetPriority in os::drivers::plic - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/plic/index.html b/ch9-log/os/drivers/plic/index.html
new file mode 100644
index 00000000..4a9481fa
--- /dev/null
+++ b/ch9-log/os/drivers/plic/index.html
@@ -0,0 +1,8 @@
+os::drivers::plic - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/plic/sidebar-items.js b/ch9-log/os/drivers/plic/sidebar-items.js
new file mode 100644
index 00000000..8d3772c7
--- /dev/null
+++ b/ch9-log/os/drivers/plic/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"enum":[["IntrTargetPriority",""]],"struct":[["PLIC",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/drivers/plic/struct.PLIC.html b/ch9-log/os/drivers/plic/struct.PLIC.html
new file mode 100644
index 00000000..55a61609
--- /dev/null
+++ b/ch9-log/os/drivers/plic/struct.PLIC.html
@@ -0,0 +1,17 @@
+PLIC in os::drivers::plic - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/drivers/sidebar-items.js b/ch9-log/os/drivers/sidebar-items.js
new file mode 100644
index 00000000..f8f3f7d7
--- /dev/null
+++ b/ch9-log/os/drivers/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"mod":[["block",""],["chardev",""],["plic",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/fn.clear_bss.html b/ch9-log/os/fn.clear_bss.html
new file mode 100644
index 00000000..b5e1709b
--- /dev/null
+++ b/ch9-log/os/fn.clear_bss.html
@@ -0,0 +1,6 @@
+clear_bss in os - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fn.rust_main.html b/ch9-log/os/fn.rust_main.html
new file mode 100644
index 00000000..011f0cf9
--- /dev/null
+++ b/ch9-log/os/fn.rust_main.html
@@ -0,0 +1,7 @@
+rust_main in os - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/index.html b/ch9-log/os/fs/index.html
new file mode 100644
index 00000000..8fb7e062
--- /dev/null
+++ b/ch9-log/os/fs/index.html
@@ -0,0 +1,9 @@
+os::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/fn.list_apps.html b/ch9-log/os/fs/inode/fn.list_apps.html
new file mode 100644
index 00000000..a461c96f
--- /dev/null
+++ b/ch9-log/os/fs/inode/fn.list_apps.html
@@ -0,0 +1,6 @@
+list_apps in os::fs::inode - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/fn.open_file.html b/ch9-log/os/fs/inode/fn.open_file.html
new file mode 100644
index 00000000..14adceba
--- /dev/null
+++ b/ch9-log/os/fs/inode/fn.open_file.html
@@ -0,0 +1,6 @@
+open_file in os::fs::inode - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/index.html b/ch9-log/os/fs/inode/index.html
new file mode 100644
index 00000000..e3125573
--- /dev/null
+++ b/ch9-log/os/fs/inode/index.html
@@ -0,0 +1,8 @@
+os::fs::inode - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/sidebar-items.js b/ch9-log/os/fs/inode/sidebar-items.js
new file mode 100644
index 00000000..6b53705a
--- /dev/null
+++ b/ch9-log/os/fs/inode/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["list_apps",""],["open_file",""]],"struct":[["OSInode",""],["OSInodeInner",""],["OpenFlags",""],["ROOT_INODE",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/struct.OSInode.html b/ch9-log/os/fs/inode/struct.OSInode.html
new file mode 100644
index 00000000..096d459b
--- /dev/null
+++ b/ch9-log/os/fs/inode/struct.OSInode.html
@@ -0,0 +1,19 @@
+OSInode in os::fs::inode - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/struct.OSInodeInner.html b/ch9-log/os/fs/inode/struct.OSInodeInner.html
new file mode 100644
index 00000000..1d39bc94
--- /dev/null
+++ b/ch9-log/os/fs/inode/struct.OSInodeInner.html
@@ -0,0 +1,18 @@
+OSInodeInner in os::fs::inode - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/struct.OpenFlags.html b/ch9-log/os/fs/inode/struct.OpenFlags.html
new file mode 100644
index 00000000..44a23a72
--- /dev/null
+++ b/ch9-log/os/fs/inode/struct.OpenFlags.html
@@ -0,0 +1,121 @@
+OpenFlags in os::fs::inode - Rust
+
Returns the union of between the flags in self and other.
+
Specifically, the returned set contains all flags which are
+present in eitherselforother, including any which are
+present in both (see Self::symmetric_difference if that
+is undesirable).
+
This is equivalent to using the | operator (e.g.
+ops::BitOr), as in flags | other.
Specifically, the returned set contains the flags present which
+are present in self or other, but that are not present in
+both. Equivalently, it contains the flags present in exactly
+one of the sets self and other.
+
This is equivalent to using the ^ operator (e.g.
+ops::BitXor), as in flags ^ other.
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/inode/struct.ROOT_INODE.html b/ch9-log/os/fs/inode/struct.ROOT_INODE.html
new file mode 100644
index 00000000..8569472f
--- /dev/null
+++ b/ch9-log/os/fs/inode/struct.ROOT_INODE.html
@@ -0,0 +1,19 @@
+ROOT_INODE in os::fs::inode - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/pipe/constant.RING_BUFFER_SIZE.html b/ch9-log/os/fs/pipe/constant.RING_BUFFER_SIZE.html
new file mode 100644
index 00000000..9300f28c
--- /dev/null
+++ b/ch9-log/os/fs/pipe/constant.RING_BUFFER_SIZE.html
@@ -0,0 +1,6 @@
+RING_BUFFER_SIZE in os::fs::pipe - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/pipe/enum.RingBufferStatus.html b/ch9-log/os/fs/pipe/enum.RingBufferStatus.html
new file mode 100644
index 00000000..93b37d92
--- /dev/null
+++ b/ch9-log/os/fs/pipe/enum.RingBufferStatus.html
@@ -0,0 +1,27 @@
+RingBufferStatus in os::fs::pipe - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/pipe/fn.make_pipe.html b/ch9-log/os/fs/pipe/fn.make_pipe.html
new file mode 100644
index 00000000..b74a8220
--- /dev/null
+++ b/ch9-log/os/fs/pipe/fn.make_pipe.html
@@ -0,0 +1,7 @@
+make_pipe in os::fs::pipe - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/pipe/index.html b/ch9-log/os/fs/pipe/index.html
new file mode 100644
index 00000000..0bd647c3
--- /dev/null
+++ b/ch9-log/os/fs/pipe/index.html
@@ -0,0 +1,11 @@
+os::fs::pipe - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/pipe/sidebar-items.js b/ch9-log/os/fs/pipe/sidebar-items.js
new file mode 100644
index 00000000..9c0d7ebc
--- /dev/null
+++ b/ch9-log/os/fs/pipe/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["RING_BUFFER_SIZE",""]],"enum":[["RingBufferStatus",""]],"fn":[["make_pipe","Return (read_end, write_end)"]],"struct":[["Pipe",""],["PipeRingBuffer",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/fs/pipe/struct.Pipe.html b/ch9-log/os/fs/pipe/struct.Pipe.html
new file mode 100644
index 00000000..cb98bd20
--- /dev/null
+++ b/ch9-log/os/fs/pipe/struct.Pipe.html
@@ -0,0 +1,19 @@
+Pipe in os::fs::pipe - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/pipe/struct.PipeRingBuffer.html b/ch9-log/os/fs/pipe/struct.PipeRingBuffer.html
new file mode 100644
index 00000000..2aa49c2f
--- /dev/null
+++ b/ch9-log/os/fs/pipe/struct.PipeRingBuffer.html
@@ -0,0 +1,21 @@
+PipeRingBuffer in os::fs::pipe - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/sidebar-items.js b/ch9-log/os/fs/sidebar-items.js
new file mode 100644
index 00000000..835c949e
--- /dev/null
+++ b/ch9-log/os/fs/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"mod":[["inode",""],["pipe",""],["stdio",""]],"trait":[["File",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/fs/stdio/index.html b/ch9-log/os/fs/stdio/index.html
new file mode 100644
index 00000000..56bfdc0e
--- /dev/null
+++ b/ch9-log/os/fs/stdio/index.html
@@ -0,0 +1,7 @@
+os::fs::stdio - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/stdio/sidebar-items.js b/ch9-log/os/fs/stdio/sidebar-items.js
new file mode 100644
index 00000000..9dbb449f
--- /dev/null
+++ b/ch9-log/os/fs/stdio/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["Stdin",""],["Stdout",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/fs/stdio/struct.Stdin.html b/ch9-log/os/fs/stdio/struct.Stdin.html
new file mode 100644
index 00000000..105fbb1b
--- /dev/null
+++ b/ch9-log/os/fs/stdio/struct.Stdin.html
@@ -0,0 +1,15 @@
+Stdin in os::fs::stdio - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/stdio/struct.Stdout.html b/ch9-log/os/fs/stdio/struct.Stdout.html
new file mode 100644
index 00000000..7c0e10b8
--- /dev/null
+++ b/ch9-log/os/fs/stdio/struct.Stdout.html
@@ -0,0 +1,15 @@
+Stdout in os::fs::stdio - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/fs/trait.File.html b/ch9-log/os/fs/trait.File.html
new file mode 100644
index 00000000..1fa9b8bb
--- /dev/null
+++ b/ch9-log/os/fs/trait.File.html
@@ -0,0 +1,11 @@
+File in os::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/index.html b/ch9-log/os/index.html
new file mode 100644
index 00000000..5ceb9828
--- /dev/null
+++ b/ch9-log/os/index.html
@@ -0,0 +1,10 @@
+os - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/lang_items/fn.backtrace.html b/ch9-log/os/lang_items/fn.backtrace.html
new file mode 100644
index 00000000..39864fc1
--- /dev/null
+++ b/ch9-log/os/lang_items/fn.backtrace.html
@@ -0,0 +1,6 @@
+backtrace in os::lang_items - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/lang_items/fn.panic.html b/ch9-log/os/lang_items/fn.panic.html
new file mode 100644
index 00000000..70a8c97f
--- /dev/null
+++ b/ch9-log/os/lang_items/fn.panic.html
@@ -0,0 +1,6 @@
+panic in os::lang_items - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/lang_items/index.html b/ch9-log/os/lang_items/index.html
new file mode 100644
index 00000000..47387d15
--- /dev/null
+++ b/ch9-log/os/lang_items/index.html
@@ -0,0 +1,7 @@
+os::lang_items - Rust
+
+
+
+
\ No newline at end of file
diff --git a/ch9-log/os/macro.kprint.html b/ch9-log/os/macro.kprint.html
new file mode 100644
index 00000000..080fb161
--- /dev/null
+++ b/ch9-log/os/macro.kprint.html
@@ -0,0 +1,9 @@
+kprint in os - Rust
+
+
+
+
\ No newline at end of file
diff --git a/ch9-log/os/macro.kprintln.html b/ch9-log/os/macro.kprintln.html
new file mode 100644
index 00000000..9631070a
--- /dev/null
+++ b/ch9-log/os/macro.kprintln.html
@@ -0,0 +1,9 @@
+kprintln in os - Rust
+
+
+
+
\ No newline at end of file
diff --git a/ch9-log/os/macro.print.html b/ch9-log/os/macro.print.html
new file mode 100644
index 00000000..17d519f7
--- /dev/null
+++ b/ch9-log/os/macro.print.html
@@ -0,0 +1,9 @@
+print in os - Rust
+
+
+
+
\ No newline at end of file
diff --git a/ch9-log/os/macro.println.html b/ch9-log/os/macro.println.html
new file mode 100644
index 00000000..6f58012d
--- /dev/null
+++ b/ch9-log/os/macro.println.html
@@ -0,0 +1,9 @@
+println in os - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/constant.PA_WIDTH_SV39.html b/ch9-log/os/mm/address/constant.PA_WIDTH_SV39.html
new file mode 100644
index 00000000..d7ded0db
--- /dev/null
+++ b/ch9-log/os/mm/address/constant.PA_WIDTH_SV39.html
@@ -0,0 +1,6 @@
+PA_WIDTH_SV39 in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/constant.PPN_WIDTH_SV39.html b/ch9-log/os/mm/address/constant.PPN_WIDTH_SV39.html
new file mode 100644
index 00000000..07bf60dc
--- /dev/null
+++ b/ch9-log/os/mm/address/constant.PPN_WIDTH_SV39.html
@@ -0,0 +1,6 @@
+PPN_WIDTH_SV39 in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/constant.VA_WIDTH_SV39.html b/ch9-log/os/mm/address/constant.VA_WIDTH_SV39.html
new file mode 100644
index 00000000..1f0e06d1
--- /dev/null
+++ b/ch9-log/os/mm/address/constant.VA_WIDTH_SV39.html
@@ -0,0 +1,6 @@
+VA_WIDTH_SV39 in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/constant.VPN_WIDTH_SV39.html b/ch9-log/os/mm/address/constant.VPN_WIDTH_SV39.html
new file mode 100644
index 00000000..124aa845
--- /dev/null
+++ b/ch9-log/os/mm/address/constant.VPN_WIDTH_SV39.html
@@ -0,0 +1,6 @@
+VPN_WIDTH_SV39 in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/index.html b/ch9-log/os/mm/address/index.html
new file mode 100644
index 00000000..cf1a589b
--- /dev/null
+++ b/ch9-log/os/mm/address/index.html
@@ -0,0 +1,11 @@
+os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/sidebar-items.js b/ch9-log/os/mm/address/sidebar-items.js
new file mode 100644
index 00000000..354c1cc1
--- /dev/null
+++ b/ch9-log/os/mm/address/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["PA_WIDTH_SV39",""],["PPN_WIDTH_SV39",""],["VA_WIDTH_SV39",""],["VPN_WIDTH_SV39",""]],"struct":[["PhysAddr","Definitions"],["PhysPageNum",""],["SimpleRange",""],["SimpleRangeIterator",""],["VirtAddr",""],["VirtPageNum",""]],"trait":[["StepByOne",""]],"type":[["VPNRange",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/struct.PhysAddr.html b/ch9-log/os/mm/address/struct.PhysAddr.html
new file mode 100644
index 00000000..dd88701f
--- /dev/null
+++ b/ch9-log/os/mm/address/struct.PhysAddr.html
@@ -0,0 +1,43 @@
+PhysAddr in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/struct.PhysPageNum.html b/ch9-log/os/mm/address/struct.PhysPageNum.html
new file mode 100644
index 00000000..b8b8d1ee
--- /dev/null
+++ b/ch9-log/os/mm/address/struct.PhysPageNum.html
@@ -0,0 +1,39 @@
+PhysPageNum in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/struct.SimpleRange.html b/ch9-log/os/mm/address/struct.SimpleRange.html
new file mode 100644
index 00000000..163d0da6
--- /dev/null
+++ b/ch9-log/os/mm/address/struct.SimpleRange.html
@@ -0,0 +1,26 @@
+SimpleRange in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/struct.SimpleRangeIterator.html b/ch9-log/os/mm/address/struct.SimpleRangeIterator.html
new file mode 100644
index 00000000..988ccfa1
--- /dev/null
+++ b/ch9-log/os/mm/address/struct.SimpleRangeIterator.html
@@ -0,0 +1,130 @@
+SimpleRangeIterator in os::mm::address - Rust
+
Creates an iterator which can use the peek and peek_mut methods
+to look at the next element of the iterator without consuming it. See
+their documentation for more information. Read more
🔬 This is a nightly-only experimental API. (iter_partition_in_place)
Reorders the elements of this iterator in-place according to the given predicate,
+such that all those that return true precede all those that return false.
+Returns the number of true elements found. Read more
🔬 This is a nightly-only experimental API. (iter_is_partitioned)
Checks if the elements of this iterator are partitioned according to the given predicate,
+such that all those that return true precede all those that return false. Read more
🔬 This is a nightly-only experimental API. (iterator_try_reduce)
Reduces the elements to a single one by repeatedly applying a reducing operation. If the
+closure returns a failure, the failure is propagated back to the caller immediately. Read more
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/struct.VirtAddr.html b/ch9-log/os/mm/address/struct.VirtAddr.html
new file mode 100644
index 00000000..fff94adf
--- /dev/null
+++ b/ch9-log/os/mm/address/struct.VirtAddr.html
@@ -0,0 +1,40 @@
+VirtAddr in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/struct.VirtPageNum.html b/ch9-log/os/mm/address/struct.VirtPageNum.html
new file mode 100644
index 00000000..7f222ee9
--- /dev/null
+++ b/ch9-log/os/mm/address/struct.VirtPageNum.html
@@ -0,0 +1,39 @@
+VirtPageNum in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/trait.StepByOne.html b/ch9-log/os/mm/address/trait.StepByOne.html
new file mode 100644
index 00000000..63b7ba1c
--- /dev/null
+++ b/ch9-log/os/mm/address/trait.StepByOne.html
@@ -0,0 +1,8 @@
+StepByOne in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/address/type.VPNRange.html b/ch9-log/os/mm/address/type.VPNRange.html
new file mode 100644
index 00000000..c1fbb02e
--- /dev/null
+++ b/ch9-log/os/mm/address/type.VPNRange.html
@@ -0,0 +1,6 @@
+VPNRange in os::mm::address - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/fn.init.html b/ch9-log/os/mm/fn.init.html
new file mode 100644
index 00000000..21af91c8
--- /dev/null
+++ b/ch9-log/os/mm/fn.init.html
@@ -0,0 +1,6 @@
+init in os::mm - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/fn.frame_alloc.html b/ch9-log/os/mm/frame_allocator/fn.frame_alloc.html
new file mode 100644
index 00000000..d84c92e4
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/fn.frame_alloc.html
@@ -0,0 +1,6 @@
+frame_alloc in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/fn.frame_allocator_test.html b/ch9-log/os/mm/frame_allocator/fn.frame_allocator_test.html
new file mode 100644
index 00000000..77f0086a
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/fn.frame_allocator_test.html
@@ -0,0 +1,6 @@
+frame_allocator_test in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/fn.frame_dealloc.html b/ch9-log/os/mm/frame_allocator/fn.frame_dealloc.html
new file mode 100644
index 00000000..c80bcc8c
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/fn.frame_dealloc.html
@@ -0,0 +1,6 @@
+frame_dealloc in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/fn.init_frame_allocator.html b/ch9-log/os/mm/frame_allocator/fn.init_frame_allocator.html
new file mode 100644
index 00000000..b72e6ac9
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/fn.init_frame_allocator.html
@@ -0,0 +1,6 @@
+init_frame_allocator in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/index.html b/ch9-log/os/mm/frame_allocator/index.html
new file mode 100644
index 00000000..dd1d4e85
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/index.html
@@ -0,0 +1,10 @@
+os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/sidebar-items.js b/ch9-log/os/mm/frame_allocator/sidebar-items.js
new file mode 100644
index 00000000..d63ca944
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["frame_alloc",""],["frame_allocator_test",""],["frame_dealloc",""],["init_frame_allocator",""]],"struct":[["FRAME_ALLOCATOR",""],["FrameTracker",""],["StackFrameAllocator",""]],"trait":[["FrameAllocator",""]],"type":[["FrameAllocatorImpl",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/struct.FRAME_ALLOCATOR.html b/ch9-log/os/mm/frame_allocator/struct.FRAME_ALLOCATOR.html
new file mode 100644
index 00000000..a34a0b89
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/struct.FRAME_ALLOCATOR.html
@@ -0,0 +1,20 @@
+FRAME_ALLOCATOR in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/struct.FrameTracker.html b/ch9-log/os/mm/frame_allocator/struct.FrameTracker.html
new file mode 100644
index 00000000..dfc45fe7
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/struct.FrameTracker.html
@@ -0,0 +1,19 @@
+FrameTracker in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/struct.StackFrameAllocator.html b/ch9-log/os/mm/frame_allocator/struct.StackFrameAllocator.html
new file mode 100644
index 00000000..5a401b3a
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/struct.StackFrameAllocator.html
@@ -0,0 +1,19 @@
+StackFrameAllocator in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/trait.FrameAllocator.html b/ch9-log/os/mm/frame_allocator/trait.FrameAllocator.html
new file mode 100644
index 00000000..00839253
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/trait.FrameAllocator.html
@@ -0,0 +1,10 @@
+FrameAllocator in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/frame_allocator/type.FrameAllocatorImpl.html b/ch9-log/os/mm/frame_allocator/type.FrameAllocatorImpl.html
new file mode 100644
index 00000000..d9a85d3e
--- /dev/null
+++ b/ch9-log/os/mm/frame_allocator/type.FrameAllocatorImpl.html
@@ -0,0 +1,6 @@
+FrameAllocatorImpl in os::mm::frame_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/heap_allocator/fn.handle_alloc_error.html b/ch9-log/os/mm/heap_allocator/fn.handle_alloc_error.html
new file mode 100644
index 00000000..f85900a1
--- /dev/null
+++ b/ch9-log/os/mm/heap_allocator/fn.handle_alloc_error.html
@@ -0,0 +1,6 @@
+handle_alloc_error in os::mm::heap_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/heap_allocator/fn.heap_test.html b/ch9-log/os/mm/heap_allocator/fn.heap_test.html
new file mode 100644
index 00000000..91ee139b
--- /dev/null
+++ b/ch9-log/os/mm/heap_allocator/fn.heap_test.html
@@ -0,0 +1,6 @@
+heap_test in os::mm::heap_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/heap_allocator/fn.init_heap.html b/ch9-log/os/mm/heap_allocator/fn.init_heap.html
new file mode 100644
index 00000000..aa158869
--- /dev/null
+++ b/ch9-log/os/mm/heap_allocator/fn.init_heap.html
@@ -0,0 +1,6 @@
+init_heap in os::mm::heap_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/heap_allocator/index.html b/ch9-log/os/mm/heap_allocator/index.html
new file mode 100644
index 00000000..dd360e18
--- /dev/null
+++ b/ch9-log/os/mm/heap_allocator/index.html
@@ -0,0 +1,8 @@
+os::mm::heap_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/heap_allocator/sidebar-items.js b/ch9-log/os/mm/heap_allocator/sidebar-items.js
new file mode 100644
index 00000000..d1f423dc
--- /dev/null
+++ b/ch9-log/os/mm/heap_allocator/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["handle_alloc_error",""],["heap_test",""],["init_heap",""]],"static":[["HEAP_ALLOCATOR",""],["HEAP_SPACE",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/mm/heap_allocator/static.HEAP_ALLOCATOR.html b/ch9-log/os/mm/heap_allocator/static.HEAP_ALLOCATOR.html
new file mode 100644
index 00000000..80e8d72a
--- /dev/null
+++ b/ch9-log/os/mm/heap_allocator/static.HEAP_ALLOCATOR.html
@@ -0,0 +1,6 @@
+HEAP_ALLOCATOR in os::mm::heap_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/heap_allocator/static.HEAP_SPACE.html b/ch9-log/os/mm/heap_allocator/static.HEAP_SPACE.html
new file mode 100644
index 00000000..16025214
--- /dev/null
+++ b/ch9-log/os/mm/heap_allocator/static.HEAP_SPACE.html
@@ -0,0 +1,6 @@
+HEAP_SPACE in os::mm::heap_allocator - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/index.html b/ch9-log/os/mm/index.html
new file mode 100644
index 00000000..c1d17fb7
--- /dev/null
+++ b/ch9-log/os/mm/index.html
@@ -0,0 +1,9 @@
+os::mm - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/enum.MapType.html b/ch9-log/os/mm/memory_set/enum.MapType.html
new file mode 100644
index 00000000..05f723ed
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/enum.MapType.html
@@ -0,0 +1,27 @@
+MapType in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.ebss.html b/ch9-log/os/mm/memory_set/fn.ebss.html
new file mode 100644
index 00000000..3bd8584f
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.ebss.html
@@ -0,0 +1,6 @@
+ebss in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.edata.html b/ch9-log/os/mm/memory_set/fn.edata.html
new file mode 100644
index 00000000..b9f4cc53
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.edata.html
@@ -0,0 +1,6 @@
+edata in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.ekernel.html b/ch9-log/os/mm/memory_set/fn.ekernel.html
new file mode 100644
index 00000000..a68105d6
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.ekernel.html
@@ -0,0 +1,6 @@
+ekernel in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.erodata.html b/ch9-log/os/mm/memory_set/fn.erodata.html
new file mode 100644
index 00000000..7a42fc8f
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.erodata.html
@@ -0,0 +1,6 @@
+erodata in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.etext.html b/ch9-log/os/mm/memory_set/fn.etext.html
new file mode 100644
index 00000000..dfa43cfd
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.etext.html
@@ -0,0 +1,6 @@
+etext in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.kernel_token.html b/ch9-log/os/mm/memory_set/fn.kernel_token.html
new file mode 100644
index 00000000..91f879db
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.kernel_token.html
@@ -0,0 +1,6 @@
+kernel_token in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.remap_test.html b/ch9-log/os/mm/memory_set/fn.remap_test.html
new file mode 100644
index 00000000..689a0135
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.remap_test.html
@@ -0,0 +1,6 @@
+remap_test in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.sbss_with_stack.html b/ch9-log/os/mm/memory_set/fn.sbss_with_stack.html
new file mode 100644
index 00000000..ecbf7b8a
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.sbss_with_stack.html
@@ -0,0 +1,6 @@
+sbss_with_stack in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.sdata.html b/ch9-log/os/mm/memory_set/fn.sdata.html
new file mode 100644
index 00000000..21790d43
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.sdata.html
@@ -0,0 +1,6 @@
+sdata in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.srodata.html b/ch9-log/os/mm/memory_set/fn.srodata.html
new file mode 100644
index 00000000..12becf5b
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.srodata.html
@@ -0,0 +1,6 @@
+srodata in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.stext.html b/ch9-log/os/mm/memory_set/fn.stext.html
new file mode 100644
index 00000000..f462b9fc
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.stext.html
@@ -0,0 +1,6 @@
+stext in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/fn.strampoline.html b/ch9-log/os/mm/memory_set/fn.strampoline.html
new file mode 100644
index 00000000..6dd5b9da
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/fn.strampoline.html
@@ -0,0 +1,6 @@
+strampoline in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/index.html b/ch9-log/os/mm/memory_set/index.html
new file mode 100644
index 00000000..fe4a834d
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/index.html
@@ -0,0 +1,9 @@
+os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/sidebar-items.js b/ch9-log/os/mm/memory_set/sidebar-items.js
new file mode 100644
index 00000000..9883059c
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"enum":[["MapType",""]],"fn":[["ebss",""],["edata",""],["ekernel",""],["erodata",""],["etext",""],["kernel_token",""],["remap_test",""],["sbss_with_stack",""],["sdata",""],["srodata",""],["stext",""],["strampoline",""]],"struct":[["KERNEL_SPACE",""],["MapArea",""],["MapPermission",""],["MemorySet",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/struct.KERNEL_SPACE.html b/ch9-log/os/mm/memory_set/struct.KERNEL_SPACE.html
new file mode 100644
index 00000000..56304ff0
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/struct.KERNEL_SPACE.html
@@ -0,0 +1,19 @@
+KERNEL_SPACE in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/struct.MapArea.html b/ch9-log/os/mm/memory_set/struct.MapArea.html
new file mode 100644
index 00000000..8db4a37e
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/struct.MapArea.html
@@ -0,0 +1,22 @@
+MapArea in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/struct.MapPermission.html b/ch9-log/os/mm/memory_set/struct.MapPermission.html
new file mode 100644
index 00000000..8bb63220
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/struct.MapPermission.html
@@ -0,0 +1,119 @@
+MapPermission in os::mm::memory_set - Rust
+
Returns the union of between the flags in self and other.
+
Specifically, the returned set contains all flags which are
+present in eitherselforother, including any which are
+present in both (see Self::symmetric_difference if that
+is undesirable).
+
This is equivalent to using the | operator (e.g.
+ops::BitOr), as in flags | other.
Specifically, the returned set contains the flags present which
+are present in self or other, but that are not present in
+both. Equivalently, it contains the flags present in exactly
+one of the sets self and other.
+
This is equivalent to using the ^ operator (e.g.
+ops::BitXor), as in flags ^ other.
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/memory_set/struct.MemorySet.html b/ch9-log/os/mm/memory_set/struct.MemorySet.html
new file mode 100644
index 00000000..09e05344
--- /dev/null
+++ b/ch9-log/os/mm/memory_set/struct.MemorySet.html
@@ -0,0 +1,23 @@
+MemorySet in os::mm::memory_set - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/fn.translated_byte_buffer.html b/ch9-log/os/mm/page_table/fn.translated_byte_buffer.html
new file mode 100644
index 00000000..0a78b767
--- /dev/null
+++ b/ch9-log/os/mm/page_table/fn.translated_byte_buffer.html
@@ -0,0 +1,6 @@
+translated_byte_buffer in os::mm::page_table - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/fn.translated_ref.html b/ch9-log/os/mm/page_table/fn.translated_ref.html
new file mode 100644
index 00000000..ec3d9511
--- /dev/null
+++ b/ch9-log/os/mm/page_table/fn.translated_ref.html
@@ -0,0 +1,6 @@
+translated_ref in os::mm::page_table - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/fn.translated_refmut.html b/ch9-log/os/mm/page_table/fn.translated_refmut.html
new file mode 100644
index 00000000..2c696d79
--- /dev/null
+++ b/ch9-log/os/mm/page_table/fn.translated_refmut.html
@@ -0,0 +1,6 @@
+translated_refmut in os::mm::page_table - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/fn.translated_str.html b/ch9-log/os/mm/page_table/fn.translated_str.html
new file mode 100644
index 00000000..9660da3e
--- /dev/null
+++ b/ch9-log/os/mm/page_table/fn.translated_str.html
@@ -0,0 +1,7 @@
+translated_str in os::mm::page_table - Rust
+
Load a string from other address spaces into kernel space without an end \0.
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/index.html b/ch9-log/os/mm/page_table/index.html
new file mode 100644
index 00000000..8e6224e4
--- /dev/null
+++ b/ch9-log/os/mm/page_table/index.html
@@ -0,0 +1,9 @@
+os::mm::page_table - Rust
+
Load a string from other address spaces into kernel space without an end \0.
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/sidebar-items.js b/ch9-log/os/mm/page_table/sidebar-items.js
new file mode 100644
index 00000000..2c9e8d24
--- /dev/null
+++ b/ch9-log/os/mm/page_table/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["translated_byte_buffer",""],["translated_ref",""],["translated_refmut",""],["translated_str","Load a string from other address spaces into kernel space without an end `\\0`."]],"struct":[["PTEFlags",""],["PageTable",""],["PageTableEntry",""],["UserBuffer",""],["UserBufferIterator",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/struct.PTEFlags.html b/ch9-log/os/mm/page_table/struct.PTEFlags.html
new file mode 100644
index 00000000..f73ea52f
--- /dev/null
+++ b/ch9-log/os/mm/page_table/struct.PTEFlags.html
@@ -0,0 +1,119 @@
+PTEFlags in os::mm::page_table - Rust
+
Returns the union of between the flags in self and other.
+
Specifically, the returned set contains all flags which are
+present in eitherselforother, including any which are
+present in both (see Self::symmetric_difference if that
+is undesirable).
+
This is equivalent to using the | operator (e.g.
+ops::BitOr), as in flags | other.
Specifically, the returned set contains the flags present which
+are present in self or other, but that are not present in
+both. Equivalently, it contains the flags present in exactly
+one of the sets self and other.
+
This is equivalent to using the ^ operator (e.g.
+ops::BitXor), as in flags ^ other.
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/struct.PageTable.html b/ch9-log/os/mm/page_table/struct.PageTable.html
new file mode 100644
index 00000000..07010acc
--- /dev/null
+++ b/ch9-log/os/mm/page_table/struct.PageTable.html
@@ -0,0 +1,20 @@
+PageTable in os::mm::page_table - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/struct.PageTableEntry.html b/ch9-log/os/mm/page_table/struct.PageTableEntry.html
new file mode 100644
index 00000000..cc67b5da
--- /dev/null
+++ b/ch9-log/os/mm/page_table/struct.PageTableEntry.html
@@ -0,0 +1,22 @@
+PageTableEntry in os::mm::page_table - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/struct.UserBuffer.html b/ch9-log/os/mm/page_table/struct.UserBuffer.html
new file mode 100644
index 00000000..933e4bcb
--- /dev/null
+++ b/ch9-log/os/mm/page_table/struct.UserBuffer.html
@@ -0,0 +1,20 @@
+UserBuffer in os::mm::page_table - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/page_table/struct.UserBufferIterator.html b/ch9-log/os/mm/page_table/struct.UserBufferIterator.html
new file mode 100644
index 00000000..c4f95bb8
--- /dev/null
+++ b/ch9-log/os/mm/page_table/struct.UserBufferIterator.html
@@ -0,0 +1,131 @@
+UserBufferIterator in os::mm::page_table - Rust
+
Creates an iterator which can use the peek and peek_mut methods
+to look at the next element of the iterator without consuming it. See
+their documentation for more information. Read more
🔬 This is a nightly-only experimental API. (iter_partition_in_place)
Reorders the elements of this iterator in-place according to the given predicate,
+such that all those that return true precede all those that return false.
+Returns the number of true elements found. Read more
🔬 This is a nightly-only experimental API. (iter_is_partitioned)
Checks if the elements of this iterator are partitioned according to the given predicate,
+such that all those that return true precede all those that return false. Read more
🔬 This is a nightly-only experimental API. (iterator_try_reduce)
Reduces the elements to a single one by repeatedly applying a reducing operation. If the
+closure returns a failure, the failure is propagated back to the caller immediately. Read more
+
\ No newline at end of file
diff --git a/ch9-log/os/mm/sidebar-items.js b/ch9-log/os/mm/sidebar-items.js
new file mode 100644
index 00000000..5e2f1aaa
--- /dev/null
+++ b/ch9-log/os/mm/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["init",""]],"mod":[["address",""],["frame_allocator",""],["heap_allocator",""],["memory_set",""],["page_table",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_CLEAR_IPI.html b/ch9-log/os/sbi/constant.SBI_CLEAR_IPI.html
new file mode 100644
index 00000000..c191974c
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_CLEAR_IPI.html
@@ -0,0 +1,6 @@
+SBI_CLEAR_IPI in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_CONSOLE_GETCHAR.html b/ch9-log/os/sbi/constant.SBI_CONSOLE_GETCHAR.html
new file mode 100644
index 00000000..12640c16
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_CONSOLE_GETCHAR.html
@@ -0,0 +1,6 @@
+SBI_CONSOLE_GETCHAR in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_CONSOLE_PUTCHAR.html b/ch9-log/os/sbi/constant.SBI_CONSOLE_PUTCHAR.html
new file mode 100644
index 00000000..11240f3f
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_CONSOLE_PUTCHAR.html
@@ -0,0 +1,6 @@
+SBI_CONSOLE_PUTCHAR in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_REMOTE_FENCE_I.html b/ch9-log/os/sbi/constant.SBI_REMOTE_FENCE_I.html
new file mode 100644
index 00000000..35e0c19e
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_REMOTE_FENCE_I.html
@@ -0,0 +1,6 @@
+SBI_REMOTE_FENCE_I in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_REMOTE_SFENCE_VMA.html b/ch9-log/os/sbi/constant.SBI_REMOTE_SFENCE_VMA.html
new file mode 100644
index 00000000..4bedd2b5
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_REMOTE_SFENCE_VMA.html
@@ -0,0 +1,6 @@
+SBI_REMOTE_SFENCE_VMA in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_REMOTE_SFENCE_VMA_ASID.html b/ch9-log/os/sbi/constant.SBI_REMOTE_SFENCE_VMA_ASID.html
new file mode 100644
index 00000000..06c69ce2
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_REMOTE_SFENCE_VMA_ASID.html
@@ -0,0 +1,6 @@
+SBI_REMOTE_SFENCE_VMA_ASID in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_SEND_IPI.html b/ch9-log/os/sbi/constant.SBI_SEND_IPI.html
new file mode 100644
index 00000000..a3da3df2
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_SEND_IPI.html
@@ -0,0 +1,6 @@
+SBI_SEND_IPI in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_SET_TIMER.html b/ch9-log/os/sbi/constant.SBI_SET_TIMER.html
new file mode 100644
index 00000000..b8c22ab8
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_SET_TIMER.html
@@ -0,0 +1,6 @@
+SBI_SET_TIMER in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/constant.SBI_SHUTDOWN.html b/ch9-log/os/sbi/constant.SBI_SHUTDOWN.html
new file mode 100644
index 00000000..1019984f
--- /dev/null
+++ b/ch9-log/os/sbi/constant.SBI_SHUTDOWN.html
@@ -0,0 +1,6 @@
+SBI_SHUTDOWN in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/fn.console_getchar.html b/ch9-log/os/sbi/fn.console_getchar.html
new file mode 100644
index 00000000..877c7578
--- /dev/null
+++ b/ch9-log/os/sbi/fn.console_getchar.html
@@ -0,0 +1,6 @@
+console_getchar in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/fn.console_putchar.html b/ch9-log/os/sbi/fn.console_putchar.html
new file mode 100644
index 00000000..d1f365ff
--- /dev/null
+++ b/ch9-log/os/sbi/fn.console_putchar.html
@@ -0,0 +1,6 @@
+console_putchar in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/fn.sbi_call.html b/ch9-log/os/sbi/fn.sbi_call.html
new file mode 100644
index 00000000..00731305
--- /dev/null
+++ b/ch9-log/os/sbi/fn.sbi_call.html
@@ -0,0 +1,6 @@
+sbi_call in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/fn.set_timer.html b/ch9-log/os/sbi/fn.set_timer.html
new file mode 100644
index 00000000..baa87c5b
--- /dev/null
+++ b/ch9-log/os/sbi/fn.set_timer.html
@@ -0,0 +1,6 @@
+set_timer in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/fn.shutdown.html b/ch9-log/os/sbi/fn.shutdown.html
new file mode 100644
index 00000000..14b7a2d8
--- /dev/null
+++ b/ch9-log/os/sbi/fn.shutdown.html
@@ -0,0 +1,6 @@
+shutdown in os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/index.html b/ch9-log/os/sbi/index.html
new file mode 100644
index 00000000..8c090e8c
--- /dev/null
+++ b/ch9-log/os/sbi/index.html
@@ -0,0 +1,8 @@
+os::sbi - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sbi/sidebar-items.js b/ch9-log/os/sbi/sidebar-items.js
new file mode 100644
index 00000000..025cc5ad
--- /dev/null
+++ b/ch9-log/os/sbi/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["SBI_CLEAR_IPI",""],["SBI_CONSOLE_GETCHAR",""],["SBI_CONSOLE_PUTCHAR",""],["SBI_REMOTE_FENCE_I",""],["SBI_REMOTE_SFENCE_VMA",""],["SBI_REMOTE_SFENCE_VMA_ASID",""],["SBI_SEND_IPI",""],["SBI_SET_TIMER",""],["SBI_SHUTDOWN",""]],"fn":[["console_getchar",""],["console_putchar",""],["sbi_call",""],["set_timer",""],["shutdown",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/sidebar-items.js b/ch9-log/os/sidebar-items.js
new file mode 100644
index 00000000..229bf158
--- /dev/null
+++ b/ch9-log/os/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["clear_bss",""],["rust_main",""]],"macro":[["kprint",""],["kprintln",""],["print",""],["println",""]],"mod":[["board",""],["config",""],["console",""],["drivers",""],["fs",""],["lang_items",""],["mm",""],["sbi",""],["sync",""],["syscall",""],["task",""],["timer",""],["trap",""]],"struct":[["DEV_NON_BLOCKING_ACCESS",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/struct.DEV_NON_BLOCKING_ACCESS.html b/ch9-log/os/struct.DEV_NON_BLOCKING_ACCESS.html
new file mode 100644
index 00000000..2b55e7f8
--- /dev/null
+++ b/ch9-log/os/struct.DEV_NON_BLOCKING_ACCESS.html
@@ -0,0 +1,20 @@
+DEV_NON_BLOCKING_ACCESS in os - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/condvar/index.html b/ch9-log/os/sync/condvar/index.html
new file mode 100644
index 00000000..af3076d6
--- /dev/null
+++ b/ch9-log/os/sync/condvar/index.html
@@ -0,0 +1,7 @@
+os::sync::condvar - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/condvar/sidebar-items.js b/ch9-log/os/sync/condvar/sidebar-items.js
new file mode 100644
index 00000000..9c6e0531
--- /dev/null
+++ b/ch9-log/os/sync/condvar/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["Condvar",""],["CondvarInner",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/sync/condvar/struct.Condvar.html b/ch9-log/os/sync/condvar/struct.Condvar.html
new file mode 100644
index 00000000..3cc63d77
--- /dev/null
+++ b/ch9-log/os/sync/condvar/struct.Condvar.html
@@ -0,0 +1,17 @@
+Condvar in os::sync::condvar - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/condvar/struct.CondvarInner.html b/ch9-log/os/sync/condvar/struct.CondvarInner.html
new file mode 100644
index 00000000..f1dd3996
--- /dev/null
+++ b/ch9-log/os/sync/condvar/struct.CondvarInner.html
@@ -0,0 +1,17 @@
+CondvarInner in os::sync::condvar - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/index.html b/ch9-log/os/sync/index.html
new file mode 100644
index 00000000..3d630dd9
--- /dev/null
+++ b/ch9-log/os/sync/index.html
@@ -0,0 +1,8 @@
+os::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/mutex/index.html b/ch9-log/os/sync/mutex/index.html
new file mode 100644
index 00000000..5a6bd965
--- /dev/null
+++ b/ch9-log/os/sync/mutex/index.html
@@ -0,0 +1,8 @@
+os::sync::mutex - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/mutex/sidebar-items.js b/ch9-log/os/sync/mutex/sidebar-items.js
new file mode 100644
index 00000000..bcf7fb56
--- /dev/null
+++ b/ch9-log/os/sync/mutex/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["MutexBlocking",""],["MutexBlockingInner",""],["MutexSpin",""]],"trait":[["Mutex",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/sync/mutex/struct.MutexBlocking.html b/ch9-log/os/sync/mutex/struct.MutexBlocking.html
new file mode 100644
index 00000000..b2718350
--- /dev/null
+++ b/ch9-log/os/sync/mutex/struct.MutexBlocking.html
@@ -0,0 +1,17 @@
+MutexBlocking in os::sync::mutex - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/mutex/struct.MutexBlockingInner.html b/ch9-log/os/sync/mutex/struct.MutexBlockingInner.html
new file mode 100644
index 00000000..374cd9d3
--- /dev/null
+++ b/ch9-log/os/sync/mutex/struct.MutexBlockingInner.html
@@ -0,0 +1,18 @@
+MutexBlockingInner in os::sync::mutex - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/mutex/struct.MutexSpin.html b/ch9-log/os/sync/mutex/struct.MutexSpin.html
new file mode 100644
index 00000000..38c6d73d
--- /dev/null
+++ b/ch9-log/os/sync/mutex/struct.MutexSpin.html
@@ -0,0 +1,17 @@
+MutexSpin in os::sync::mutex - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/mutex/trait.Mutex.html b/ch9-log/os/sync/mutex/trait.Mutex.html
new file mode 100644
index 00000000..dfd4727c
--- /dev/null
+++ b/ch9-log/os/sync/mutex/trait.Mutex.html
@@ -0,0 +1,9 @@
+Mutex in os::sync::mutex - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/semaphore/index.html b/ch9-log/os/sync/semaphore/index.html
new file mode 100644
index 00000000..ca290fe6
--- /dev/null
+++ b/ch9-log/os/sync/semaphore/index.html
@@ -0,0 +1,7 @@
+os::sync::semaphore - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/semaphore/sidebar-items.js b/ch9-log/os/sync/semaphore/sidebar-items.js
new file mode 100644
index 00000000..aab70692
--- /dev/null
+++ b/ch9-log/os/sync/semaphore/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["Semaphore",""],["SemaphoreInner",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/sync/semaphore/struct.Semaphore.html b/ch9-log/os/sync/semaphore/struct.Semaphore.html
new file mode 100644
index 00000000..3b6d387c
--- /dev/null
+++ b/ch9-log/os/sync/semaphore/struct.Semaphore.html
@@ -0,0 +1,17 @@
+Semaphore in os::sync::semaphore - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/semaphore/struct.SemaphoreInner.html b/ch9-log/os/sync/semaphore/struct.SemaphoreInner.html
new file mode 100644
index 00000000..b8fcc22b
--- /dev/null
+++ b/ch9-log/os/sync/semaphore/struct.SemaphoreInner.html
@@ -0,0 +1,18 @@
+SemaphoreInner in os::sync::semaphore - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/sidebar-items.js b/ch9-log/os/sync/sidebar-items.js
new file mode 100644
index 00000000..246433bd
--- /dev/null
+++ b/ch9-log/os/sync/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"mod":[["condvar",""],["mutex",""],["semaphore",""],["up",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/sync/up/index.html b/ch9-log/os/sync/up/index.html
new file mode 100644
index 00000000..6fbb0356
--- /dev/null
+++ b/ch9-log/os/sync/up/index.html
@@ -0,0 +1,7 @@
+os::sync::up - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/up/sidebar-items.js b/ch9-log/os/sync/up/sidebar-items.js
new file mode 100644
index 00000000..e903a9f6
--- /dev/null
+++ b/ch9-log/os/sync/up/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["INTR_MASKING_INFO",""],["IntrMaskingInfo",""],["UPIntrFreeCell",""],["UPIntrRefMut",""],["UPSafeCellRaw",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/sync/up/struct.INTR_MASKING_INFO.html b/ch9-log/os/sync/up/struct.INTR_MASKING_INFO.html
new file mode 100644
index 00000000..497d74f5
--- /dev/null
+++ b/ch9-log/os/sync/up/struct.INTR_MASKING_INFO.html
@@ -0,0 +1,19 @@
+INTR_MASKING_INFO in os::sync::up - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/up/struct.IntrMaskingInfo.html b/ch9-log/os/sync/up/struct.IntrMaskingInfo.html
new file mode 100644
index 00000000..22e54718
--- /dev/null
+++ b/ch9-log/os/sync/up/struct.IntrMaskingInfo.html
@@ -0,0 +1,18 @@
+IntrMaskingInfo in os::sync::up - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/up/struct.UPIntrFreeCell.html b/ch9-log/os/sync/up/struct.UPIntrFreeCell.html
new file mode 100644
index 00000000..0e5ba3f1
--- /dev/null
+++ b/ch9-log/os/sync/up/struct.UPIntrFreeCell.html
@@ -0,0 +1,19 @@
+UPIntrFreeCell in os::sync::up - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/up/struct.UPIntrRefMut.html b/ch9-log/os/sync/up/struct.UPIntrRefMut.html
new file mode 100644
index 00000000..42c933bb
--- /dev/null
+++ b/ch9-log/os/sync/up/struct.UPIntrRefMut.html
@@ -0,0 +1,19 @@
+UPIntrRefMut in os::sync::up - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/sync/up/struct.UPSafeCellRaw.html b/ch9-log/os/sync/up/struct.UPSafeCellRaw.html
new file mode 100644
index 00000000..1b75faa6
--- /dev/null
+++ b/ch9-log/os/sync/up/struct.UPSafeCellRaw.html
@@ -0,0 +1,17 @@
+UPSafeCellRaw in os::sync::up - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_CLOSE.html b/ch9-log/os/syscall/constant.SYSCALL_CLOSE.html
new file mode 100644
index 00000000..c189a9c2
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_CLOSE.html
@@ -0,0 +1,6 @@
+SYSCALL_CLOSE in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_CREATE.html b/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_CREATE.html
new file mode 100644
index 00000000..81a37d17
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_CREATE.html
@@ -0,0 +1,6 @@
+SYSCALL_CONDVAR_CREATE in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_SIGNAL.html b/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_SIGNAL.html
new file mode 100644
index 00000000..de1ca4a3
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_SIGNAL.html
@@ -0,0 +1,6 @@
+SYSCALL_CONDVAR_SIGNAL in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_WAIT.html b/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_WAIT.html
new file mode 100644
index 00000000..95304d26
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_CONDVAR_WAIT.html
@@ -0,0 +1,6 @@
+SYSCALL_CONDVAR_WAIT in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_DUP.html b/ch9-log/os/syscall/constant.SYSCALL_DUP.html
new file mode 100644
index 00000000..4a3ed056
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_DUP.html
@@ -0,0 +1,6 @@
+SYSCALL_DUP in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_EXEC.html b/ch9-log/os/syscall/constant.SYSCALL_EXEC.html
new file mode 100644
index 00000000..ca11f1f5
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_EXEC.html
@@ -0,0 +1,6 @@
+SYSCALL_EXEC in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_EXIT.html b/ch9-log/os/syscall/constant.SYSCALL_EXIT.html
new file mode 100644
index 00000000..4ab8b379
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_EXIT.html
@@ -0,0 +1,6 @@
+SYSCALL_EXIT in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_FORK.html b/ch9-log/os/syscall/constant.SYSCALL_FORK.html
new file mode 100644
index 00000000..a60495ae
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_FORK.html
@@ -0,0 +1,6 @@
+SYSCALL_FORK in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_GETPID.html b/ch9-log/os/syscall/constant.SYSCALL_GETPID.html
new file mode 100644
index 00000000..3b32faa9
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_GETPID.html
@@ -0,0 +1,6 @@
+SYSCALL_GETPID in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_GETTID.html b/ch9-log/os/syscall/constant.SYSCALL_GETTID.html
new file mode 100644
index 00000000..ca733626
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_GETTID.html
@@ -0,0 +1,6 @@
+SYSCALL_GETTID in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_GET_TIME.html b/ch9-log/os/syscall/constant.SYSCALL_GET_TIME.html
new file mode 100644
index 00000000..343a08f8
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_GET_TIME.html
@@ -0,0 +1,6 @@
+SYSCALL_GET_TIME in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_KILL.html b/ch9-log/os/syscall/constant.SYSCALL_KILL.html
new file mode 100644
index 00000000..bf5ec3eb
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_KILL.html
@@ -0,0 +1,6 @@
+SYSCALL_KILL in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_MUTEX_CREATE.html b/ch9-log/os/syscall/constant.SYSCALL_MUTEX_CREATE.html
new file mode 100644
index 00000000..6ed93ace
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_MUTEX_CREATE.html
@@ -0,0 +1,6 @@
+SYSCALL_MUTEX_CREATE in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_MUTEX_LOCK.html b/ch9-log/os/syscall/constant.SYSCALL_MUTEX_LOCK.html
new file mode 100644
index 00000000..3f352e9d
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_MUTEX_LOCK.html
@@ -0,0 +1,6 @@
+SYSCALL_MUTEX_LOCK in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_MUTEX_UNLOCK.html b/ch9-log/os/syscall/constant.SYSCALL_MUTEX_UNLOCK.html
new file mode 100644
index 00000000..074de3fe
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_MUTEX_UNLOCK.html
@@ -0,0 +1,6 @@
+SYSCALL_MUTEX_UNLOCK in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_OPEN.html b/ch9-log/os/syscall/constant.SYSCALL_OPEN.html
new file mode 100644
index 00000000..6db5ddbd
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_OPEN.html
@@ -0,0 +1,6 @@
+SYSCALL_OPEN in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_PIPE.html b/ch9-log/os/syscall/constant.SYSCALL_PIPE.html
new file mode 100644
index 00000000..e92c2618
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_PIPE.html
@@ -0,0 +1,6 @@
+SYSCALL_PIPE in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_READ.html b/ch9-log/os/syscall/constant.SYSCALL_READ.html
new file mode 100644
index 00000000..028c955f
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_READ.html
@@ -0,0 +1,6 @@
+SYSCALL_READ in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_CREATE.html b/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_CREATE.html
new file mode 100644
index 00000000..42485644
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_CREATE.html
@@ -0,0 +1,6 @@
+SYSCALL_SEMAPHORE_CREATE in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_DOWN.html b/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_DOWN.html
new file mode 100644
index 00000000..e7b97375
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_DOWN.html
@@ -0,0 +1,6 @@
+SYSCALL_SEMAPHORE_DOWN in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_UP.html b/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_UP.html
new file mode 100644
index 00000000..ce325bb6
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_SEMAPHORE_UP.html
@@ -0,0 +1,6 @@
+SYSCALL_SEMAPHORE_UP in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_SLEEP.html b/ch9-log/os/syscall/constant.SYSCALL_SLEEP.html
new file mode 100644
index 00000000..e1e9e0bc
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_SLEEP.html
@@ -0,0 +1,6 @@
+SYSCALL_SLEEP in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_THREAD_CREATE.html b/ch9-log/os/syscall/constant.SYSCALL_THREAD_CREATE.html
new file mode 100644
index 00000000..2fe08c30
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_THREAD_CREATE.html
@@ -0,0 +1,6 @@
+SYSCALL_THREAD_CREATE in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_WAITPID.html b/ch9-log/os/syscall/constant.SYSCALL_WAITPID.html
new file mode 100644
index 00000000..d902aa1a
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_WAITPID.html
@@ -0,0 +1,6 @@
+SYSCALL_WAITPID in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_WAITTID.html b/ch9-log/os/syscall/constant.SYSCALL_WAITTID.html
new file mode 100644
index 00000000..c259da17
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_WAITTID.html
@@ -0,0 +1,6 @@
+SYSCALL_WAITTID in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_WRITE.html b/ch9-log/os/syscall/constant.SYSCALL_WRITE.html
new file mode 100644
index 00000000..73f23b78
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_WRITE.html
@@ -0,0 +1,6 @@
+SYSCALL_WRITE in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/constant.SYSCALL_YIELD.html b/ch9-log/os/syscall/constant.SYSCALL_YIELD.html
new file mode 100644
index 00000000..45bf9297
--- /dev/null
+++ b/ch9-log/os/syscall/constant.SYSCALL_YIELD.html
@@ -0,0 +1,6 @@
+SYSCALL_YIELD in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fn.sys_id_str.html b/ch9-log/os/syscall/fn.sys_id_str.html
new file mode 100644
index 00000000..bb748054
--- /dev/null
+++ b/ch9-log/os/syscall/fn.sys_id_str.html
@@ -0,0 +1,6 @@
+sys_id_str in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fn.syscall.html b/ch9-log/os/syscall/fn.syscall.html
new file mode 100644
index 00000000..46807849
--- /dev/null
+++ b/ch9-log/os/syscall/fn.syscall.html
@@ -0,0 +1,6 @@
+syscall in os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/fn.sys_close.html b/ch9-log/os/syscall/fs/fn.sys_close.html
new file mode 100644
index 00000000..f3880698
--- /dev/null
+++ b/ch9-log/os/syscall/fs/fn.sys_close.html
@@ -0,0 +1,6 @@
+sys_close in os::syscall::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/fn.sys_dup.html b/ch9-log/os/syscall/fs/fn.sys_dup.html
new file mode 100644
index 00000000..b2af56bb
--- /dev/null
+++ b/ch9-log/os/syscall/fs/fn.sys_dup.html
@@ -0,0 +1,6 @@
+sys_dup in os::syscall::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/fn.sys_open.html b/ch9-log/os/syscall/fs/fn.sys_open.html
new file mode 100644
index 00000000..ccb6d0de
--- /dev/null
+++ b/ch9-log/os/syscall/fs/fn.sys_open.html
@@ -0,0 +1,6 @@
+sys_open in os::syscall::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/fn.sys_pipe.html b/ch9-log/os/syscall/fs/fn.sys_pipe.html
new file mode 100644
index 00000000..a5e0ea02
--- /dev/null
+++ b/ch9-log/os/syscall/fs/fn.sys_pipe.html
@@ -0,0 +1,6 @@
+sys_pipe in os::syscall::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/fn.sys_read.html b/ch9-log/os/syscall/fs/fn.sys_read.html
new file mode 100644
index 00000000..46b28058
--- /dev/null
+++ b/ch9-log/os/syscall/fs/fn.sys_read.html
@@ -0,0 +1,6 @@
+sys_read in os::syscall::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/fn.sys_write.html b/ch9-log/os/syscall/fs/fn.sys_write.html
new file mode 100644
index 00000000..ffd9f98c
--- /dev/null
+++ b/ch9-log/os/syscall/fs/fn.sys_write.html
@@ -0,0 +1,6 @@
+sys_write in os::syscall::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/index.html b/ch9-log/os/syscall/fs/index.html
new file mode 100644
index 00000000..73e15653
--- /dev/null
+++ b/ch9-log/os/syscall/fs/index.html
@@ -0,0 +1,7 @@
+os::syscall::fs - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/fs/sidebar-items.js b/ch9-log/os/syscall/fs/sidebar-items.js
new file mode 100644
index 00000000..ec5d581d
--- /dev/null
+++ b/ch9-log/os/syscall/fs/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["sys_close",""],["sys_dup",""],["sys_open",""],["sys_pipe",""],["sys_read",""],["sys_write",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/syscall/index.html b/ch9-log/os/syscall/index.html
new file mode 100644
index 00000000..70493310
--- /dev/null
+++ b/ch9-log/os/syscall/index.html
@@ -0,0 +1,9 @@
+os::syscall - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_exec.html b/ch9-log/os/syscall/process/fn.sys_exec.html
new file mode 100644
index 00000000..eae1285d
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_exec.html
@@ -0,0 +1,6 @@
+sys_exec in os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_exit.html b/ch9-log/os/syscall/process/fn.sys_exit.html
new file mode 100644
index 00000000..f353f095
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_exit.html
@@ -0,0 +1,6 @@
+sys_exit in os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_fork.html b/ch9-log/os/syscall/process/fn.sys_fork.html
new file mode 100644
index 00000000..2ae00581
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_fork.html
@@ -0,0 +1,6 @@
+sys_fork in os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_get_time.html b/ch9-log/os/syscall/process/fn.sys_get_time.html
new file mode 100644
index 00000000..c114be47
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_get_time.html
@@ -0,0 +1,6 @@
+sys_get_time in os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_getpid.html b/ch9-log/os/syscall/process/fn.sys_getpid.html
new file mode 100644
index 00000000..7277bafa
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_getpid.html
@@ -0,0 +1,6 @@
+sys_getpid in os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_kill.html b/ch9-log/os/syscall/process/fn.sys_kill.html
new file mode 100644
index 00000000..14c8e709
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_kill.html
@@ -0,0 +1,6 @@
+sys_kill in os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_waitpid.html b/ch9-log/os/syscall/process/fn.sys_waitpid.html
new file mode 100644
index 00000000..d953fce3
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_waitpid.html
@@ -0,0 +1,8 @@
+sys_waitpid in os::syscall::process - Rust
+
If there is not a child process whose pid is same as given, return -1.
+Else if there is a child process but it is still running, return -2.
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/fn.sys_yield.html b/ch9-log/os/syscall/process/fn.sys_yield.html
new file mode 100644
index 00000000..591b19e5
--- /dev/null
+++ b/ch9-log/os/syscall/process/fn.sys_yield.html
@@ -0,0 +1,6 @@
+sys_yield in os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/index.html b/ch9-log/os/syscall/process/index.html
new file mode 100644
index 00000000..8bd8e19e
--- /dev/null
+++ b/ch9-log/os/syscall/process/index.html
@@ -0,0 +1,9 @@
+os::syscall::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/process/sidebar-items.js b/ch9-log/os/syscall/process/sidebar-items.js
new file mode 100644
index 00000000..df2652b3
--- /dev/null
+++ b/ch9-log/os/syscall/process/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["sys_exec",""],["sys_exit",""],["sys_fork",""],["sys_get_time",""],["sys_getpid",""],["sys_kill",""],["sys_waitpid","If there is not a child process whose pid is same as given, return -1. Else if there is a child process but it is still running, return -2."],["sys_yield",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sidebar-items.js b/ch9-log/os/syscall/sidebar-items.js
new file mode 100644
index 00000000..0df8e4dc
--- /dev/null
+++ b/ch9-log/os/syscall/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["SYSCALL_CLOSE",""],["SYSCALL_CONDVAR_CREATE",""],["SYSCALL_CONDVAR_SIGNAL",""],["SYSCALL_CONDVAR_WAIT",""],["SYSCALL_DUP",""],["SYSCALL_EXEC",""],["SYSCALL_EXIT",""],["SYSCALL_FORK",""],["SYSCALL_GETPID",""],["SYSCALL_GETTID",""],["SYSCALL_GET_TIME",""],["SYSCALL_KILL",""],["SYSCALL_MUTEX_CREATE",""],["SYSCALL_MUTEX_LOCK",""],["SYSCALL_MUTEX_UNLOCK",""],["SYSCALL_OPEN",""],["SYSCALL_PIPE",""],["SYSCALL_READ",""],["SYSCALL_SEMAPHORE_CREATE",""],["SYSCALL_SEMAPHORE_DOWN",""],["SYSCALL_SEMAPHORE_UP",""],["SYSCALL_SLEEP",""],["SYSCALL_THREAD_CREATE",""],["SYSCALL_WAITPID",""],["SYSCALL_WAITTID",""],["SYSCALL_WRITE",""],["SYSCALL_YIELD",""]],"fn":[["sys_id_str",""],["syscall",""]],"mod":[["fs",""],["process",""],["sync",""],["thread",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_condvar_create.html b/ch9-log/os/syscall/sync/fn.sys_condvar_create.html
new file mode 100644
index 00000000..e9328362
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_condvar_create.html
@@ -0,0 +1,6 @@
+sys_condvar_create in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_condvar_signal.html b/ch9-log/os/syscall/sync/fn.sys_condvar_signal.html
new file mode 100644
index 00000000..f80ea7d7
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_condvar_signal.html
@@ -0,0 +1,6 @@
+sys_condvar_signal in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_condvar_wait.html b/ch9-log/os/syscall/sync/fn.sys_condvar_wait.html
new file mode 100644
index 00000000..1ee8cb62
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_condvar_wait.html
@@ -0,0 +1,6 @@
+sys_condvar_wait in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_mutex_create.html b/ch9-log/os/syscall/sync/fn.sys_mutex_create.html
new file mode 100644
index 00000000..ec8b6c51
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_mutex_create.html
@@ -0,0 +1,6 @@
+sys_mutex_create in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_mutex_lock.html b/ch9-log/os/syscall/sync/fn.sys_mutex_lock.html
new file mode 100644
index 00000000..82df5577
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_mutex_lock.html
@@ -0,0 +1,6 @@
+sys_mutex_lock in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_mutex_unlock.html b/ch9-log/os/syscall/sync/fn.sys_mutex_unlock.html
new file mode 100644
index 00000000..e3b3c56e
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_mutex_unlock.html
@@ -0,0 +1,6 @@
+sys_mutex_unlock in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_semaphore_create.html b/ch9-log/os/syscall/sync/fn.sys_semaphore_create.html
new file mode 100644
index 00000000..dea11d79
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_semaphore_create.html
@@ -0,0 +1,6 @@
+sys_semaphore_create in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_semaphore_down.html b/ch9-log/os/syscall/sync/fn.sys_semaphore_down.html
new file mode 100644
index 00000000..960453ca
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_semaphore_down.html
@@ -0,0 +1,6 @@
+sys_semaphore_down in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_semaphore_up.html b/ch9-log/os/syscall/sync/fn.sys_semaphore_up.html
new file mode 100644
index 00000000..3ba76d19
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_semaphore_up.html
@@ -0,0 +1,6 @@
+sys_semaphore_up in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/fn.sys_sleep.html b/ch9-log/os/syscall/sync/fn.sys_sleep.html
new file mode 100644
index 00000000..9c2d044a
--- /dev/null
+++ b/ch9-log/os/syscall/sync/fn.sys_sleep.html
@@ -0,0 +1,6 @@
+sys_sleep in os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/index.html b/ch9-log/os/syscall/sync/index.html
new file mode 100644
index 00000000..92132186
--- /dev/null
+++ b/ch9-log/os/syscall/sync/index.html
@@ -0,0 +1,7 @@
+os::syscall::sync - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/sync/sidebar-items.js b/ch9-log/os/syscall/sync/sidebar-items.js
new file mode 100644
index 00000000..40eb130e
--- /dev/null
+++ b/ch9-log/os/syscall/sync/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["sys_condvar_create",""],["sys_condvar_signal",""],["sys_condvar_wait",""],["sys_mutex_create",""],["sys_mutex_lock",""],["sys_mutex_unlock",""],["sys_semaphore_create",""],["sys_semaphore_down",""],["sys_semaphore_up",""],["sys_sleep",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/syscall/thread/fn.sys_gettid.html b/ch9-log/os/syscall/thread/fn.sys_gettid.html
new file mode 100644
index 00000000..3e2a08b4
--- /dev/null
+++ b/ch9-log/os/syscall/thread/fn.sys_gettid.html
@@ -0,0 +1,6 @@
+sys_gettid in os::syscall::thread - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/thread/fn.sys_thread_create.html b/ch9-log/os/syscall/thread/fn.sys_thread_create.html
new file mode 100644
index 00000000..705c100d
--- /dev/null
+++ b/ch9-log/os/syscall/thread/fn.sys_thread_create.html
@@ -0,0 +1,6 @@
+sys_thread_create in os::syscall::thread - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/thread/fn.sys_waittid.html b/ch9-log/os/syscall/thread/fn.sys_waittid.html
new file mode 100644
index 00000000..0e2d59ff
--- /dev/null
+++ b/ch9-log/os/syscall/thread/fn.sys_waittid.html
@@ -0,0 +1,9 @@
+sys_waittid in os::syscall::thread - Rust
+
thread does not exist, return -1
+thread has not exited yet, return -2
+otherwise, return thread’s exit code
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/thread/index.html b/ch9-log/os/syscall/thread/index.html
new file mode 100644
index 00000000..1be1fb02
--- /dev/null
+++ b/ch9-log/os/syscall/thread/index.html
@@ -0,0 +1,10 @@
+os::syscall::thread - Rust
+
thread does not exist, return -1
+thread has not exited yet, return -2
+otherwise, return thread’s exit code
+
+
\ No newline at end of file
diff --git a/ch9-log/os/syscall/thread/sidebar-items.js b/ch9-log/os/syscall/thread/sidebar-items.js
new file mode 100644
index 00000000..0f0b3557
--- /dev/null
+++ b/ch9-log/os/syscall/thread/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["sys_gettid",""],["sys_thread_create",""],["sys_waittid","thread does not exist, return -1 thread has not exited yet, return -2 otherwise, return thread’s exit code"]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/context/index.html b/ch9-log/os/task/context/index.html
new file mode 100644
index 00000000..d9baf036
--- /dev/null
+++ b/ch9-log/os/task/context/index.html
@@ -0,0 +1,7 @@
+os::task::context - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/context/sidebar-items.js b/ch9-log/os/task/context/sidebar-items.js
new file mode 100644
index 00000000..86a68385
--- /dev/null
+++ b/ch9-log/os/task/context/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["TaskContext",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/context/struct.TaskContext.html b/ch9-log/os/task/context/struct.TaskContext.html
new file mode 100644
index 00000000..86c3149c
--- /dev/null
+++ b/ch9-log/os/task/context/struct.TaskContext.html
@@ -0,0 +1,19 @@
+TaskContext in os::task::context - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/fn.add_initproc.html b/ch9-log/os/task/fn.add_initproc.html
new file mode 100644
index 00000000..8ec0a18a
--- /dev/null
+++ b/ch9-log/os/task/fn.add_initproc.html
@@ -0,0 +1,6 @@
+add_initproc in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/fn.block_current_and_run_next.html b/ch9-log/os/task/fn.block_current_and_run_next.html
new file mode 100644
index 00000000..ee26d68c
--- /dev/null
+++ b/ch9-log/os/task/fn.block_current_and_run_next.html
@@ -0,0 +1,6 @@
+block_current_and_run_next in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/fn.block_current_task.html b/ch9-log/os/task/fn.block_current_task.html
new file mode 100644
index 00000000..f463dcab
--- /dev/null
+++ b/ch9-log/os/task/fn.block_current_task.html
@@ -0,0 +1,7 @@
+block_current_task in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/fn.check_signals_of_current.html b/ch9-log/os/task/fn.check_signals_of_current.html
new file mode 100644
index 00000000..81459e61
--- /dev/null
+++ b/ch9-log/os/task/fn.check_signals_of_current.html
@@ -0,0 +1,6 @@
+check_signals_of_current in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/fn.current_add_signal.html b/ch9-log/os/task/fn.current_add_signal.html
new file mode 100644
index 00000000..2cab1c52
--- /dev/null
+++ b/ch9-log/os/task/fn.current_add_signal.html
@@ -0,0 +1,6 @@
+current_add_signal in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/fn.exit_current_and_run_next.html b/ch9-log/os/task/fn.exit_current_and_run_next.html
new file mode 100644
index 00000000..c622f748
--- /dev/null
+++ b/ch9-log/os/task/fn.exit_current_and_run_next.html
@@ -0,0 +1,6 @@
+exit_current_and_run_next in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/fn.suspend_current_and_run_next.html b/ch9-log/os/task/fn.suspend_current_and_run_next.html
new file mode 100644
index 00000000..07d8310a
--- /dev/null
+++ b/ch9-log/os/task/fn.suspend_current_and_run_next.html
@@ -0,0 +1,6 @@
+suspend_current_and_run_next in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/fn.kernel_stack_position.html b/ch9-log/os/task/id/fn.kernel_stack_position.html
new file mode 100644
index 00000000..4d746b7c
--- /dev/null
+++ b/ch9-log/os/task/id/fn.kernel_stack_position.html
@@ -0,0 +1,7 @@
+kernel_stack_position in os::task::id - Rust
+
Return (bottom, top) of a kernel stack in kernel space.
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/fn.kstack_alloc.html b/ch9-log/os/task/id/fn.kstack_alloc.html
new file mode 100644
index 00000000..ed362ad4
--- /dev/null
+++ b/ch9-log/os/task/id/fn.kstack_alloc.html
@@ -0,0 +1,6 @@
+kstack_alloc in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/fn.pid_alloc.html b/ch9-log/os/task/id/fn.pid_alloc.html
new file mode 100644
index 00000000..9e76e058
--- /dev/null
+++ b/ch9-log/os/task/id/fn.pid_alloc.html
@@ -0,0 +1,6 @@
+pid_alloc in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/fn.trap_cx_bottom_from_tid.html b/ch9-log/os/task/id/fn.trap_cx_bottom_from_tid.html
new file mode 100644
index 00000000..5e5d08cb
--- /dev/null
+++ b/ch9-log/os/task/id/fn.trap_cx_bottom_from_tid.html
@@ -0,0 +1,6 @@
+trap_cx_bottom_from_tid in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/fn.ustack_bottom_from_tid.html b/ch9-log/os/task/id/fn.ustack_bottom_from_tid.html
new file mode 100644
index 00000000..954d1cb8
--- /dev/null
+++ b/ch9-log/os/task/id/fn.ustack_bottom_from_tid.html
@@ -0,0 +1,6 @@
+ustack_bottom_from_tid in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/index.html b/ch9-log/os/task/id/index.html
new file mode 100644
index 00000000..8cb66035
--- /dev/null
+++ b/ch9-log/os/task/id/index.html
@@ -0,0 +1,9 @@
+os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/sidebar-items.js b/ch9-log/os/task/id/sidebar-items.js
new file mode 100644
index 00000000..693c0c6e
--- /dev/null
+++ b/ch9-log/os/task/id/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["kernel_stack_position","Return (bottom, top) of a kernel stack in kernel space."],["kstack_alloc",""],["pid_alloc",""],["trap_cx_bottom_from_tid",""],["ustack_bottom_from_tid",""]],"struct":[["KSTACK_ALLOCATOR",""],["KernelStack",""],["PID_ALLOCATOR",""],["PidHandle",""],["RecycleAllocator",""],["TaskUserRes",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/id/struct.KSTACK_ALLOCATOR.html b/ch9-log/os/task/id/struct.KSTACK_ALLOCATOR.html
new file mode 100644
index 00000000..f75edfd9
--- /dev/null
+++ b/ch9-log/os/task/id/struct.KSTACK_ALLOCATOR.html
@@ -0,0 +1,20 @@
+KSTACK_ALLOCATOR in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/struct.KernelStack.html b/ch9-log/os/task/id/struct.KernelStack.html
new file mode 100644
index 00000000..2a4cf7f3
--- /dev/null
+++ b/ch9-log/os/task/id/struct.KernelStack.html
@@ -0,0 +1,16 @@
+KernelStack in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/struct.PID_ALLOCATOR.html b/ch9-log/os/task/id/struct.PID_ALLOCATOR.html
new file mode 100644
index 00000000..33653525
--- /dev/null
+++ b/ch9-log/os/task/id/struct.PID_ALLOCATOR.html
@@ -0,0 +1,20 @@
+PID_ALLOCATOR in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/struct.PidHandle.html b/ch9-log/os/task/id/struct.PidHandle.html
new file mode 100644
index 00000000..9a28040a
--- /dev/null
+++ b/ch9-log/os/task/id/struct.PidHandle.html
@@ -0,0 +1,16 @@
+PidHandle in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/struct.RecycleAllocator.html b/ch9-log/os/task/id/struct.RecycleAllocator.html
new file mode 100644
index 00000000..d92efefd
--- /dev/null
+++ b/ch9-log/os/task/id/struct.RecycleAllocator.html
@@ -0,0 +1,18 @@
+RecycleAllocator in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/id/struct.TaskUserRes.html b/ch9-log/os/task/id/struct.TaskUserRes.html
new file mode 100644
index 00000000..4e56392e
--- /dev/null
+++ b/ch9-log/os/task/id/struct.TaskUserRes.html
@@ -0,0 +1,20 @@
+TaskUserRes in os::task::id - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/index.html b/ch9-log/os/task/index.html
new file mode 100644
index 00000000..3c546869
--- /dev/null
+++ b/ch9-log/os/task/index.html
@@ -0,0 +1,11 @@
+os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/fn.add_task.html b/ch9-log/os/task/manager/fn.add_task.html
new file mode 100644
index 00000000..dafd317a
--- /dev/null
+++ b/ch9-log/os/task/manager/fn.add_task.html
@@ -0,0 +1,6 @@
+add_task in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/fn.fetch_task.html b/ch9-log/os/task/manager/fn.fetch_task.html
new file mode 100644
index 00000000..87474011
--- /dev/null
+++ b/ch9-log/os/task/manager/fn.fetch_task.html
@@ -0,0 +1,6 @@
+fetch_task in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/fn.insert_into_pid2process.html b/ch9-log/os/task/manager/fn.insert_into_pid2process.html
new file mode 100644
index 00000000..54489173
--- /dev/null
+++ b/ch9-log/os/task/manager/fn.insert_into_pid2process.html
@@ -0,0 +1,6 @@
+insert_into_pid2process in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/fn.pid2process.html b/ch9-log/os/task/manager/fn.pid2process.html
new file mode 100644
index 00000000..9bb72067
--- /dev/null
+++ b/ch9-log/os/task/manager/fn.pid2process.html
@@ -0,0 +1,6 @@
+pid2process in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/fn.remove_from_pid2process.html b/ch9-log/os/task/manager/fn.remove_from_pid2process.html
new file mode 100644
index 00000000..41d9ff35
--- /dev/null
+++ b/ch9-log/os/task/manager/fn.remove_from_pid2process.html
@@ -0,0 +1,6 @@
+remove_from_pid2process in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/index.html b/ch9-log/os/task/manager/index.html
new file mode 100644
index 00000000..5f4eff61
--- /dev/null
+++ b/ch9-log/os/task/manager/index.html
@@ -0,0 +1,8 @@
+os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/sidebar-items.js b/ch9-log/os/task/manager/sidebar-items.js
new file mode 100644
index 00000000..faed1787
--- /dev/null
+++ b/ch9-log/os/task/manager/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["add_task",""],["fetch_task",""],["insert_into_pid2process",""],["pid2process",""],["remove_from_pid2process",""]],"struct":[["PID2PCB",""],["TASK_MANAGER",""],["TaskManager",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/struct.PID2PCB.html b/ch9-log/os/task/manager/struct.PID2PCB.html
new file mode 100644
index 00000000..6caba82d
--- /dev/null
+++ b/ch9-log/os/task/manager/struct.PID2PCB.html
@@ -0,0 +1,20 @@
+PID2PCB in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/struct.TASK_MANAGER.html b/ch9-log/os/task/manager/struct.TASK_MANAGER.html
new file mode 100644
index 00000000..fa546224
--- /dev/null
+++ b/ch9-log/os/task/manager/struct.TASK_MANAGER.html
@@ -0,0 +1,20 @@
+TASK_MANAGER in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/manager/struct.TaskManager.html b/ch9-log/os/task/manager/struct.TaskManager.html
new file mode 100644
index 00000000..06461f22
--- /dev/null
+++ b/ch9-log/os/task/manager/struct.TaskManager.html
@@ -0,0 +1,18 @@
+TaskManager in os::task::manager - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/process/index.html b/ch9-log/os/task/process/index.html
new file mode 100644
index 00000000..e718743f
--- /dev/null
+++ b/ch9-log/os/task/process/index.html
@@ -0,0 +1,7 @@
+os::task::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/process/sidebar-items.js b/ch9-log/os/task/process/sidebar-items.js
new file mode 100644
index 00000000..bdfaf442
--- /dev/null
+++ b/ch9-log/os/task/process/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["ProcessControlBlock",""],["ProcessControlBlockInner",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/process/struct.ProcessControlBlock.html b/ch9-log/os/task/process/struct.ProcessControlBlock.html
new file mode 100644
index 00000000..4dea8528
--- /dev/null
+++ b/ch9-log/os/task/process/struct.ProcessControlBlock.html
@@ -0,0 +1,20 @@
+ProcessControlBlock in os::task::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/process/struct.ProcessControlBlockInner.html b/ch9-log/os/task/process/struct.ProcessControlBlockInner.html
new file mode 100644
index 00000000..ea0fe5dc
--- /dev/null
+++ b/ch9-log/os/task/process/struct.ProcessControlBlockInner.html
@@ -0,0 +1,28 @@
+ProcessControlBlockInner in os::task::process - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.current_kstack_top.html b/ch9-log/os/task/processor/fn.current_kstack_top.html
new file mode 100644
index 00000000..8dac726d
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.current_kstack_top.html
@@ -0,0 +1,6 @@
+current_kstack_top in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.current_process.html b/ch9-log/os/task/processor/fn.current_process.html
new file mode 100644
index 00000000..d5903bf0
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.current_process.html
@@ -0,0 +1,6 @@
+current_process in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.current_task.html b/ch9-log/os/task/processor/fn.current_task.html
new file mode 100644
index 00000000..f6f6bccc
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.current_task.html
@@ -0,0 +1,6 @@
+current_task in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.current_trap_cx.html b/ch9-log/os/task/processor/fn.current_trap_cx.html
new file mode 100644
index 00000000..79f846c8
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.current_trap_cx.html
@@ -0,0 +1,6 @@
+current_trap_cx in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.current_trap_cx_user_va.html b/ch9-log/os/task/processor/fn.current_trap_cx_user_va.html
new file mode 100644
index 00000000..a42a3ccc
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.current_trap_cx_user_va.html
@@ -0,0 +1,6 @@
+current_trap_cx_user_va in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.current_user_token.html b/ch9-log/os/task/processor/fn.current_user_token.html
new file mode 100644
index 00000000..6087a229
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.current_user_token.html
@@ -0,0 +1,6 @@
+current_user_token in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.run_tasks.html b/ch9-log/os/task/processor/fn.run_tasks.html
new file mode 100644
index 00000000..d9451900
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.run_tasks.html
@@ -0,0 +1,6 @@
+run_tasks in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.schedule.html b/ch9-log/os/task/processor/fn.schedule.html
new file mode 100644
index 00000000..3e7f480b
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.schedule.html
@@ -0,0 +1,6 @@
+schedule in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/fn.take_current_task.html b/ch9-log/os/task/processor/fn.take_current_task.html
new file mode 100644
index 00000000..11abf37c
--- /dev/null
+++ b/ch9-log/os/task/processor/fn.take_current_task.html
@@ -0,0 +1,6 @@
+take_current_task in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/index.html b/ch9-log/os/task/processor/index.html
new file mode 100644
index 00000000..a9bd2c70
--- /dev/null
+++ b/ch9-log/os/task/processor/index.html
@@ -0,0 +1,8 @@
+os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/sidebar-items.js b/ch9-log/os/task/processor/sidebar-items.js
new file mode 100644
index 00000000..b4f831f3
--- /dev/null
+++ b/ch9-log/os/task/processor/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["current_kstack_top",""],["current_process",""],["current_task",""],["current_trap_cx",""],["current_trap_cx_user_va",""],["current_user_token",""],["run_tasks",""],["schedule",""],["take_current_task",""]],"struct":[["PROCESSOR",""],["Processor",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/struct.PROCESSOR.html b/ch9-log/os/task/processor/struct.PROCESSOR.html
new file mode 100644
index 00000000..81cb91a9
--- /dev/null
+++ b/ch9-log/os/task/processor/struct.PROCESSOR.html
@@ -0,0 +1,20 @@
+PROCESSOR in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/processor/struct.Processor.html b/ch9-log/os/task/processor/struct.Processor.html
new file mode 100644
index 00000000..9fc6cc87
--- /dev/null
+++ b/ch9-log/os/task/processor/struct.Processor.html
@@ -0,0 +1,18 @@
+Processor in os::task::processor - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/sidebar-items.js b/ch9-log/os/task/sidebar-items.js
new file mode 100644
index 00000000..b0eaa08b
--- /dev/null
+++ b/ch9-log/os/task/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["add_initproc",""],["block_current_and_run_next",""],["block_current_task","This function must be followed by a schedule"],["check_signals_of_current",""],["current_add_signal",""],["exit_current_and_run_next",""],["suspend_current_and_run_next",""]],"mod":[["context",""],["id",""],["manager",""],["process",""],["processor",""],["signal",""],["switch",""],["task",""]],"struct":[["INITPROC",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/signal/index.html b/ch9-log/os/task/signal/index.html
new file mode 100644
index 00000000..b3346870
--- /dev/null
+++ b/ch9-log/os/task/signal/index.html
@@ -0,0 +1,7 @@
+os::task::signal - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/signal/sidebar-items.js b/ch9-log/os/task/signal/sidebar-items.js
new file mode 100644
index 00000000..e012b489
--- /dev/null
+++ b/ch9-log/os/task/signal/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["SignalFlags",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/signal/struct.SignalFlags.html b/ch9-log/os/task/signal/struct.SignalFlags.html
new file mode 100644
index 00000000..c994d201
--- /dev/null
+++ b/ch9-log/os/task/signal/struct.SignalFlags.html
@@ -0,0 +1,119 @@
+SignalFlags in os::task::signal - Rust
+
Returns the union of between the flags in self and other.
+
Specifically, the returned set contains all flags which are
+present in eitherselforother, including any which are
+present in both (see Self::symmetric_difference if that
+is undesirable).
+
This is equivalent to using the | operator (e.g.
+ops::BitOr), as in flags | other.
Specifically, the returned set contains the flags present which
+are present in self or other, but that are not present in
+both. Equivalently, it contains the flags present in exactly
+one of the sets self and other.
+
This is equivalent to using the ^ operator (e.g.
+ops::BitXor), as in flags ^ other.
+
\ No newline at end of file
diff --git a/ch9-log/os/task/struct.INITPROC.html b/ch9-log/os/task/struct.INITPROC.html
new file mode 100644
index 00000000..9a5fbd45
--- /dev/null
+++ b/ch9-log/os/task/struct.INITPROC.html
@@ -0,0 +1,19 @@
+INITPROC in os::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/switch/fn.__switch.html b/ch9-log/os/task/switch/fn.__switch.html
new file mode 100644
index 00000000..7d5e620d
--- /dev/null
+++ b/ch9-log/os/task/switch/fn.__switch.html
@@ -0,0 +1,6 @@
+__switch in os::task::switch - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/switch/index.html b/ch9-log/os/task/switch/index.html
new file mode 100644
index 00000000..c7c3e27b
--- /dev/null
+++ b/ch9-log/os/task/switch/index.html
@@ -0,0 +1,7 @@
+os::task::switch - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/switch/sidebar-items.js b/ch9-log/os/task/switch/sidebar-items.js
new file mode 100644
index 00000000..59e64029
--- /dev/null
+++ b/ch9-log/os/task/switch/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["__switch",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/task/enum.TaskStatus.html b/ch9-log/os/task/task/enum.TaskStatus.html
new file mode 100644
index 00000000..2de57649
--- /dev/null
+++ b/ch9-log/os/task/task/enum.TaskStatus.html
@@ -0,0 +1,27 @@
+TaskStatus in os::task::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/task/index.html b/ch9-log/os/task/task/index.html
new file mode 100644
index 00000000..d907cfb5
--- /dev/null
+++ b/ch9-log/os/task/task/index.html
@@ -0,0 +1,8 @@
+os::task::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/task/sidebar-items.js b/ch9-log/os/task/task/sidebar-items.js
new file mode 100644
index 00000000..dd3e5786
--- /dev/null
+++ b/ch9-log/os/task/task/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"enum":[["TaskStatus",""]],"struct":[["TaskControlBlock",""],["TaskControlBlockInner",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/task/task/struct.TaskControlBlock.html b/ch9-log/os/task/task/struct.TaskControlBlock.html
new file mode 100644
index 00000000..c9cc2393
--- /dev/null
+++ b/ch9-log/os/task/task/struct.TaskControlBlock.html
@@ -0,0 +1,19 @@
+TaskControlBlock in os::task::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/task/task/struct.TaskControlBlockInner.html b/ch9-log/os/task/task/struct.TaskControlBlockInner.html
new file mode 100644
index 00000000..cd782d69
--- /dev/null
+++ b/ch9-log/os/task/task/struct.TaskControlBlockInner.html
@@ -0,0 +1,21 @@
+TaskControlBlockInner in os::task::task - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/constant.MSEC_PER_SEC.html b/ch9-log/os/timer/constant.MSEC_PER_SEC.html
new file mode 100644
index 00000000..3c422973
--- /dev/null
+++ b/ch9-log/os/timer/constant.MSEC_PER_SEC.html
@@ -0,0 +1,6 @@
+MSEC_PER_SEC in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/constant.TICKS_PER_SEC.html b/ch9-log/os/timer/constant.TICKS_PER_SEC.html
new file mode 100644
index 00000000..296cfd51
--- /dev/null
+++ b/ch9-log/os/timer/constant.TICKS_PER_SEC.html
@@ -0,0 +1,6 @@
+TICKS_PER_SEC in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/fn.add_timer.html b/ch9-log/os/timer/fn.add_timer.html
new file mode 100644
index 00000000..6dc21570
--- /dev/null
+++ b/ch9-log/os/timer/fn.add_timer.html
@@ -0,0 +1,6 @@
+add_timer in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/fn.check_timer.html b/ch9-log/os/timer/fn.check_timer.html
new file mode 100644
index 00000000..d587e176
--- /dev/null
+++ b/ch9-log/os/timer/fn.check_timer.html
@@ -0,0 +1,6 @@
+check_timer in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/fn.get_time.html b/ch9-log/os/timer/fn.get_time.html
new file mode 100644
index 00000000..b217a3fb
--- /dev/null
+++ b/ch9-log/os/timer/fn.get_time.html
@@ -0,0 +1,6 @@
+get_time in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/fn.get_time_ms.html b/ch9-log/os/timer/fn.get_time_ms.html
new file mode 100644
index 00000000..1749b65b
--- /dev/null
+++ b/ch9-log/os/timer/fn.get_time_ms.html
@@ -0,0 +1,6 @@
+get_time_ms in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/fn.set_next_trigger.html b/ch9-log/os/timer/fn.set_next_trigger.html
new file mode 100644
index 00000000..f306d03d
--- /dev/null
+++ b/ch9-log/os/timer/fn.set_next_trigger.html
@@ -0,0 +1,6 @@
+set_next_trigger in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/index.html b/ch9-log/os/timer/index.html
new file mode 100644
index 00000000..7ead5b25
--- /dev/null
+++ b/ch9-log/os/timer/index.html
@@ -0,0 +1,9 @@
+os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/sidebar-items.js b/ch9-log/os/timer/sidebar-items.js
new file mode 100644
index 00000000..0e6557e4
--- /dev/null
+++ b/ch9-log/os/timer/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"constant":[["MSEC_PER_SEC",""],["TICKS_PER_SEC",""]],"fn":[["add_timer",""],["check_timer",""],["get_time",""],["get_time_ms",""],["set_next_trigger",""]],"struct":[["TIMERS",""],["TimerCondVar",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/timer/struct.TIMERS.html b/ch9-log/os/timer/struct.TIMERS.html
new file mode 100644
index 00000000..160c3fd8
--- /dev/null
+++ b/ch9-log/os/timer/struct.TIMERS.html
@@ -0,0 +1,20 @@
+TIMERS in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/timer/struct.TimerCondVar.html b/ch9-log/os/timer/struct.TimerCondVar.html
new file mode 100644
index 00000000..9c75a56e
--- /dev/null
+++ b/ch9-log/os/timer/struct.TimerCondVar.html
@@ -0,0 +1,32 @@
+TimerCondVar in os::timer - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/context/index.html b/ch9-log/os/trap/context/index.html
new file mode 100644
index 00000000..33efe7c8
--- /dev/null
+++ b/ch9-log/os/trap/context/index.html
@@ -0,0 +1,7 @@
+os::trap::context - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/context/sidebar-items.js b/ch9-log/os/trap/context/sidebar-items.js
new file mode 100644
index 00000000..d7c5bfe2
--- /dev/null
+++ b/ch9-log/os/trap/context/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"struct":[["TrapContext",""]]});
\ No newline at end of file
diff --git a/ch9-log/os/trap/context/struct.TrapContext.html b/ch9-log/os/trap/context/struct.TrapContext.html
new file mode 100644
index 00000000..fe6763d4
--- /dev/null
+++ b/ch9-log/os/trap/context/struct.TrapContext.html
@@ -0,0 +1,23 @@
+TrapContext in os::trap::context - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.disable_supervisor_interrupt.html b/ch9-log/os/trap/fn.disable_supervisor_interrupt.html
new file mode 100644
index 00000000..30915bc0
--- /dev/null
+++ b/ch9-log/os/trap/fn.disable_supervisor_interrupt.html
@@ -0,0 +1,6 @@
+disable_supervisor_interrupt in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.enable_supervisor_interrupt.html b/ch9-log/os/trap/fn.enable_supervisor_interrupt.html
new file mode 100644
index 00000000..0a4d7e06
--- /dev/null
+++ b/ch9-log/os/trap/fn.enable_supervisor_interrupt.html
@@ -0,0 +1,6 @@
+enable_supervisor_interrupt in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.enable_timer_interrupt.html b/ch9-log/os/trap/fn.enable_timer_interrupt.html
new file mode 100644
index 00000000..5369cd76
--- /dev/null
+++ b/ch9-log/os/trap/fn.enable_timer_interrupt.html
@@ -0,0 +1,6 @@
+enable_timer_interrupt in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.init.html b/ch9-log/os/trap/fn.init.html
new file mode 100644
index 00000000..9c003952
--- /dev/null
+++ b/ch9-log/os/trap/fn.init.html
@@ -0,0 +1,6 @@
+init in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.set_kernel_trap_entry.html b/ch9-log/os/trap/fn.set_kernel_trap_entry.html
new file mode 100644
index 00000000..e5335492
--- /dev/null
+++ b/ch9-log/os/trap/fn.set_kernel_trap_entry.html
@@ -0,0 +1,6 @@
+set_kernel_trap_entry in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.set_user_trap_entry.html b/ch9-log/os/trap/fn.set_user_trap_entry.html
new file mode 100644
index 00000000..4cea44da
--- /dev/null
+++ b/ch9-log/os/trap/fn.set_user_trap_entry.html
@@ -0,0 +1,6 @@
+set_user_trap_entry in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.trap_from_kernel.html b/ch9-log/os/trap/fn.trap_from_kernel.html
new file mode 100644
index 00000000..2fe8534c
--- /dev/null
+++ b/ch9-log/os/trap/fn.trap_from_kernel.html
@@ -0,0 +1,7 @@
+trap_from_kernel in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.trap_handler.html b/ch9-log/os/trap/fn.trap_handler.html
new file mode 100644
index 00000000..eb45b417
--- /dev/null
+++ b/ch9-log/os/trap/fn.trap_handler.html
@@ -0,0 +1,7 @@
+trap_handler in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/fn.trap_return.html b/ch9-log/os/trap/fn.trap_return.html
new file mode 100644
index 00000000..093fd8e7
--- /dev/null
+++ b/ch9-log/os/trap/fn.trap_return.html
@@ -0,0 +1,7 @@
+trap_return in os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/index.html b/ch9-log/os/trap/index.html
new file mode 100644
index 00000000..3275cc44
--- /dev/null
+++ b/ch9-log/os/trap/index.html
@@ -0,0 +1,9 @@
+os::trap - Rust
+
+
\ No newline at end of file
diff --git a/ch9-log/os/trap/sidebar-items.js b/ch9-log/os/trap/sidebar-items.js
new file mode 100644
index 00000000..240dedf4
--- /dev/null
+++ b/ch9-log/os/trap/sidebar-items.js
@@ -0,0 +1 @@
+initSidebarItems({"fn":[["disable_supervisor_interrupt",""],["enable_supervisor_interrupt",""],["enable_timer_interrupt",""],["init",""],["set_kernel_trap_entry",""],["set_user_trap_entry",""],["trap_from_kernel",""],["trap_handler",""],["trap_return",""]],"mod":[["context",""]]});
\ No newline at end of file
diff --git a/ch9-log/rust-logo.svg b/ch9-log/rust-logo.svg
new file mode 100644
index 00000000..62424d8f
--- /dev/null
+++ b/ch9-log/rust-logo.svg
@@ -0,0 +1,61 @@
+
diff --git a/ch9-log/rustdoc.css b/ch9-log/rustdoc.css
new file mode 100644
index 00000000..deed2f8a
--- /dev/null
+++ b/ch9-log/rustdoc.css
@@ -0,0 +1 @@
+ @font-face {font-family:'Fira Sans';font-style:normal;font-weight:400;src:local('Fira Sans'),url("FiraSans-Regular.woff2") format("woff2"),url("FiraSans-Regular.woff") format('woff');font-display:swap;}@font-face {font-family:'Fira Sans';font-style:normal;font-weight:500;src:local('Fira Sans Medium'),url("FiraSans-Medium.woff2") format("woff2"),url("FiraSans-Medium.woff") format('woff');font-display:swap;}@font-face {font-family:'Source Serif 4';font-style:normal;font-weight:400;src:local('Source Serif 4'),url("SourceSerif4-Regular.ttf.woff2") format("woff2"),url("SourceSerif4-Regular.ttf.woff") format("woff");font-display:swap;}@font-face {font-family:'Source Serif 4';font-style:italic;font-weight:400;src:local('Source Serif 4 Italic'),url("SourceSerif4-It.ttf.woff2") format("woff2"),url("SourceSerif4-It.ttf.woff") format("woff");font-display:swap;}@font-face {font-family:'Source Serif 4';font-style:normal;font-weight:700;src:local('Source Serif 4 Bold'),url("SourceSerif4-Bold.ttf.woff2") format("woff2"),url("SourceSerif4-Bold.ttf.woff") format("woff");font-display:swap;}@font-face {font-family:'Source Code Pro';font-style:normal;font-weight:400;src:url("SourceCodePro-Regular.ttf.woff2") format("woff2"),url("SourceCodePro-Regular.ttf.woff") format("woff");font-display:swap;}@font-face {font-family:'Source Code Pro';font-style:italic;font-weight:400;src:url("SourceCodePro-It.ttf.woff2") format("woff2"),url("SourceCodePro-It.ttf.woff") format("woff");font-display:swap;}@font-face {font-family:'Source Code Pro';font-style:normal;font-weight:600;src:url("SourceCodePro-Semibold.ttf.woff2") format("woff2"),url("SourceCodePro-Semibold.ttf.woff") format("woff");font-display:swap;}@font-face {font-family:'NanumBarunGothic';src:url("NanumBarunGothic.ttf.woff2") format("woff2"),url("NanumBarunGothic.ttf.woff") format("woff");font-display:swap;unicode-range:U+AC00-D7AF,U+1100-11FF,U+3130-318F,U+A960-A97F,U+D7B0-D7FF;}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}html{content:"";}@media (prefers-color-scheme:light){html{content:"light";}}@media (prefers-color-scheme:dark){html{content:"dark";}}body{font:1rem/1.4 "Source Serif 4",NanumBarunGothic,serif;margin:0;position:relative;overflow-wrap:break-word;overflow-wrap:anywhere;-webkit-font-feature-settings:"kern","liga";-moz-font-feature-settings:"kern","liga";font-feature-settings:"kern","liga";}h1{font-size:1.5rem;}h2{font-size:1.4rem;}h3{font-size:1.3rem;}h1,h2,h3,h4,h5,h6{font-weight:500;}h1,h2,h3,h4{margin:20px 0 15px 0;padding-bottom:6px;}.docblock h3,.docblock h4,h5,h6{margin:15px 0 5px 0;}h1.fqn{margin:0;padding:0;}.main-heading{display:flex;border-bottom:1px dashed #DDDDDD;padding-bottom:6px;margin-bottom:15px;padding-left:1px;}.main-heading a:hover{text-decoration:underline;}#toggle-all-docs{text-decoration:none;}h2,.top-doc h3,.top-doc h4,.sidebar .others h3{border-bottom:1px solid;}h3.code-header{font-size:1.1rem;}h4.code-header{font-size:1rem;}h3.code-header,h4.code-header{font-weight:600;border-bottom-style:none;padding:0;margin:0;}.impl,.impl-items .method,.methods .method,.impl-items .type,.methods .type,.impl-items .associatedconstant,.methods .associatedconstant,.impl-items .associatedtype,.methods .associatedtype{flex-basis:100%;font-weight:600;margin-top:16px;margin-bottom:10px;position:relative;}div.impl-items>div{padding-left:0;}h1,h2,h3,h4,h5,h6,.sidebar,a.source,.search-input,.search-results .result-name,.content table td:first-child>a,.item-left>a,.out-of-band,span.since,#source-sidebar,#sidebar-toggle,details.rustdoc-toggle>summary::before,div.impl-items>div:not(.docblock):not(.item-info),.content ul.crate a.crate,a.srclink,#main-content>ul.docblock>li>a{font-family:"Fira Sans",Arial,NanumBarunGothic,sans-serif;}.content ul.crate a.crate{font-size:1rem/1.6;}ol,ul{padding-left:25px;}ul ul,ol ul,ul ol,ol ol{margin-bottom:.6em;}p{margin:0 0 .6em 0;}summary{outline:none;}td,th{padding:0;}table{border-collapse:collapse;}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0;}.rustdoc{display:flex;flex-direction:row;flex-wrap:nowrap;}main{position:relative;flex-grow:1;padding:10px 15px 40px 45px;min-width:0;}.source main{padding:15px;}.width-limiter{max-width:960px;margin-right:auto;}.source .width-limiter{max-width:unset;}details:not(.rustdoc-toggle) summary{margin-bottom:.6em;}code,pre,a.test-arrow,.code-header{font-family:"Source Code Pro",monospace;}.docblock code,.docblock-short code{border-radius:3px;padding:0 0.1em;}.docblock pre code,.docblock-short pre code{padding:0;}pre{padding:14px;}.docblock.item-decl{margin-left:0;}.item-decl pre{overflow-x:auto;}.source .content pre{padding:20px;}img{max-width:100%;}li{position:relative;}.source .content{max-width:none;overflow:visible;margin-left:0px;}nav.sub{position:relative;font-size:1rem;text-transform:uppercase;}.sub-container{display:flex;flex-direction:row;flex-wrap:nowrap;}.sub-logo-container{display:none;margin-right:20px;}.source .sub-logo-container{display:block;}.source .sub-logo-container>img{height:60px;width:60px;object-fit:contain;}.sidebar{width:200px;overflow-y:scroll;position:sticky;min-width:200px;height:100vh;top:0;left:0;}.rustdoc.source .sidebar{width:50px;min-width:0px;max-width:300px;flex-grow:0;flex-shrink:0;flex-basis:auto;border-right:1px solid;overflow-x:hidden;overflow-y:hidden;}.source .sidebar>*:not(:first-child){transition:opacity 0.5s,visibility 0.2s;opacity:0;visibility:hidden;}.source .sidebar.expanded{overflow-y:auto;}.source .sidebar.expanded>*{opacity:1;visibility:visible;}*{scrollbar-width:initial;}.sidebar{scrollbar-width:thin;}::-webkit-scrollbar{width:12px;}.sidebar::-webkit-scrollbar{width:8px;}::-webkit-scrollbar-track{-webkit-box-shadow:inset 0;}.sidebar .block>ul>li{margin-right:-10px;}.hidden{display:none !important;}.logo-container{display:flex;margin-top:10px;margin-bottom:10px;justify-content:center;}.logo-container>img{height:100px;width:100px;}.sidebar .location{border:1px solid;font-size:1.0625rem;margin:30px 10px 20px 10px;text-align:center;word-wrap:break-word;font-weight:inherit;padding:0;}.sidebar .version{font-size:0.9375rem;text-align:center;border-bottom:1px solid;overflow-wrap:break-word;overflow-wrap:anywhere;word-wrap:break-word;word-break:break-word;}.location:empty{border:none;}.location a:first-of-type{font-weight:500;}.location a:hover{text-decoration:underline;}.block{padding:0;margin-bottom:14px;}.block h2,.block h3{text-align:center;}.block ul,.block li{margin:0 10px;padding:0;list-style:none;}.block a{display:block;text-overflow:ellipsis;overflow:hidden;line-height:15px;padding:7px 5px;font-size:0.875rem;font-weight:300;transition:border 500ms ease-out;}.sidebar-title{border-top:1px solid;border-bottom:1px solid;text-align:center;font-size:1.0625rem;margin-bottom:5px;font-weight:inherit;padding:0;}.sidebar-links{margin-bottom:15px;}.sidebar-links>a{padding-left:10px;width:100%;}.sidebar-menu{display:none;}.source .content pre.rust{white-space:pre;overflow:auto;padding-left:0;}.rustdoc .example-wrap{display:inline-flex;margin-bottom:10px;}.example-wrap{position:relative;width:100%;}.example-wrap>pre.line-number{overflow:initial;border:1px solid;padding:13px 8px;text-align:right;border-top-left-radius:5px;border-bottom-left-radius:5px;}.example-wrap>pre.rust a:hover{text-decoration:underline;}.rustdoc:not(.source) .example-wrap>pre:not(.line-number){width:100%;overflow-x:auto;}.rustdoc:not(.source) .example-wrap>pre.line-numbers{width:auto;overflow-x:visible;}.rustdoc .example-wrap>pre{margin:0;}#search{position:relative;}.search-loading{text-align:center;}#results>table{width:100%;table-layout:fixed;}.content>.example-wrap pre.line-numbers{position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;}.line-numbers span{cursor:pointer;}.docblock-short{overflow-wrap:break-word;overflow-wrap:anywhere;}.docblock-short p{display:inline;}.docblock-short p{overflow:hidden;text-overflow:ellipsis;margin:0;}.docblock>:not(pre)>code,.docblock-short>:not(pre)>code{white-space:pre-wrap;}.top-doc .docblock h2{font-size:1.3rem;}.top-doc .docblock h3{font-size:1.15rem;}.top-doc .docblock h4,.top-doc .docblock h5{font-size:1.1rem;}.top-doc .docblock h6{font-size:1rem;}.docblock h5{font-size:1rem;}.docblock h6{font-size:0.95rem;}.docblock{margin-left:24px;position:relative;}.docblock>:not(.information){max-width:100%;overflow-x:auto;}.content .out-of-band{flex-grow:0;text-align:right;margin-left:auto;margin-right:0;font-size:1.15rem;padding:0 0 0 12px;font-weight:normal;float:right;}.method>.code-header,.trait-impl>.code-header,.invisible>.code-header{max-width:calc(100% - 41px);display:block;}.invisible{width:100%;display:inline-block;}.content .in-band{flex-grow:1;margin:0px;padding:0px;overflow-wrap:break-word;overflow-wrap:anywhere;}.in-band>code,.in-band>.code-header{display:inline-block;}#main-content{position:relative;}#main-content>.since{top:inherit;font-family:"Fira Sans",Arial,sans-serif;}.content table:not(.table-display){border-spacing:0 5px;}.content td{vertical-align:top;}.content td:first-child{padding-right:20px;}.content td p:first-child{margin-top:0;}.content td h1,.content td h2{margin-left:0;font-size:1.1rem;}.content tr:first-child td{border-top:0;}.docblock table{margin:.5em 0;width:calc(100% - 2px);overflow-x:auto;overflow-wrap:normal;display:block;}.docblock table td{padding:.5em;border:1px dashed;}.docblock table th{padding:.5em;text-align:left;border:1px solid;}.fields+table{margin-bottom:1em;}.content .item-list{list-style-type:none;padding:0;}.content .multi-column{-moz-column-count:5;-moz-column-gap:2.5em;-webkit-column-count:5;-webkit-column-gap:2.5em;column-count:5;column-gap:2.5em;}.content .multi-column li{width:100%;display:inline-block;}.content>.methods>.method{font-size:1rem;position:relative;}.content .method .where,.content .fn .where,.content .where.fmt-newline{display:block;font-size:0.8rem;}.content .methods>div:not(.notable-traits):not(.method){margin-left:40px;margin-bottom:15px;}.content .docblock>.impl-items{margin-left:20px;margin-top:-34px;}.content .docblock>.impl-items .table-display{margin:0;}.content .docblock>.impl-items table td{padding:0;}.content .docblock>.impl-items .table-display,.impl-items table td{border:none;}.content .item-info code{font-size:0.81rem;}.content .item-info{position:relative;margin-left:33px;}.sub-variant>div>.item-info{margin-top:initial;}.content .item-info::before{content:'⬑';font-size:1.5625rem;position:absolute;top:-6px;left:-19px;}.content .impl-items .docblock,.content .impl-items .item-info{margin-bottom:.6em;}.content .impl-items>.item-info{margin-left:40px;}.methods>.item-info,.content .impl-items>.item-info{margin-top:-8px;}.impl-items{flex-basis:100%;}#main-content>.item-info{margin-top:0;}nav:not(.sidebar){flex-grow:1;border-bottom:1px solid;padding-bottom:10px;margin-bottom:25px;}.source nav:not(.sidebar).sub{margin-left:32px;}nav.main{padding:20px 0;text-align:center;}nav.main .current{border-top:1px solid;border-bottom:1px solid;}nav.main .separator{border:1px solid;display:inline-block;height:23px;margin:0 20px;}nav.sum{text-align:right;}nav.sub form{display:inline;}a{text-decoration:none;background:transparent;}.small-section-header{display:flex;justify-content:space-between;position:relative;}.small-section-header:hover>.anchor{display:initial;}.in-band:hover>.anchor,.impl:hover>.anchor,.method.trait-impl:hover>.anchor,.type.trait-impl:hover>.anchor,.associatedconstant.trait-impl:hover>.anchor,.associatedtype.trait-impl:hover>.anchor{display:inline-block;position:absolute;}.anchor{display:none;position:absolute;left:-0.5em;background:none !important;}.anchor.field{left:-5px;}.small-section-header>.anchor{left:-15px;padding-right:8px;}h2.small-section-header>.anchor{padding-right:6px;}.anchor::before{content:'§';}.docblock a:not(.srclink):not(.test-arrow):hover,.docblock-short a:not(.srclink):not(.test-arrow):hover,.item-info a{text-decoration:underline;}.invisible>.srclink,.method>.code-header+.srclink{position:absolute;top:0;right:0;font-size:1.0625rem;font-weight:normal;}.block a.current.crate{font-weight:500;}.item-table{display:table;}.item-row{display:table-row;}.item-left,.item-right{display:table-cell;}.item-left{padding-right:1.2rem;}.search-container{position:relative;max-width:960px;}.search-container>div{display:inline-flex;width:calc(100% - 63px);}.search-results-title{display:inline;}#search-settings{font-size:1.5rem;font-weight:500;margin-bottom:20px;}#crate-search{min-width:115px;margin-top:5px;margin-left:0.2em;padding-left:0.3em;padding-right:23px;border:0;border-radius:4px;outline:none;cursor:pointer;-moz-appearance:none;-webkit-appearance:none;text-indent:0.01px;text-overflow:"";background-repeat:no-repeat;background-color:transparent;background-size:20px;background-position:calc(100% - 1px) 56%;background-image:url("down-arrow.svg");}.search-container>.top-button{position:absolute;right:0;top:10px;}.search-input{-webkit-appearance:none;-moz-box-sizing:border-box !important;box-sizing:border-box !important;outline:none;border:none;border-radius:1px;margin-top:5px;padding:10px 16px;font-size:1.0625rem;transition:border-color 300ms ease;transition:border-radius 300ms ease-in-out;transition:box-shadow 300ms ease-in-out;width:100%;}.search-input:focus{border-radius:2px;border:0;outline:0;}.search-results{display:none;padding-bottom:2em;}.search-results.active{display:block;clear:both;}.search-results .desc>span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;display:block;}.search-results>a{display:block;width:100%;margin-left:2px;margin-right:2px;border-bottom:1px solid #aaa3;}.search-results>a>div{display:flex;flex-flow:row wrap;}.search-results .result-name,.search-results div.desc,.search-results .result-description{width:50%;}.search-results .result-name{padding-right:1em;}.search-results .result-name>span{display:inline-block;margin:0;font-weight:normal;}body.blur>:not(#help){filter:blur(8px);-webkit-filter:blur(8px);opacity:.7;}#help{width:100%;height:100vh;position:fixed;top:0;left:0;display:flex;justify-content:center;align-items:center;}#help>div{flex:0 0 auto;box-shadow:0 0 6px rgba(0,0,0,.2);width:550px;height:auto;border:1px solid;}#help dt{float:left;clear:left;display:block;margin-right:0.5rem;}#help span.top,#help span.bottom{text-align:center;display:block;font-size:1.125rem;}#help span.top{text-align:center;display:block;margin:10px 0;border-bottom:1px solid;padding-bottom:4px;margin-bottom:6px;}#help span.bottom{clear:both;border-top:1px solid;}#help dd{margin:5px 35px;}#help .infos{padding-left:0;}#help h1,#help h2{margin-top:0;}#help>div div{width:50%;float:left;padding:0 20px 20px 17px;;}.item-info .stab{display:table;}.stab{padding:3px;margin-bottom:5px;font-size:0.9rem;font-weight:normal;}.stab p{display:inline;}.stab .emoji{font-size:1.2rem;}.emoji{text-shadow:1px 0 0 black,-1px 0 0 black,0 1px 0 black,0 -1px 0 black;}.module-item .stab,.import-item .stab{border-radius:3px;display:inline-block;font-size:0.8rem;line-height:1.2;margin-bottom:0;margin-left:.3em;padding:2px;vertical-align:text-bottom;}.module-item.unstable,.import-item.unstable{opacity:0.65;}.since{font-weight:normal;font-size:initial;}.rightside{padding-left:12px;padding-right:2px;position:initial;}.impl-items .srclink,.impl .srclink,.methods .srclink{font-weight:normal;font-size:1rem;}.impl .srclink{font-size:1.0625rem;}.rightside{float:right;}.has-srclink{font-size:1rem;margin-bottom:12px;justify-content:space-between;}.variants_table{width:100%;}.variants_table tbody tr td:first-child{width:1%;}td.summary-column{width:100%;}.summary{padding-right:0px;}pre.rust .question-mark{font-weight:bold;}a.test-arrow{display:inline-block;visibility:hidden;position:absolute;padding:5px 10px 5px 10px;border-radius:5px;font-size:1.3rem;top:5px;right:5px;z-index:1;}.example-wrap:hover .test-arrow{visibility:visible;}a.test-arrow:hover{text-decoration:none;}.section-header:hover a:before{position:absolute;left:-25px;padding-right:10px;content:'\2002\00a7\2002';}.section-header:hover a{text-decoration:none;}.code-attribute{font-weight:300;}.item-spacer{width:100%;height:12px;}.out-of-band>span.since{position:initial;font-size:1.25rem;margin-right:5px;}h3.variant{font-weight:600;font-size:1.1rem;margin-bottom:10px;border-bottom:none;}.sub-variant h4{font-size:1rem;font-weight:400;border-bottom:none;margin-top:0;margin-bottom:0;}.sub-variant{margin-left:24px;margin-bottom:40px;}.sub-variant>.sub-variant-field{margin-left:24px;}.toggle-label{display:inline-block;margin-left:4px;margin-top:3px;}.top-doc .docblock>.section-header:first-child{margin-left:15px;}.top-doc .docblock>.section-header:first-child:hover>a:before{left:-10px;}.docblock>.section-header:first-child{margin-top:0;}:target>code,:target>.code-header{opacity:1;}:target{padding-right:3px;}.information{position:absolute;left:-25px;margin-top:7px;z-index:1;}.tooltip{position:relative;display:inline-block;cursor:pointer;}.tooltip::after{display:none;text-align:center;padding:5px 3px 3px 3px;border-radius:6px;margin-left:5px;font-size:1rem;}.tooltip.ignore::after{content:"This example is not tested";}.tooltip.compile_fail::after{content:"This example deliberately fails to compile";}.tooltip.should_panic::after{content:"This example panics";}.tooltip.edition::after{content:"This code runs with edition " attr(data-edition);}.tooltip::before{content:" ";position:absolute;top:50%;left:16px;margin-top:-5px;border-width:5px;border-style:solid;display:none;}.tooltip:hover::before,.tooltip:hover::after{display:inline;}.tooltip.compile_fail,.tooltip.should_panic,.tooltip.ignore{font-weight:bold;font-size:1.25rem;}.notable-traits-tooltip{display:inline-block;cursor:pointer;}.notable-traits:hover .notable-traits-tooltiptext,.notable-traits .notable-traits-tooltiptext.force-tooltip{display:inline-block;}.notable-traits .notable-traits-tooltiptext{display:none;padding:5px 3px 3px 3px;border-radius:6px;margin-left:5px;z-index:10;font-size:1rem;cursor:default;position:absolute;border:1px solid;}.notable-traits-tooltip::after{content:"\00a0\00a0\00a0";}.notable-traits .notable,.notable-traits .docblock{margin:0;}.notable-traits .notable{margin:0;margin-bottom:13px;font-size:1.1875rem;font-weight:600;}.notable-traits .docblock code.content{margin:0;padding:0;font-size:1.25rem;}pre.rust.rust-example-rendered{position:relative;}pre.rust{tab-size:4;-moz-tab-size:4;}.search-failed{text-align:center;margin-top:20px;display:none;}.search-failed.active{display:block;}.search-failed>ul{text-align:left;max-width:570px;margin-left:auto;margin-right:auto;}#titles{height:35px;}#titles>button{float:left;width:33.3%;text-align:center;font-size:1.125rem;cursor:pointer;border:0;border-top:2px solid;}#titles>button:not(:last-child){margin-right:1px;width:calc(33.3% - 1px);}#titles>button>div.count{display:inline-block;font-size:1rem;}.notable-traits{cursor:pointer;z-index:2;margin-left:5px;}#all-types{text-align:center;border:1px solid;margin:0 10px;margin-bottom:10px;display:block;border-radius:7px;}#all-types>p{margin:5px 0;}#sidebar-toggle{position:sticky;top:0;left:0;cursor:pointer;font-weight:bold;font-size:1.2rem;border-bottom:1px solid;display:flex;height:40px;justify-content:center;align-items:center;z-index:10;}#source-sidebar{width:100%;z-index:1;overflow:auto;}#source-sidebar>.title{font-size:1.5rem;text-align:center;border-bottom:1px solid;margin-bottom:6px;}.theme-picker{position:absolute;left:-34px;top:9px;}.theme-picker button{outline:none;}#settings-menu,#help-button{position:absolute;top:10px;}#settings-menu{right:0;outline:none;}#theme-picker,#settings-menu,#help-button,#copy-path{padding:4px;font-size:16px;width:27px;height:29px;border:1px solid;border-radius:3px;cursor:pointer;}#help-button{right:30px;font-family:"Fira Sans",Arial,sans-serif;text-align:center;font-size:16px;padding-top:2px;}#copy-path{background:initial;margin-left:10px;padding:0;padding-left:2px;border:0;}#theme-choices{display:none;position:absolute;left:0;top:28px;border:1px solid;border-radius:3px;z-index:1;cursor:pointer;}#theme-choices>button{border:none;width:100%;padding:4px 8px;text-align:center;background:rgba(0,0,0,0);overflow-wrap:normal;}#theme-choices>button:not(:first-child){border-top:1px solid;}kbd{display:inline-block;padding:3px 5px;font:15px monospace;line-height:10px;vertical-align:middle;border:solid 1px;border-radius:3px;box-shadow:inset 0 -1px 0;cursor:default;}.hidden-by-impl-hider,.hidden-by-usual-hider{display:none !important;}#implementations-list>h3>span.in-band{width:100%;}.table-display{width:100%;border:0;border-collapse:collapse;border-spacing:0;font-size:1rem;}.table-display tr td:first-child{padding-right:0;}.table-display tr td:last-child{float:right;}.table-display .out-of-band{position:relative;font-size:1.1875rem;display:block;}#implementors-list>.impl-items .table-display .out-of-band{font-size:1.0625rem;}.table-display td:hover .anchor{display:block;top:2px;left:-5px;}#main-content>ul{padding-left:10px;}#main-content>ul>li{list-style:none;}.non-exhaustive{margin-bottom:1em;}div.children{padding-left:27px;display:none;}div.name{cursor:pointer;position:relative;margin-left:16px;}div.files>a{display:block;padding:0 3px;}div.files>a:hover,div.name:hover{background-color:#a14b4b;}div.name.expand+.children{display:block;}div.name::before{content:"\25B6";padding-left:4px;font-size:0.7rem;position:absolute;left:-16px;top:4px;}div.name.expand::before{transform:rotate(90deg);left:-15px;top:2px;}details.rustdoc-toggle>summary.hideme{cursor:pointer;}details.rustdoc-toggle>summary{list-style:none;}details.rustdoc-toggle>summary::-webkit-details-marker,details.rustdoc-toggle>summary::marker{display:none;}details.rustdoc-toggle>summary.hideme>span{margin-left:9px;}details.rustdoc-toggle>summary::before{content:"";cursor:pointer;width:17px;height:max(17px,1.1em);background-repeat:no-repeat;background-position:top left;display:inline-block;vertical-align:middle;opacity:.5;}details.rustdoc-toggle>summary::after{content:"Expand";overflow:hidden;width:0;height:0;position:absolute;}details.rustdoc-toggle>summary.hideme::after{content:"";}details.rustdoc-toggle>summary:focus::before,details.rustdoc-toggle>summary:hover::before{opacity:1;}details.rustdoc-toggle.top-doc>summary,details.rustdoc-toggle.top-doc>summary::before,details.rustdoc-toggle.non-exhaustive>summary,details.rustdoc-toggle.non-exhaustive>summary::before{font-family:'Fira Sans';font-size:1rem;}details.non-exhaustive{margin-bottom:8px;}details.rustdoc-toggle>summary.hideme::before{position:relative;}details.rustdoc-toggle>summary:not(.hideme)::before{position:absolute;left:-24px;top:3px;}.impl-items>details.rustdoc-toggle>summary:not(.hideme)::before{position:absolute;left:-24px;}details.rustdoc-toggle[open] >summary.hideme{position:absolute;}details.rustdoc-toggle{position:relative;}details.rustdoc-toggle[open] >summary.hideme>span{display:none;}details.undocumented[open] >summary::before,details.rustdoc-toggle[open] >summary::before,details.rustdoc-toggle[open] >summary.hideme::before{background-image:url("toggle-minus.svg");}details.undocumented>summary::before,details.rustdoc-toggle>summary::before{background-image:url("toggle-plus.svg");}details.rustdoc-toggle[open] >summary::before,details.rustdoc-toggle[open] >summary.hideme::before{width:17px;height:max(17px,1.1em);background-repeat:no-repeat;background-position:top left;display:inline-block;content:"";}details.rustdoc-toggle[open] >summary::after,details.rustdoc-toggle[open] >summary.hideme::after{content:"Collapse";}@media (min-width:701px){.docblock>.information:first-child>.tooltip{margin-top:16px;}.sidebar.expanded+main .width-limiter .sub-logo-container.rust-logo{display:none;}.rustdoc.source .sidebar{transition:width .5s;}.source .sidebar.expanded{width:300px;}}@media (max-width:700px){body{padding-top:0px;}main{padding-left:15px;padding-top:0px;}#theme-picker{display:none;width:0;}.rustdoc{flex-direction:column;}.rustdoc:not(.source)>.sidebar{width:100%;height:45px;min-height:40px;max-height:45px;margin:0;padding:0 15px;position:static;z-index:11;overflow-y:hidden;}.rustdoc.source>.sidebar{position:fixed;top:0;left:0;margin:0;z-index:11;width:0;}.sidebar.mobile{position:sticky !important;top:0;left:0;width:100%;margin-left:0;background-color:rgba(0,0,0,0);}.sidebar>.location{float:right;margin:0px;margin-top:2px;padding:3px 10px 1px 10px;min-height:39px;background:inherit;text-align:left;font-size:1.5rem;}.sidebar .location:empty{padding:0;}.rustdoc:not(.source) .sidebar .logo-container{width:35px;height:35px;margin-top:5px;margin-bottom:5px;float:left;margin-left:50px;}.sidebar .logo-container>img{max-width:35px;max-height:35px;}.sidebar-menu{position:fixed;z-index:10;font-size:2rem;cursor:pointer;width:45px;left:0;top:0;text-align:center;display:block;border-bottom:1px solid;border-right:1px solid;height:45px;}.rustdoc.source>.sidebar>.sidebar-menu{display:none;}.sidebar-elems{position:fixed;z-index:1;top:45px;bottom:0;width:246px;left:-246px;overflow-y:auto;border-right:1px solid;}.sidebar>.block.version{overflow:hidden;border-bottom:none;margin-bottom:0;height:100%;padding-left:12px;}.sidebar>.block.version>div.narrow-helper{float:left;width:1px;height:100%;}.sidebar>.block.version>p{margin:0;min-width:55px;display:flex;align-items:center;height:100%;}.source nav:not(.sidebar).sub{margin-left:32px;}.content{margin-left:0px;}.source .content{margin-top:10px;}#search{margin-left:0;padding:0;}.anchor{display:none !important;}.theme-picker{z-index:1;}.notable-traits{position:absolute;left:-22px;top:24px;}#titles>button>div.count{float:left;width:100%;}#titles{height:50px;}.show-it,.sidebar-elems:focus-within{z-index:2;left:0;}.show-it>.block.items{margin:8px 0;}.show-it>.block.items>ul{margin:0;}.show-it>.block.items>ul>li{text-align:center;margin:2px 0;}.show-it>.block.items>ul>li>a{font-size:1.3125rem;}#sidebar-filler{position:fixed;left:45px;width:calc(100% - 45px);top:0;height:45px;z-index:-1;border-bottom:1px solid;}#main-content>details.rustdoc-toggle>summary::before,#main-content>div>details.rustdoc-toggle>summary::before{left:-11px;}#all-types{margin:10px;}.sidebar.expanded #sidebar-toggle{font-size:1.5rem;}.sidebar:not(.expanded) #sidebar-toggle{position:fixed;left:1px;top:100px;width:30px;font-size:1.5rem;text-align:center;padding:0;z-index:10;border-top-right-radius:3px;border-bottom-right-radius:3px;cursor:pointer;font-weight:bold;border:1px solid;border-left:0;}#source-sidebar{z-index:11;}#main-content>.line-numbers{margin-top:0;}.notable-traits .notable-traits-tooltiptext{left:0;top:100%;}#help-button{display:none;}.item-table{display:block;}.item-row{display:flex;flex-flow:column wrap;}.item-left,.item-right{width:100%;}.search-container>div{width:calc(100% - 32px);}.search-results>a{border-bottom:1px solid #aaa9;padding:5px 0px;}.search-results .result-name,.search-results div.desc,.search-results .result-description{width:100%;}.search-results div.desc,.search-results .result-description,.item-right{padding-left:2em;}.source .sidebar.expanded{max-width:100vw;width:100vw;}details.rustdoc-toggle:not(.top-doc)>summary{margin-left:10px;}.impl-items>details.rustdoc-toggle>summary:not(.hideme)::before,#main-content>details.rustdoc-toggle:not(.top-doc)>summary::before,#main-content>div>details.rustdoc-toggle>summary::before{left:-11px;}}@media print{nav.sub,.content .out-of-band{display:none;}}@media (max-width:464px){#titles,#titles>button{height:73px;}#main-content>table:not(.table-display) td{word-break:break-word;width:50%;}.search-container>div{display:block;width:calc(100% - 37px);}#crate-search{border-radius:4px;border:0;}#theme-picker,#settings-menu{padding:5px;width:31px;height:31px;}#theme-picker{margin-top:-2px;}#settings-menu{top:7px;}.docblock{margin-left:12px;}.docblock code{overflow-wrap:break-word;overflow-wrap:anywhere;}.docblock table code{overflow-wrap:normal;}.sub-container{flex-direction:column;}.sub-logo-container{align-self:center;}.source .sub-logo-container>img{height:35px;width:35px;}.sidebar:not(.expanded) #sidebar-toggle{top:10px;}}.scraped-example-title{font-family:'Fira Sans';}.scraped-example:not(.expanded) .code-wrapper pre.line-numbers{overflow:hidden;max-height:240px;}.scraped-example:not(.expanded) .code-wrapper .example-wrap pre.rust{overflow-y:hidden;max-height:240px;padding-bottom:0;}.scraped-example .code-wrapper .prev{position:absolute;top:0.25em;right:2.25em;z-index:100;cursor:pointer;}.scraped-example .code-wrapper .next{position:absolute;top:0.25em;right:1.25em;z-index:100;cursor:pointer;}.scraped-example .code-wrapper .expand{position:absolute;top:0.25em;right:0.25em;z-index:100;cursor:pointer;}.scraped-example .code-wrapper{position:relative;display:flex;flex-direction:row;flex-wrap:wrap;width:100%;}.scraped-example:not(.expanded) .code-wrapper:before{content:" ";width:100%;height:5px;position:absolute;z-index:100;top:0;background:linear-gradient(to bottom,rgba(255,255,255,1),rgba(255,255,255,0));}.scraped-example:not(.expanded) .code-wrapper:after{content:" ";width:100%;height:5px;position:absolute;z-index:100;bottom:0;background:linear-gradient(to top,rgba(255,255,255,1),rgba(255,255,255,0));}.scraped-example:not(.expanded) .code-wrapper{overflow:hidden;max-height:240px;}.scraped-example .code-wrapper .line-numbers{margin:0;padding:14px 0;}.scraped-example .code-wrapper .line-numbers span{padding:0 14px;}.scraped-example .code-wrapper .example-wrap{flex:1;overflow-x:auto;overflow-y:hidden;margin-bottom:0;}.scraped-example .code-wrapper .example-wrap pre.rust{overflow-x:inherit;width:inherit;overflow-y:hidden;}.scraped-example .example-wrap .rust span.highlight{background:#fcffd6;}.scraped-example .example-wrap .rust span.highlight.focus{background:#f6fdb0;}.more-examples-toggle{margin-top:10px;}.more-examples-toggle summary{color:#999;font-family:'Fira Sans';}.more-scraped-examples{margin-left:25px;display:flex;flex-direction:row;width:calc(100% - 25px);}.more-scraped-examples-inner{width:calc(100% - 20px);}.toggle-line{align-self:stretch;margin-right:10px;margin-top:5px;padding:0 4px;cursor:pointer;}.toggle-line:hover .toggle-line-inner{background:#aaa;}.toggle-line-inner{min-width:2px;background:#ddd;height:100%;}.more-scraped-examples .scraped-example{margin-bottom:20px;}.more-scraped-examples .scraped-example:last-child{margin-bottom:0;}.example-links a{margin-top:20px;font-family:'Fira Sans';}.example-links ul{margin-bottom:0;}
\ No newline at end of file
diff --git a/ch9-log/search-index.js b/ch9-log/search-index.js
new file mode 100644
index 00000000..e1c812fe
--- /dev/null
+++ b/ch9-log/search-index.js
@@ -0,0 +1,4 @@
+var searchIndex = JSON.parse('{\
+"os":{"doc":"","t":[3,12,0,11,11,5,0,0,11,0,11,0,11,14,14,0,0,14,14,5,0,0,0,0,0,0,11,11,11,6,17,6,17,17,17,5,5,17,17,17,17,17,17,17,17,3,3,11,11,11,11,11,11,11,11,5,5,11,11,11,11,11,11,11,11,0,0,0,3,12,5,11,11,11,11,11,11,11,11,0,3,17,3,12,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,5,5,5,5,11,8,3,12,11,11,11,11,10,11,0,10,11,11,11,10,18,18,18,18,3,3,3,3,3,3,18,18,3,18,18,3,12,12,12,12,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,12,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,12,12,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,12,12,12,12,12,11,11,11,11,11,11,11,11,12,11,11,11,12,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,4,13,3,13,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,8,0,0,10,10,0,10,10,18,3,3,3,18,18,3,18,18,12,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,12,11,11,11,11,11,11,11,11,11,5,11,11,11,12,5,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,13,13,13,3,3,17,4,11,12,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,12,11,11,11,5,11,11,11,11,11,12,11,12,12,11,11,11,11,11,11,11,11,11,11,11,12,11,11,12,11,3,3,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,5,5,0,0,0,5,0,0,12,12,12,12,17,17,3,3,3,3,8,17,6,17,3,3,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,12,10,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,3,8,6,3,3,12,10,11,11,11,11,11,11,11,12,10,11,11,11,12,11,5,5,5,11,11,11,11,5,11,11,11,10,11,11,12,12,11,11,11,11,11,11,11,11,11,7,7,5,5,5,13,13,3,3,3,4,3,18,18,18,18,12,11,11,12,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,11,5,5,5,11,11,11,5,5,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,5,11,11,12,11,12,11,11,11,11,11,12,11,11,11,5,11,11,5,5,11,5,5,5,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,18,18,18,3,3,3,18,18,3,3,18,18,18,11,11,11,11,11,11,12,12,11,11,11,11,11,11,11,11,11,11,11,11,12,12,11,11,11,11,11,11,11,12,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,5,5,5,5,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,17,17,17,17,17,17,17,17,17,5,5,5,5,5,0,0,0,0,3,3,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,12,11,8,3,3,3,11,11,11,11,11,11,11,11,11,12,11,11,11,10,11,11,12,12,11,11,11,11,11,11,11,11,11,11,11,10,11,11,12,3,3,11,11,11,11,12,11,11,11,12,11,11,11,11,11,11,11,11,11,11,12,12,3,3,3,3,3,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,12,11,11,11,11,11,12,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,0,0,0,5,5,0,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,3,12,5,5,5,11,11,5,0,5,11,5,11,0,11,0,0,0,0,5,0,0,11,11,11,3,11,11,11,11,11,12,12,12,11,11,11,11,12,12,3,3,3,3,3,3,12,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,5,5,11,11,5,12,11,12,12,5,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,12,5,11,3,3,3,12,12,11,5,11,11,11,11,11,11,11,11,11,5,11,11,11,5,11,11,11,11,5,12,5,11,11,11,11,11,11,11,11,11,3,3,11,11,11,11,11,11,12,12,11,11,12,12,11,11,11,11,11,11,12,11,11,11,12,12,12,11,12,12,12,12,12,12,11,11,11,11,11,11,11,3,3,12,11,11,11,11,11,12,5,5,5,5,5,5,11,11,11,11,12,11,11,11,5,5,11,5,11,11,11,11,11,11,18,18,18,18,18,3,11,11,11,11,11,11,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,5,13,13,13,3,3,4,11,11,11,11,11,11,11,11,11,12,11,11,11,11,11,11,12,11,11,11,11,12,11,12,12,12,12,11,12,11,11,11,11,11,11,11,11,11,17,17,3,3,12,5,11,11,11,11,5,11,11,11,12,11,11,5,5,11,11,11,5,12,11,11,11,11,11,11,0,5,5,5,5,5,5,5,5,5,3,11,11,11,11,11,11,12,12,12,11,12,12,11,11,11,12],"n":["DEV_NON_BLOCKING_ACCESS","__private_field","board","borrow","borrow_mut","clear_bss","config","console","deref","drivers","from","fs","into","kprint","kprintln","lang_items","mm","print","println","rust_main","sbi","sync","syscall","task","timer","trap","try_from","try_into","type_id","BlockDeviceImpl","CLOCK_FREQ","CharDeviceImpl","MMIO","VIRT_PLIC","VIRT_UART","device_init","irq_handler","KERNEL_HEAP_SIZE","KERNEL_STACK_SIZE","MEMORY_END","PAGE_SIZE","PAGE_SIZE_BITS","TRAMPOLINE","TRAP_CONTEXT_BASE","USER_STACK_SIZE","Kstdout","Stdout","borrow","borrow","borrow_mut","borrow_mut","from","from","into","into","kprint","print","try_from","try_from","try_into","try_into","type_id","type_id","write_str","write_str","block","chardev","plic","BLOCK_DEVICE","__private_field","block_device_test","borrow","borrow_mut","deref","from","into","try_from","try_into","type_id","virtio_blk","QUEUE_FRAMES","VIRTIO0","VirtIOBlock","__private_field","borrow","borrow","borrow_mut","borrow_mut","condvars","deref","from","from","handle_irq","into","into","new","read_block","try_from","try_from","try_into","try_into","type_id","type_id","virtio_blk","virtio_dma_alloc","virtio_dma_dealloc","virtio_phys_to_virt","virtio_virt_to_phys","write_block","CharDevice","UART","__private_field","borrow","borrow_mut","deref","from","handle_irq","into","ns16550a","read","try_from","try_into","type_id","write","AUX_OUTPUT1","AUX_OUTPUT2","DATA_AVAILABLE","DATA_TERMINAL_READY","IER","LSR","MCR","NS16550a","NS16550aInner","NS16550aRaw","REQUEST_TO_SEND","RX_AVALIABLE","ReadWithoutDLAB","THR_EMPTY","TX_EMPTY","WriteWithoutDLAB","_padding0","_padding1","_padding1","_padding2","all","all","all","base_addr","bitand","bitand","bitand","bitand_assign","bitand_assign","bitand_assign","bitor","bitor","bitor","bitor_assign","bitor_assign","bitor_assign","bits","bits","bits","bits","bits","bits","bitxor","bitxor","bitxor","bitxor_assign","bitxor_assign","bitxor_assign","borrow","borrow","borrow","borrow","borrow","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","clone","clone","clone","clone_into","clone_into","clone_into","cmp","cmp","cmp","complement","complement","complement","condvar","contains","contains","contains","difference","difference","difference","empty","empty","empty","eq","eq","eq","extend","extend","extend","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","fmt","from","from","from","from","from","from","from","from","from_bits","from_bits","from_bits","from_bits_truncate","from_bits_truncate","from_bits_truncate","from_bits_unchecked","from_bits_unchecked","from_bits_unchecked","from_iter","from_iter","from_iter","handle_irq","hash","hash","hash","ier","ier","iir","init","inner","insert","insert","insert","intersection","intersection","intersection","intersects","intersects","intersects","into","into","into","into","into","into","into","into","is_all","is_all","is_all","is_empty","is_empty","is_empty","lcr","lcr","lsr","lsr","mcr","mcr","ne","ne","ne","new","new","not","not","not","ns16550a","partial_cmp","partial_cmp","partial_cmp","rbr","read","read","read_buffer","read_end","remove","remove","remove","set","set","set","sub","sub","sub","sub_assign","sub_assign","sub_assign","symmetric_difference","symmetric_difference","symmetric_difference","thr","to_owned","to_owned","to_owned","toggle","toggle","toggle","try_from","try_from","try_from","try_from","try_from","try_from","try_from","try_from","try_into","try_into","try_into","try_into","try_into","try_into","try_into","try_into","type_id","type_id","type_id","type_id","type_id","type_id","type_id","type_id","union","union","union","write","write","write_end","IntrTargetPriority","Machine","PLIC","Supervisor","base_addr","borrow","borrow","borrow_mut","borrow_mut","claim","claim_comp_ptr_of_hart_with_priority","clone","clone_into","complete","disable","enable","enable_ptr","from","from","get_priority","get_threshold","hart_id_with_priority","into","into","new","priority_ptr","set_priority","set_threshold","supported_number","threshold_ptr_of_hart_with_priority","to_owned","try_from","try_from","try_into","try_into","type_id","type_id","File","inode","pipe","read","readable","stdio","writable","write","CREATE","OSInode","OSInodeInner","OpenFlags","RDONLY","RDWR","ROOT_INODE","TRUNC","WRONLY","__private_field","all","bitand","bitand_assign","bitor","bitor_assign","bits","bits","bitxor","bitxor_assign","borrow","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","borrow_mut","clone","clone_into","cmp","complement","contains","deref","difference","empty","eq","extend","fmt","fmt","fmt","fmt","fmt","from","from","from","from","from_bits","from_bits_truncate","from_bits_unchecked","from_iter","hash","inner","inode","insert","intersection","intersects","into","into","into","into","is_all","is_empty","list_apps","ne","new","not","offset","open_file","partial_cmp","read","read_all","read_write","readable","readable","remove","set","sub","sub_assign","symmetric_difference","to_owned","toggle","try_from","try_from","try_from","try_from","try_into","try_into","try_into","try_into","type_id","type_id","type_id","type_id","union","writable","writable","write","Empty","Full","Normal","Pipe","PipeRingBuffer","RING_BUFFER_SIZE","RingBufferStatus","all_write_ends_closed","arr","available_read","available_write","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","buffer","clone","clone_into","eq","from","from","from","head","into","into","into","make_pipe","new","read","read_byte","read_end_with_buffer","readable","readable","set_write_end","status","tail","to_owned","try_from","try_from","try_from","try_into","try_into","try_into","type_id","type_id","type_id","writable","writable","write","write_byte","write_end","write_end_with_buffer","Stdin","Stdout","borrow","borrow","borrow_mut","borrow_mut","from","from","into","into","read","read","readable","readable","try_from","try_from","try_into","try_into","type_id","type_id","writable","writable","write","write","backtrace","panic","address","frame_allocator","heap_allocator","init","memory_set","page_table","0","0","0","0","PA_WIDTH_SV39","PPN_WIDTH_SV39","PhysAddr","PhysPageNum","SimpleRange","SimpleRangeIterator","StepByOne","VA_WIDTH_SV39","VPNRange","VPN_WIDTH_SV39","VirtAddr","VirtPageNum","aligned","aligned","borrow","borrow","borrow","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","ceil","ceil","clone","clone","clone","clone","clone","clone_into","clone_into","clone_into","clone_into","clone_into","cmp","cmp","cmp","cmp","current","end","eq","eq","eq","eq","floor","floor","fmt","fmt","fmt","fmt","from","from","from","from","from","from","from","from","from","from","from","from","from","from","get_bytes_array","get_end","get_mut","get_mut","get_pte_array","get_ref","get_start","indexes","into","into","into","into","into","into","into_iter","into_iter","l","ne","ne","ne","ne","new","new","next","page_offset","page_offset","partial_cmp","partial_cmp","partial_cmp","partial_cmp","r","step","step","step","to_owned","to_owned","to_owned","to_owned","to_owned","try_from","try_from","try_from","try_from","try_from","try_from","try_into","try_into","try_into","try_into","try_into","try_into","type_id","type_id","type_id","type_id","type_id","type_id","FRAME_ALLOCATOR","FrameAllocator","FrameAllocatorImpl","FrameTracker","StackFrameAllocator","__private_field","alloc","alloc","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","current","dealloc","dealloc","deref","drop","end","fmt","frame_alloc","frame_allocator_test","frame_dealloc","from","from","from","init","init_frame_allocator","into","into","into","new","new","new","ppn","recycled","try_from","try_from","try_from","try_into","try_into","try_into","type_id","type_id","type_id","HEAP_ALLOCATOR","HEAP_SPACE","handle_alloc_error","heap_test","init_heap","Framed","Identical","KERNEL_SPACE","MapArea","MapPermission","MapType","MemorySet","R","U","W","X","__private_field","activate","all","areas","bitand","bitand_assign","bitor","bitor_assign","bits","bits","bitxor","bitxor_assign","borrow","borrow","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","clone","clone","clone_into","clone_into","cmp","complement","contains","copy_data","data_frames","deref","difference","ebss","edata","ekernel","empty","eq","eq","erodata","etext","extend","fmt","fmt","fmt","fmt","fmt","fmt","from","from","from","from","from","from_another","from_bits","from_bits_truncate","from_bits_unchecked","from_elf","from_existed_user","from_iter","hash","insert","insert_framed_area","intersection","intersects","into","into","into","into","into","is_all","is_empty","kernel_token","map","map_one","map_perm","map_trampoline","map_type","ne","new","new_bare","new_kernel","not","page_table","partial_cmp","push","recycle_data_pages","remap_test","remove","remove_area_with_start_vpn","sbss_with_stack","sdata","set","srodata","stext","strampoline","sub","sub_assign","symmetric_difference","to_owned","to_owned","toggle","token","translate","try_from","try_from","try_from","try_from","try_from","try_into","try_into","try_into","try_into","try_into","type_id","type_id","type_id","type_id","type_id","union","unmap","unmap_one","vpn_range","A","D","G","PTEFlags","PageTable","PageTableEntry","R","U","UserBuffer","UserBufferIterator","V","W","X","all","bitand","bitand_assign","bitor","bitor_assign","bits","bits","bits","bitxor","bitxor_assign","borrow","borrow","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","buffers","buffers","clone","clone","clone_into","clone_into","cmp","complement","contains","current_buffer","current_idx","difference","empty","empty","eq","executable","extend","find_pte","find_pte_create","flags","fmt","fmt","fmt","fmt","fmt","frames","from","from","from","from","from","from_bits","from_bits_truncate","from_bits_unchecked","from_iter","from_token","hash","insert","intersection","intersects","into","into","into","into","into","into_iter","into_iter","is_all","is_empty","is_valid","len","map","ne","new","new","new","next","not","partial_cmp","ppn","readable","remove","root_ppn","set","sub","sub_assign","symmetric_difference","to_owned","to_owned","toggle","token","translate","translate_va","translated_byte_buffer","translated_ref","translated_refmut","translated_str","try_from","try_from","try_from","try_from","try_from","try_into","try_into","try_into","try_into","try_into","type_id","type_id","type_id","type_id","type_id","union","unmap","writable","SBI_CLEAR_IPI","SBI_CONSOLE_GETCHAR","SBI_CONSOLE_PUTCHAR","SBI_REMOTE_FENCE_I","SBI_REMOTE_SFENCE_VMA","SBI_REMOTE_SFENCE_VMA_ASID","SBI_SEND_IPI","SBI_SET_TIMER","SBI_SHUTDOWN","console_getchar","console_putchar","sbi_call","set_timer","shutdown","condvar","mutex","semaphore","up","Condvar","CondvarInner","borrow","borrow","borrow_mut","borrow_mut","from","from","inner","into","into","new","signal","try_from","try_from","try_into","try_into","type_id","type_id","wait_no_sched","wait_queue","wait_with_mutex","Mutex","MutexBlocking","MutexBlockingInner","MutexSpin","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","from","from","from","inner","into","into","into","lock","lock","lock","locked","locked","new","new","try_from","try_from","try_from","try_into","try_into","try_into","type_id","type_id","type_id","unlock","unlock","unlock","wait_queue","Semaphore","SemaphoreInner","borrow","borrow","borrow_mut","borrow_mut","count","down","from","from","inner","into","into","new","try_from","try_from","try_into","try_into","type_id","type_id","up","wait_queue","0","INTR_MASKING_INFO","IntrMaskingInfo","UPIntrFreeCell","UPIntrRefMut","UPSafeCellRaw","__private_field","borrow","borrow","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","deref","deref","deref_mut","drop","enter","exclusive_access","exclusive_session","exit","from","from","from","from","from","get_mut","inner","inner","into","into","into","into","into","nested_level","new","new","new","sie_before_masking","try_from","try_from","try_from","try_from","try_from","try_into","try_into","try_into","try_into","try_into","type_id","type_id","type_id","type_id","type_id","SYSCALL_CLOSE","SYSCALL_CONDVAR_CREATE","SYSCALL_CONDVAR_SIGNAL","SYSCALL_CONDVAR_WAIT","SYSCALL_DUP","SYSCALL_EXEC","SYSCALL_EXIT","SYSCALL_FORK","SYSCALL_GETPID","SYSCALL_GETTID","SYSCALL_GET_TIME","SYSCALL_KILL","SYSCALL_MUTEX_CREATE","SYSCALL_MUTEX_LOCK","SYSCALL_MUTEX_UNLOCK","SYSCALL_OPEN","SYSCALL_PIPE","SYSCALL_READ","SYSCALL_SEMAPHORE_CREATE","SYSCALL_SEMAPHORE_DOWN","SYSCALL_SEMAPHORE_UP","SYSCALL_SLEEP","SYSCALL_THREAD_CREATE","SYSCALL_WAITPID","SYSCALL_WAITTID","SYSCALL_WRITE","SYSCALL_YIELD","fs","process","sync","sys_id_str","syscall","thread","sys_close","sys_dup","sys_open","sys_pipe","sys_read","sys_write","sys_exec","sys_exit","sys_fork","sys_get_time","sys_getpid","sys_kill","sys_waitpid","sys_yield","sys_condvar_create","sys_condvar_signal","sys_condvar_wait","sys_mutex_create","sys_mutex_lock","sys_mutex_unlock","sys_semaphore_create","sys_semaphore_down","sys_semaphore_up","sys_sleep","sys_gettid","sys_thread_create","sys_waittid","INITPROC","__private_field","add_initproc","block_current_and_run_next","block_current_task","borrow","borrow_mut","check_signals_of_current","context","current_add_signal","deref","exit_current_and_run_next","from","id","into","manager","process","processor","signal","suspend_current_and_run_next","switch","task","try_from","try_into","type_id","TaskContext","borrow","borrow_mut","from","goto_trap_return","into","ra","s","sp","try_from","try_into","type_id","zero_init","0","0","KSTACK_ALLOCATOR","KernelStack","PID_ALLOCATOR","PidHandle","RecycleAllocator","TaskUserRes","__private_field","__private_field","alloc","alloc_tid","alloc_user_res","borrow","borrow","borrow","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","borrow_mut","current","dealloc","dealloc_tid","dealloc_user_res","deref","deref","drop","drop","drop","from","from","from","from","from","from","get_top","into","into","into","into","into","into","kernel_stack_position","kstack_alloc","new","new","pid_alloc","process","push_on_top","recycled","tid","trap_cx_bottom_from_tid","trap_cx_ppn","trap_cx_user_va","try_from","try_from","try_from","try_from","try_from","try_from","try_into","try_into","try_into","try_into","try_into","try_into","type_id","type_id","type_id","type_id","type_id","type_id","ustack_base","ustack_base","ustack_bottom_from_tid","ustack_top","PID2PCB","TASK_MANAGER","TaskManager","__private_field","__private_field","add","add_task","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","deref","deref","fetch","fetch_task","from","from","from","insert_into_pid2process","into","into","into","new","pid2process","ready_queue","remove_from_pid2process","try_from","try_from","try_from","try_into","try_into","try_into","type_id","type_id","type_id","ProcessControlBlock","ProcessControlBlockInner","alloc_fd","alloc_tid","borrow","borrow","borrow_mut","borrow_mut","children","condvar_list","dealloc_tid","exec","exit_code","fd_table","fork","from","from","get_task","get_user_token","getpid","inner","inner_exclusive_access","into","into","is_zombie","memory_set","mutex_list","new","parent","pid","semaphore_list","signals","task_res_allocator","tasks","thread_count","try_from","try_from","try_into","try_into","type_id","type_id","PROCESSOR","Processor","__private_field","borrow","borrow","borrow_mut","borrow_mut","current","current","current_kstack_top","current_process","current_task","current_trap_cx","current_trap_cx_user_va","current_user_token","deref","from","from","get_idle_task_cx_ptr","idle_task_cx","into","into","new","run_tasks","schedule","take_current","take_current_task","try_from","try_from","try_into","try_into","type_id","type_id","SIGABRT","SIGFPE","SIGILL","SIGINT","SIGSEGV","SignalFlags","all","bitand","bitand_assign","bitor","bitor_assign","bits","bits","bitxor","bitxor_assign","borrow","borrow_mut","check_error","clone","clone_into","cmp","complement","contains","difference","empty","eq","extend","fmt","fmt","fmt","fmt","fmt","from","from_bits","from_bits_truncate","from_bits_unchecked","from_iter","hash","insert","intersection","intersects","into","is_all","is_empty","ne","not","partial_cmp","remove","set","sub","sub_assign","symmetric_difference","to_owned","toggle","try_from","try_into","type_id","union","__switch","Blocking","Ready","Running","TaskControlBlock","TaskControlBlockInner","TaskStatus","borrow","borrow","borrow","borrow_mut","borrow_mut","borrow_mut","clone","clone_into","eq","exit_code","from","from","from","get_status","get_trap_cx","get_user_token","inner","inner_exclusive_access","into","into","into","kstack","new","process","res","task_cx","task_status","to_owned","trap_cx_ppn","try_from","try_from","try_from","try_into","try_into","try_into","type_id","type_id","type_id","MSEC_PER_SEC","TICKS_PER_SEC","TIMERS","TimerCondVar","__private_field","add_timer","borrow","borrow","borrow_mut","borrow_mut","check_timer","cmp","deref","eq","expire_ms","from","from","get_time","get_time_ms","into","into","partial_cmp","set_next_trigger","task","try_from","try_from","try_into","try_into","type_id","type_id","context","disable_supervisor_interrupt","enable_supervisor_interrupt","enable_timer_interrupt","init","set_kernel_trap_entry","set_user_trap_entry","trap_from_kernel","trap_handler","trap_return","TrapContext","app_init_context","borrow","borrow_mut","fmt","from","into","kernel_satp","kernel_sp","sepc","set_sp","sstatus","trap_handler","try_from","try_into","type_id","x"],"q":["os","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::board","","","","","","","","os::config","","","","","","","","os::console","","","","","","","","","","","","","","","","","","","","os::drivers","","","os::drivers::block","","","","","","","","","","","","os::drivers::block::virtio_blk","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::drivers::chardev","","","","","","","","","","","","","","","os::drivers::chardev::ns16550a","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::drivers::plic","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::fs","","","","","","","","os::fs::inode","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::fs::pipe","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::fs::stdio","","","","","","","","","","","","","","","","","","","","","","","","os::lang_items","","os::mm","","","","","","os::mm::address","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::mm::frame_allocator","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::mm::heap_allocator","","","","","os::mm::memory_set","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::mm::page_table","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::sbi","","","","","","","","","","","","","","os::sync","","","","os::sync::condvar","","","","","","","","","","","","","","","","","","","","","","os::sync::mutex","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::sync::semaphore","","","","","","","","","","","","","","","","","","","","","","os::sync::up","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::syscall","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::syscall::fs","","","","","","os::syscall::process","","","","","","","","os::syscall::sync","","","","","","","","","","os::syscall::thread","","","os::task","","","","","","","","","","","","","","","","","","","","","","","","","os::task::context","","","","","","","","","","","","","os::task::id","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::task::manager","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::task::process","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::task::processor","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::task::signal","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::task::switch","os::task::task","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::timer","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","os::trap","","","","","","","","","","os::trap::context","","","","","","","","","","","","","","","",""],"d":["","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","InterruptEnableRegister","LineStatusRegister","Model Control Register","","","","","","","","","","ignore FCR","ignore MSR","ignore other registers","ignore SCR","Returns the set containing all flags.","Returns the set containing all flags.","Returns the set containing all flags.","","Returns the intersection between the two sets of flags.","Returns the intersection between the two sets of flags.","Returns the intersection between the two sets of flags.","Disables all flags disabled in the set.","Disables all flags disabled in the set.","Disables all flags disabled in the set.","Returns the union of the two sets of flags.","Returns the union of the two sets of flags.","Returns the union of the two sets of flags.","Adds the set of flags.","Adds the set of flags.","Adds the set of flags.","Returns the raw value of the flags currently stored.","Returns the raw value of the flags currently stored.","Returns the raw value of the flags currently stored.","","","","Returns the left flags, but with all the right flags …","Returns the left flags, but with all the right flags …","Returns the left flags, but with all the right flags …","Toggles the set of flags.","Toggles the set of flags.","Toggles the set of flags.","","","","","","","","","","","","","","","","","","","","","","","","","","Returns the complement of this set of flags.","Returns the complement of this set of flags.","Returns the complement of this set of flags.","","Returns true if all of the flags in other are contained …","Returns true if all of the flags in other are contained …","Returns true if all of the flags in other are contained …","Returns the difference between the flags in self and other.","Returns the difference between the flags in self and other.","Returns the difference between the flags in self and other.","Returns an empty set of flags.","Returns an empty set of flags.","Returns an empty set of flags.","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Convert from underlying bit representation, unless that …","Convert from underlying bit representation, unless that …","Convert from underlying bit representation, unless that …","Convert from underlying bit representation, dropping any …","Convert from underlying bit representation, dropping any …","Convert from underlying bit representation, dropping any …","Convert from underlying bit representation, preserving all …","Convert from underlying bit representation, preserving all …","Convert from underlying bit representation, preserving all …","","","","","","","","interrupt enable register","interrupt enable register","interrupt identification register","","","Inserts the specified flags in-place.","Inserts the specified flags in-place.","Inserts the specified flags in-place.","Returns the intersection between the flags in self and …","Returns the intersection between the flags in self and …","Returns the intersection between the flags in self and …","Returns true if there are flags common to both self and …","Returns true if there are flags common to both self and …","Returns true if there are flags common to both self and …","","","","","","","","","Returns true if all flags are currently set.","Returns true if all flags are currently set.","Returns true if all flags are currently set.","Returns true if no flags are currently stored.","Returns true if no flags are currently stored.","Returns true if no flags are currently stored.","line control register","line control register","line status register","line status register","model control register","modem control register","","","","","","Returns the complement of this set of flags.","Returns the complement of this set of flags.","Returns the complement of this set of flags.","","","","","receiver buffer register","","","","","Removes the specified flags in-place.","Removes the specified flags in-place.","Removes the specified flags in-place.","Inserts or removes the specified flags depending on the …","Inserts or removes the specified flags depending on the …","Inserts or removes the specified flags depending on the …","Returns the set difference of the two sets of flags.","Returns the set difference of the two sets of flags.","Returns the set difference of the two sets of flags.","Disables all flags enabled in the set.","Disables all flags enabled in the set.","Disables all flags enabled in the set.","Returns the symmetric difference between the flags in self …","Returns the symmetric difference between the flags in self …","Returns the symmetric difference between the flags in self …","transmitter holding register","","","","Toggles the specified flags in-place.","Toggles the specified flags in-place.","Toggles the specified flags in-place.","","","","","","","","","","","","","","","","","","","","","","","","","Returns the union of between the flags in self and other.","Returns the union of between the flags in self and other.","Returns the union of between the flags in self and other.","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Returns the set containing all flags.","Returns the intersection between the two sets of flags.","Disables all flags disabled in the set.","Returns the union of the two sets of flags.","Adds the set of flags.","Returns the raw value of the flags currently stored.","","Returns the left flags, but with all the right flags …","Toggles the set of flags.","","","","","","","","","","","","Returns the complement of this set of flags.","Returns true if all of the flags in other are contained …","","Returns the difference between the flags in self and other.","Returns an empty set of flags.","","","","","","","","","","","","Convert from underlying bit representation, unless that …","Convert from underlying bit representation, dropping any …","Convert from underlying bit representation, preserving all …","","","","","Inserts the specified flags in-place.","Returns the intersection between the flags in self and …","Returns true if there are flags common to both self and …","","","","","Returns true if all flags are currently set.","Returns true if no flags are currently stored.","","","","Returns the complement of this set of flags.","","","","","","Do not check validity for simplicity Return (readable, …","","","Removes the specified flags in-place.","Inserts or removes the specified flags depending on the …","Returns the set difference of the two sets of flags.","Disables all flags enabled in the set.","Returns the symmetric difference between the flags in self …","","Toggles the specified flags in-place.","","","","","","","","","","","","","Returns the union of between the flags in self and other.","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Return (read_end, write_end)","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Definitions","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Returns the set containing all flags.","","Returns the intersection between the two sets of flags.","Disables all flags disabled in the set.","Returns the union of the two sets of flags.","Adds the set of flags.","Returns the raw value of the flags currently stored.","","Returns the left flags, but with all the right flags …","Toggles the set of flags.","","","","","","","","","","","","","","","","Returns the complement of this set of flags.","Returns true if all of the flags in other are contained …","data: start-aligned but maybe with shorter length assume …","","","Returns the difference between the flags in self and other.","","","","Returns an empty set of flags.","","","","","","","","","","","","","","","","","","Convert from underlying bit representation, unless that …","Convert from underlying bit representation, dropping any …","Convert from underlying bit representation, preserving all …","Include sections in elf and trampoline, also returns …","","","","Inserts the specified flags in-place.","Assume that no conflicts.","Returns the intersection between the flags in self and …","Returns true if there are flags common to both self and …","","","","","","Returns true if all flags are currently set.","Returns true if no flags are currently stored.","","","","","Mention that trampoline is not collected by areas.","","","","","Without kernel stacks.","Returns the complement of this set of flags.","","","","","","Removes the specified flags in-place.","","","","Inserts or removes the specified flags depending on the …","","","","Returns the set difference of the two sets of flags.","Disables all flags enabled in the set.","Returns the symmetric difference between the flags in self …","","","Toggles the specified flags in-place.","","","","","","","","","","","","","","","","","","Returns the union of between the flags in self and other.","","","","","","","","","","","","","","","","","Returns the set containing all flags.","Returns the intersection between the two sets of flags.","Disables all flags disabled in the set.","Returns the union of the two sets of flags.","Adds the set of flags.","Returns the raw value of the flags currently stored.","","","Returns the left flags, but with all the right flags …","Toggles the set of flags.","","","","","","","","","","","","","","","","","","Returns the complement of this set of flags.","Returns true if all of the flags in other are contained …","","","Returns the difference between the flags in self and other.","Returns an empty set of flags.","","","","","","","","","","","","","","","","","","","Convert from underlying bit representation, unless that …","Convert from underlying bit representation, dropping any …","Convert from underlying bit representation, preserving all …","","Temporarily used to get arguments from user space.","","Inserts the specified flags in-place.","Returns the intersection between the flags in self and …","Returns true if there are flags common to both self and …","","","","","","","","Returns true if all flags are currently set.","Returns true if no flags are currently stored.","","","","","","","","","Returns the complement of this set of flags.","","","","Removes the specified flags in-place.","","Inserts or removes the specified flags depending on the …","Returns the set difference of the two sets of flags.","Disables all flags enabled in the set.","Returns the symmetric difference between the flags in self …","","","Toggles the specified flags in-place.","","","","","","","Load a string from other address spaces into kernel space …","","","","","","","","","","","","","","","","Returns the union of between the flags in self and other.","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Panic if the data has been borrowed.","","","","","","","","","","inner data","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","If there is not a child process whose pid is same as …","","","","","","","","","","","","","","thread does not exist, return -1 thread has not exited …","","","","","This function must be followed by a schedule","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Return (bottom, top) of a kernel stack in kernel space.","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Only support processes with a single thread.","","","Only support processes with a single thread.","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Returns the set containing all flags.","Returns the intersection between the two sets of flags.","Disables all flags disabled in the set.","Returns the union of the two sets of flags.","Adds the set of flags.","Returns the raw value of the flags currently stored.","","Returns the left flags, but with all the right flags …","Toggles the set of flags.","","","","","","","Returns the complement of this set of flags.","Returns true if all of the flags in other are contained …","Returns the difference between the flags in self and other.","Returns an empty set of flags.","","","","","","","","","Convert from underlying bit representation, unless that …","Convert from underlying bit representation, dropping any …","Convert from underlying bit representation, preserving all …","","","Inserts the specified flags in-place.","Returns the intersection between the flags in self and …","Returns true if there are flags common to both self and …","","Returns true if all flags are currently set.","Returns true if no flags are currently stored.","","Returns the complement of this set of flags.","","Removes the specified flags in-place.","Inserts or removes the specified flags depending on the …","Returns the set difference of the two sets of flags.","Disables all flags enabled in the set.","Returns the symmetric difference between the flags in self …","","Toggles the specified flags in-place.","","","","Returns the union of between the flags in self and other.","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","",""],"i":[0,1,0,1,1,0,0,0,1,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,2,3,2,3,2,3,0,0,2,3,2,3,2,3,2,3,0,0,0,0,4,0,4,4,4,4,4,4,4,4,0,0,0,0,5,6,5,6,5,6,5,6,5,6,6,5,6,6,6,5,6,5,6,5,6,0,0,0,0,6,0,0,7,7,7,7,7,8,7,0,8,7,7,7,8,9,9,10,9,0,0,0,0,0,0,9,11,0,10,11,0,12,13,12,13,11,10,9,14,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,13,12,14,15,16,11,10,9,13,12,14,15,16,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,16,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,11,11,11,11,11,10,10,10,10,10,9,9,9,9,9,13,12,14,15,16,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,16,11,10,9,13,12,13,14,16,11,10,9,11,10,9,11,10,9,13,12,14,15,16,11,10,9,11,10,9,11,10,9,13,12,13,12,13,12,11,10,9,14,16,11,10,9,15,11,10,9,13,14,16,15,14,11,10,9,11,10,9,11,10,9,11,10,9,11,10,9,12,11,10,9,11,10,9,13,12,14,15,16,11,10,9,13,12,14,15,16,11,10,9,13,12,14,15,16,11,10,9,11,10,9,14,16,14,0,17,0,17,18,18,17,18,17,18,18,17,17,18,18,18,18,18,17,18,18,18,18,17,18,18,18,18,17,18,17,18,17,18,17,18,17,0,0,0,19,19,0,19,19,20,0,0,0,20,20,0,20,20,21,20,20,20,20,20,20,20,20,20,22,23,21,20,22,23,21,20,20,20,20,20,20,21,20,20,20,20,20,20,20,20,20,22,23,21,20,20,20,20,20,20,22,23,20,20,20,22,23,21,20,20,20,0,20,22,20,23,0,20,22,22,20,22,22,20,20,20,20,20,20,20,22,23,21,20,22,23,21,20,22,23,21,20,20,22,22,22,24,24,24,0,0,0,0,25,25,25,25,26,25,24,26,25,24,26,24,24,24,26,25,24,25,26,25,24,0,25,26,25,26,26,26,25,25,25,24,26,25,24,26,25,24,26,25,24,26,26,26,25,25,26,0,0,27,28,27,28,27,28,27,28,27,28,27,28,27,28,27,28,27,28,27,28,27,28,0,0,0,0,0,0,0,0,29,30,31,32,0,0,0,0,0,0,0,0,0,0,0,0,29,30,33,29,30,31,32,34,33,29,30,31,32,34,29,30,29,30,31,32,34,29,30,31,32,34,29,30,31,32,33,33,29,30,31,32,29,30,29,30,31,32,33,29,29,29,30,30,30,31,31,31,32,32,32,34,31,34,29,31,31,29,34,32,33,29,30,31,32,34,33,34,34,29,30,31,32,33,34,33,29,30,29,30,31,32,34,35,31,32,29,30,31,32,34,33,29,30,31,32,34,33,29,30,31,32,34,33,29,30,31,32,34,0,0,0,0,0,36,37,38,39,38,36,39,38,36,38,37,38,36,39,38,39,0,0,0,39,38,36,38,0,39,38,36,37,39,38,39,38,39,38,36,39,38,36,39,38,36,0,0,0,0,0,40,40,0,0,0,0,0,41,41,41,41,42,43,41,43,41,41,41,41,41,41,41,41,43,44,42,40,41,43,44,42,40,41,40,41,40,41,41,41,41,44,44,42,41,0,0,0,41,40,41,0,0,41,40,41,41,41,41,41,43,44,42,40,41,44,41,41,41,43,43,41,41,41,43,41,41,43,44,42,40,41,41,41,0,44,44,44,43,44,41,44,43,43,41,43,41,43,43,0,41,43,0,0,41,0,0,0,41,41,41,40,41,41,43,43,43,44,42,40,41,43,44,42,40,41,43,44,42,40,41,41,44,44,44,45,45,45,0,0,0,45,45,0,0,45,45,45,45,45,45,45,45,45,45,46,45,45,47,48,49,45,46,47,48,49,45,46,48,49,45,46,45,46,45,45,45,49,49,45,45,46,45,46,45,47,47,46,45,45,45,45,45,47,47,48,49,45,46,45,45,45,45,47,45,45,45,45,47,48,49,45,46,48,49,45,45,46,48,47,45,47,48,46,49,45,45,46,46,45,47,45,45,45,45,45,46,45,47,47,47,0,0,0,0,47,48,49,45,46,47,48,49,45,46,47,48,49,45,46,45,47,46,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,50,51,50,51,50,51,50,50,51,50,50,50,51,50,51,50,51,50,51,50,0,0,0,0,52,53,54,52,53,54,52,53,54,53,52,53,54,55,52,53,52,54,52,53,52,53,54,52,53,54,52,53,54,55,52,53,54,0,0,56,57,56,57,57,56,56,57,56,56,57,56,56,57,56,57,56,57,56,57,58,0,0,0,0,0,59,60,61,62,58,59,60,61,62,58,59,58,59,58,58,61,62,62,61,60,61,62,58,59,60,60,62,60,61,62,58,59,61,60,61,62,61,60,61,62,58,59,60,61,62,58,59,60,61,62,58,59,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,63,0,0,0,63,63,0,0,0,63,0,63,0,63,0,0,0,0,0,0,0,63,63,63,0,64,64,64,64,64,64,64,64,64,64,64,64,65,66,0,0,0,0,0,0,67,68,69,70,70,69,65,66,70,67,68,69,65,66,70,67,68,69,69,70,70,67,68,65,66,70,69,65,66,70,67,68,66,69,65,66,70,67,68,0,0,69,70,0,70,66,69,70,0,70,70,69,65,66,70,67,68,69,65,66,70,67,68,69,65,66,70,67,68,70,70,0,70,0,0,0,71,72,73,0,73,71,72,73,71,72,71,72,73,0,73,71,72,0,73,71,72,73,0,73,0,73,71,72,73,71,72,73,71,72,0,0,74,74,75,74,75,74,74,74,74,75,74,74,75,75,74,74,74,75,75,75,75,74,74,74,74,75,74,75,74,74,74,74,74,75,74,75,74,75,74,0,0,76,77,76,77,76,77,77,0,0,0,0,0,0,76,77,76,77,77,77,76,77,0,0,77,0,77,76,77,76,77,76,78,78,78,78,78,0,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,78,0,79,79,79,0,0,0,80,81,79,80,81,79,79,79,79,81,80,81,79,81,81,80,80,80,80,81,79,80,80,80,81,81,81,79,81,80,81,79,80,81,79,80,81,79,0,0,0,0,82,0,83,82,83,82,0,83,82,83,83,83,82,0,0,83,82,83,0,83,83,82,83,82,83,82,0,0,0,0,0,0,0,0,0,0,0,84,84,84,84,84,84,84,84,84,84,84,84,84,84,84,84],"f":[null,null,null,[[]],[[]],[[]],null,null,[[],["upintrfreecell",3]],null,[[]],null,[[]],null,null,null,null,null,null,[[],["never",15]],null,null,null,null,null,null,[[],["result",4]],[[],["result",4]],[[],["typeid",3]],null,null,null,null,null,null,[[]],[[]],null,null,null,null,null,null,null,null,null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[["arguments",3]]],[[["arguments",3]]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[["str",15]],["result",6]],[[["str",15]],["result",6]],null,null,null,null,null,[[]],[[]],[[]],[[],["arc",3]],[[]],[[]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],null,null,null,null,null,[[]],[[]],[[]],[[]],null,[[],["upintrfreecell",3]],[[]],[[]],[[]],[[]],[[]],[[]],[[["usize",15]]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],null,[[["usize",15]],["physaddr",3]],[[["physaddr",3],["usize",15]],["i32",15]],[[["physaddr",3]],["virtaddr",3]],[[["virtaddr",3]],["physaddr",3]],[[["usize",15]]],null,null,null,[[]],[[]],[[],["arc",3]],[[]],[[]],[[]],null,[[],["u8",15]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[["u8",15]]],null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,[[]],[[]],[[]],null,[[]],[[]],[[]],[[]],[[]],[[]],[[["ier",3]]],[[["lsr",3]]],[[["mcr",3]]],[[]],[[]],[[]],[[],["u8",15]],[[],["u8",15]],[[],["u8",15]],null,null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["ier",3]],[[],["lsr",3]],[[],["mcr",3]],[[]],[[]],[[]],[[["ier",3]],["ordering",4]],[[["lsr",3]],["ordering",4]],[[["mcr",3]],["ordering",4]],[[]],[[]],[[]],null,[[],["bool",15]],[[],["bool",15]],[[],["bool",15]],[[]],[[]],[[]],[[]],[[]],[[]],[[["ier",3]],["bool",15]],[[["lsr",3]],["bool",15]],[[["mcr",3]],["bool",15]],[[["intoiterator",8]]],[[["intoiterator",8]]],[[["intoiterator",8]]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[["u8",15]],["option",4]],[[["u8",15]],["option",4]],[[["u8",15]],["option",4]],[[["u8",15]]],[[["u8",15]]],[[["u8",15]]],[[["u8",15]]],[[["u8",15]]],[[["u8",15]]],[[["intoiterator",8]]],[[["intoiterator",8]]],[[["intoiterator",8]]],[[]],[[]],[[]],[[]],null,null,null,[[]],null,[[]],[[]],[[]],[[]],[[]],[[]],[[],["bool",15]],[[],["bool",15]],[[],["bool",15]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["bool",15]],[[],["bool",15]],[[],["bool",15]],[[],["bool",15]],[[],["bool",15]],[[],["bool",15]],null,null,null,null,null,null,[[["ier",3]],["bool",15]],[[["lsr",3]],["bool",15]],[[["mcr",3]],["bool",15]],[[["usize",15]]],[[]],[[]],[[]],[[]],null,[[["ier",3]],["option",4,[["ordering",4]]]],[[["lsr",3]],["option",4,[["ordering",4]]]],[[["mcr",3]],["option",4,[["ordering",4]]]],null,[[],["option",4,[["u8",15]]]],[[],["u8",15]],null,[[],["readwithoutdlab",3]],[[]],[[]],[[]],[[["bool",15]]],[[["bool",15]]],[[["bool",15]]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],null,[[]],[[]],[[]],[[]],[[]],[[]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[]],[[]],[[]],[[["u8",15]]],[[["u8",15]]],[[],["writewithoutdlab",3]],null,null,null,null,null,[[]],[[]],[[]],[[]],[[["usize",15],["intrtargetpriority",4]],["u32",15]],[[["usize",15],["intrtargetpriority",4]]],[[],["intrtargetpriority",4]],[[]],[[["usize",15],["intrtargetpriority",4],["u32",15]]],[[["usize",15],["intrtargetpriority",4],["usize",15]]],[[["usize",15],["intrtargetpriority",4],["usize",15]]],[[["usize",15],["intrtargetpriority",4],["usize",15]]],[[]],[[]],[[["usize",15]],["u32",15]],[[["usize",15],["intrtargetpriority",4]],["u32",15]],[[["usize",15],["intrtargetpriority",4]],["usize",15]],[[]],[[]],[[["usize",15]]],[[["usize",15]]],[[["usize",15],["u32",15]]],[[["usize",15],["intrtargetpriority",4],["u32",15]]],[[],["usize",15]],[[["usize",15],["intrtargetpriority",4]]],[[]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],null,null,null,[[["userbuffer",3]],["usize",15]],[[],["bool",15]],null,[[],["bool",15]],[[["userbuffer",3]],["usize",15]],null,null,null,null,null,null,null,null,null,null,[[]],[[]],[[]],[[["openflags",3]]],[[]],[[],["u32",15]],null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["openflags",3]],[[]],[[["openflags",3]],["ordering",4]],[[]],[[],["bool",15]],[[],["arc",3]],[[]],[[]],[[["openflags",3]],["bool",15]],[[["intoiterator",8]]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[]],[[]],[[]],[[]],[[["u32",15]],["option",4]],[[["u32",15]]],[[["u32",15]]],[[["intoiterator",8]]],[[]],null,null,[[]],[[]],[[],["bool",15]],[[]],[[]],[[]],[[]],[[],["bool",15]],[[],["bool",15]],[[]],[[["openflags",3]],["bool",15]],[[["bool",15],["bool",15],["arc",3,[["inode",3]]]]],[[]],null,[[["str",15],["openflags",3]],["option",4,[["arc",3,[["osinode",3]]]]]],[[["openflags",3]],["option",4,[["ordering",4]]]],[[["userbuffer",3]],["usize",15]],[[],["vec",3,[["u8",15]]]],[[]],[[],["bool",15]],null,[[]],[[["bool",15]]],[[]],[[]],[[]],[[]],[[]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[]],[[],["bool",15]],null,[[["userbuffer",3]],["usize",15]],null,null,null,null,null,null,null,[[],["bool",15]],null,[[],["usize",15]],[[],["usize",15]],[[]],[[]],[[]],[[]],[[]],[[]],null,[[],["ringbufferstatus",4]],[[]],[[["ringbufferstatus",4]],["bool",15]],[[]],[[]],[[]],null,[[]],[[]],[[]],[[]],[[]],[[["userbuffer",3]],["usize",15]],[[],["u8",15]],[[["arc",3,[["upintrfreecell",3,[["piperingbuffer",3]]]]]]],[[],["bool",15]],null,[[["arc",3]]],null,null,[[]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["bool",15]],null,[[["userbuffer",3]],["usize",15]],[[["u8",15]]],null,[[["arc",3,[["upintrfreecell",3,[["piperingbuffer",3]]]]]]],null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[["userbuffer",3]],["usize",15]],[[["userbuffer",3]],["usize",15]],[[],["bool",15]],[[],["bool",15]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["bool",15]],[[],["bool",15]],[[["userbuffer",3]],["usize",15]],[[["userbuffer",3]],["usize",15]],[[]],[[["panicinfo",3]],["never",15]],null,null,null,[[]],null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,[[],["bool",15]],[[],["bool",15]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["physpagenum",3]],[[],["virtpagenum",3]],[[],["physaddr",3]],[[],["virtaddr",3]],[[],["physpagenum",3]],[[],["virtpagenum",3]],[[],["simplerange",3]],[[]],[[]],[[]],[[]],[[]],[[["physaddr",3]],["ordering",4]],[[["virtaddr",3]],["ordering",4]],[[["physpagenum",3]],["ordering",4]],[[["virtpagenum",3]],["ordering",4]],null,null,[[["physaddr",3]],["bool",15]],[[["virtaddr",3]],["bool",15]],[[["physpagenum",3]],["bool",15]],[[["virtpagenum",3]],["bool",15]],[[],["physpagenum",3]],[[],["virtpagenum",3]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[]],[[]],[[["usize",15]]],[[["physpagenum",3]]],[[["usize",15]]],[[]],[[["virtpagenum",3]]],[[["usize",15]]],[[]],[[["physaddr",3]]],[[["virtaddr",3]]],[[["usize",15]]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],null,[[["physaddr",3]],["bool",15]],[[["virtaddr",3]],["bool",15]],[[["physpagenum",3]],["bool",15]],[[["virtpagenum",3]],["bool",15]],[[]],[[]],[[],["option",4]],[[],["usize",15]],[[],["usize",15]],[[["physaddr",3]],["option",4,[["ordering",4]]]],[[["virtaddr",3]],["option",4,[["ordering",4]]]],[[["physpagenum",3]],["option",4,[["ordering",4]]]],[[["virtpagenum",3]],["option",4,[["ordering",4]]]],null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],null,null,null,null,null,null,[[],["option",4,[["physpagenum",3]]]],[[],["option",4,[["physpagenum",3]]]],[[]],[[]],[[]],[[]],[[]],[[]],null,[[["physpagenum",3]]],[[["physpagenum",3]]],[[],["upintrfreecell",3]],[[]],null,[[["formatter",3]],["result",6]],[[],["option",4,[["frametracker",3]]]],[[]],[[["physpagenum",3]]],[[]],[[]],[[]],[[["physpagenum",3],["physpagenum",3]]],[[]],[[]],[[]],[[]],[[]],[[["physpagenum",3]]],[[]],null,null,[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],null,null,[[["layout",3]],["never",15]],[[]],[[]],null,null,null,null,null,null,null,null,null,null,null,null,[[]],[[]],null,[[]],[[]],[[["mappermission",3]]],[[]],[[],["u8",15]],null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["maptype",4]],[[],["mappermission",3]],[[]],[[]],[[["mappermission",3]],["ordering",4]],[[]],[[],["bool",15]],[[["pagetable",3]]],null,[[],["arc",3]],[[]],null,null,null,[[]],[[["maptype",4]],["bool",15]],[[["mappermission",3]],["bool",15]],null,null,[[["intoiterator",8]]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[]],[[]],[[]],[[]],[[]],[[["maparea",3]]],[[["u8",15]],["option",4]],[[["u8",15]]],[[["u8",15]]],[[]],[[["memoryset",3]],["memoryset",3]],[[["intoiterator",8]]],[[]],[[]],[[["virtaddr",3],["virtaddr",3],["mappermission",3]]],[[]],[[],["bool",15]],[[]],[[]],[[]],[[]],[[]],[[],["bool",15]],[[],["bool",15]],[[],["usize",15]],[[["pagetable",3]]],[[["pagetable",3],["virtpagenum",3]]],null,[[]],null,[[["mappermission",3]],["bool",15]],[[["virtaddr",3],["virtaddr",3],["maptype",4],["mappermission",3]]],[[]],[[]],[[]],null,[[["mappermission",3]],["option",4,[["ordering",4]]]],[[["maparea",3],["option",4]]],[[]],[[]],[[]],[[["virtpagenum",3]]],null,null,[[["bool",15]]],null,null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[],["usize",15]],[[["virtpagenum",3]],["option",4,[["pagetableentry",3]]]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[]],[[["pagetable",3]]],[[["pagetable",3],["virtpagenum",3]]],null,null,null,null,null,null,null,null,null,null,null,null,null,null,[[]],[[]],[[]],[[["pteflags",3]]],[[]],[[],["u8",15]],null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],null,null,[[],["pteflags",3]],[[],["pagetableentry",3]],[[]],[[]],[[["pteflags",3]],["ordering",4]],[[]],[[],["bool",15]],null,null,[[]],[[]],[[]],[[["pteflags",3]],["bool",15]],[[],["bool",15]],[[["intoiterator",8]]],[[["virtpagenum",3]],["option",4,[["pagetableentry",3]]]],[[["virtpagenum",3]],["option",4,[["pagetableentry",3]]]],[[],["pteflags",3]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],null,[[]],[[]],[[]],[[]],[[]],[[["u8",15]],["option",4]],[[["u8",15]]],[[["u8",15]]],[[["intoiterator",8]]],[[["usize",15]]],[[]],[[]],[[]],[[],["bool",15]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["bool",15]],[[],["bool",15]],[[],["bool",15]],[[],["usize",15]],[[["virtpagenum",3],["physpagenum",3],["pteflags",3]]],[[["pteflags",3]],["bool",15]],[[]],[[["vec",3]]],[[["physpagenum",3],["pteflags",3]]],[[],["option",4]],[[]],[[["pteflags",3]],["option",4,[["ordering",4]]]],[[],["physpagenum",3]],[[],["bool",15]],[[]],null,[[["bool",15]]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["usize",15]],[[["virtpagenum",3]],["option",4,[["pagetableentry",3]]]],[[["virtaddr",3]],["option",4,[["physaddr",3]]]],[[["usize",15],["usize",15]],["vec",3]],[[["usize",15]]],[[["usize",15]]],[[["usize",15]],["string",3]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[]],[[["virtpagenum",3]]],[[],["bool",15]],null,null,null,null,null,null,null,null,null,[[],["usize",15]],[[["usize",15]]],[[["usize",15],["usize",15],["usize",15],["usize",15]],["usize",15]],[[["usize",15]]],[[],["never",15]],null,null,null,null,null,null,[[]],[[]],[[]],[[]],[[]],[[]],null,[[]],[[]],[[]],[[]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[]],null,[[["arc",3,[["mutex",8]]]]],null,null,null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],null,[[]],[[]],[[]],[[]],[[]],[[]],null,null,[[]],[[]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[]],[[]],[[]],null,null,null,[[]],[[]],[[]],[[]],null,[[]],[[]],[[]],null,[[]],[[]],[[["usize",15]]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[]],null,null,null,null,null,null,null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["upsafecellraw",3]],[[]],[[]],[[]],[[],["upintrrefmut",3]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],null,null,[[]],[[]],[[]],[[]],[[]],null,[[]],[[]],[[]],null,[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,null,[[["usize",15]],["str",15]],[[["usize",15]],["isize",15]],null,[[["usize",15]],["isize",15]],[[["usize",15]],["isize",15]],[[["u32",15]],["isize",15]],[[],["isize",15]],[[["usize",15],["usize",15]],["isize",15]],[[["usize",15],["usize",15]],["isize",15]],[[],["isize",15]],[[["i32",15]],["never",15]],[[],["isize",15]],[[],["isize",15]],[[],["isize",15]],[[["usize",15],["u32",15]],["isize",15]],[[["isize",15]],["isize",15]],[[],["isize",15]],[[["usize",15]],["isize",15]],[[["usize",15]],["isize",15]],[[["usize",15],["usize",15]],["isize",15]],[[["bool",15]],["isize",15]],[[["usize",15]],["isize",15]],[[["usize",15]],["isize",15]],[[["usize",15]],["isize",15]],[[["usize",15]],["isize",15]],[[["usize",15]],["isize",15]],[[["usize",15]],["isize",15]],[[],["isize",15]],[[["usize",15],["usize",15]],["isize",15]],[[["usize",15]],["i32",15]],null,null,[[]],[[]],[[]],[[]],[[]],[[],["option",4]],null,[[["signalflags",3]]],[[],["arc",3]],[[["i32",15]]],[[]],null,[[]],null,null,null,null,[[]],null,null,[[],["result",4]],[[],["result",4]],[[],["typeid",3]],null,[[]],[[]],[[]],[[["usize",15]]],[[]],null,null,null,[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[]],null,null,null,null,null,null,null,null,null,null,[[],["usize",15]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],null,[[["usize",15]]],[[]],[[]],[[],["upintrfreecell",3]],[[],["upintrfreecell",3]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["usize",15]],[[]],[[]],[[]],[[]],[[]],[[]],[[["usize",15]]],[[],["kernelstack",3]],[[]],[[["arc",3,[["processcontrolblock",3]]],["usize",15],["bool",15]]],[[],["pidhandle",3]],null,[[]],null,null,[[["usize",15]],["usize",15]],[[],["physpagenum",3]],[[],["usize",15]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],[[],["usize",15]],null,[[["usize",15],["usize",15]],["usize",15]],[[],["usize",15]],null,null,null,null,null,[[["arc",3,[["taskcontrolblock",3]]]]],[[["arc",3,[["taskcontrolblock",3]]]]],[[]],[[]],[[]],[[]],[[]],[[]],[[],["upintrfreecell",3]],[[],["upintrfreecell",3]],[[],["option",4,[["arc",3,[["taskcontrolblock",3]]]]]],[[],["option",4,[["arc",3,[["taskcontrolblock",3]]]]]],[[]],[[]],[[]],[[["usize",15],["arc",3,[["processcontrolblock",3]]]]],[[]],[[]],[[]],[[]],[[["usize",15]],["option",4,[["arc",3,[["processcontrolblock",3]]]]]],null,[[["usize",15]]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],null,null,[[],["usize",15]],[[],["usize",15]],[[]],[[]],[[]],[[]],null,null,[[["usize",15]]],[[["arc",3],["vec",3,[["string",3]]]]],null,null,[[["arc",3]],["arc",3]],[[]],[[]],[[["usize",15]],["arc",3,[["taskcontrolblock",3]]]],[[],["usize",15]],[[],["usize",15]],null,[[],["upintrrefmut",3,[["processcontrolblockinner",3]]]],[[]],[[]],null,null,null,[[],["arc",3]],null,null,null,null,null,null,[[],["usize",15]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],null,null,null,[[]],[[]],[[]],[[]],[[],["option",4,[["arc",3,[["taskcontrolblock",3]]]]]],null,[[],["usize",15]],[[],["arc",3,[["processcontrolblock",3]]]],[[],["option",4,[["arc",3,[["taskcontrolblock",3]]]]]],[[],["trapcontext",3]],[[],["usize",15]],[[],["usize",15]],[[],["upintrfreecell",3]],[[]],[[]],[[]],null,[[]],[[]],[[]],[[]],[[]],[[],["option",4,[["arc",3,[["taskcontrolblock",3]]]]]],[[],["option",4,[["arc",3,[["taskcontrolblock",3]]]]]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],null,null,null,null,null,null,[[]],[[]],[[]],[[["signalflags",3]]],[[]],[[],["u32",15]],null,[[]],[[]],[[]],[[]],[[],["option",4]],[[],["signalflags",3]],[[]],[[["signalflags",3]],["ordering",4]],[[]],[[],["bool",15]],[[]],[[]],[[["signalflags",3]],["bool",15]],[[["intoiterator",8]]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[["formatter",3]],["result",6]],[[]],[[["u32",15]],["option",4]],[[["u32",15]]],[[["u32",15]]],[[["intoiterator",8]]],[[]],[[]],[[]],[[],["bool",15]],[[]],[[],["bool",15]],[[],["bool",15]],[[["signalflags",3]],["bool",15]],[[]],[[["signalflags",3]],["option",4,[["ordering",4]]]],[[]],[[["bool",15]]],[[]],[[]],[[]],[[]],[[]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[]],null,null,null,null,null,null,null,[[]],[[]],[[]],[[]],[[]],[[]],[[],["taskstatus",4]],[[]],[[["taskstatus",4]],["bool",15]],null,[[]],[[]],[[]],[[],["taskstatus",4]],[[],["trapcontext",3]],[[],["usize",15]],null,[[],["upintrrefmut",3,[["taskcontrolblockinner",3]]]],[[]],[[]],[[]],null,[[["arc",3,[["processcontrolblock",3]]],["usize",15],["bool",15]]],null,null,null,null,[[]],null,[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],[[],["typeid",3]],null,null,null,null,null,[[["usize",15],["arc",3,[["taskcontrolblock",3]]]]],[[]],[[]],[[]],[[]],[[]],[[],["ordering",4]],[[],["upintrfreecell",3]],[[],["bool",15]],null,[[]],[[]],[[],["usize",15]],[[],["usize",15]],[[]],[[]],[[],["option",4,[["ordering",4]]]],[[]],null,[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["result",4]],[[],["typeid",3]],[[],["typeid",3]],null,[[]],[[]],[[]],[[]],[[]],[[]],[[["trapcontext",3]]],[[],["never",15]],[[],["never",15]],null,[[["usize",15],["usize",15],["usize",15],["usize",15],["usize",15]]],[[]],[[]],[[["formatter",3]],["result",6]],[[]],[[]],null,null,null,[[["usize",15]]],null,null,[[],["result",4]],[[],["result",4]],[[],["typeid",3]],null],"p":[[3,"DEV_NON_BLOCKING_ACCESS"],[3,"Stdout"],[3,"Kstdout"],[3,"BLOCK_DEVICE"],[3,"QUEUE_FRAMES"],[3,"VirtIOBlock"],[3,"UART"],[8,"CharDevice"],[3,"MCR"],[3,"LSR"],[3,"IER"],[3,"WriteWithoutDLAB"],[3,"ReadWithoutDLAB"],[3,"NS16550aRaw"],[3,"NS16550aInner"],[3,"NS16550a"],[4,"IntrTargetPriority"],[3,"PLIC"],[8,"File"],[3,"OpenFlags"],[3,"ROOT_INODE"],[3,"OSInode"],[3,"OSInodeInner"],[4,"RingBufferStatus"],[3,"PipeRingBuffer"],[3,"Pipe"],[3,"Stdin"],[3,"Stdout"],[3,"PhysAddr"],[3,"VirtAddr"],[3,"PhysPageNum"],[3,"VirtPageNum"],[3,"SimpleRangeIterator"],[3,"SimpleRange"],[8,"StepByOne"],[3,"FRAME_ALLOCATOR"],[8,"FrameAllocator"],[3,"StackFrameAllocator"],[3,"FrameTracker"],[4,"MapType"],[3,"MapPermission"],[3,"KERNEL_SPACE"],[3,"MemorySet"],[3,"MapArea"],[3,"PTEFlags"],[3,"PageTableEntry"],[3,"PageTable"],[3,"UserBuffer"],[3,"UserBufferIterator"],[3,"Condvar"],[3,"CondvarInner"],[3,"MutexSpin"],[3,"MutexBlocking"],[3,"MutexBlockingInner"],[8,"Mutex"],[3,"Semaphore"],[3,"SemaphoreInner"],[3,"UPIntrRefMut"],[3,"INTR_MASKING_INFO"],[3,"UPSafeCellRaw"],[3,"IntrMaskingInfo"],[3,"UPIntrFreeCell"],[3,"INITPROC"],[3,"TaskContext"],[3,"PidHandle"],[3,"KernelStack"],[3,"PID_ALLOCATOR"],[3,"KSTACK_ALLOCATOR"],[3,"RecycleAllocator"],[3,"TaskUserRes"],[3,"TASK_MANAGER"],[3,"PID2PCB"],[3,"TaskManager"],[3,"ProcessControlBlockInner"],[3,"ProcessControlBlock"],[3,"PROCESSOR"],[3,"Processor"],[3,"SignalFlags"],[4,"TaskStatus"],[3,"TaskControlBlock"],[3,"TaskControlBlockInner"],[3,"TIMERS"],[3,"TimerCondVar"],[3,"TrapContext"]]}\
+}');
+if (window.initSearch) {window.initSearch(searchIndex)};
\ No newline at end of file
diff --git a/ch9-log/search.js b/ch9-log/search.js
new file mode 100644
index 00000000..3aa50607
--- /dev/null
+++ b/ch9-log/search.js
@@ -0,0 +1,2 @@
+(function(){var itemTypes=["mod","externcrate","import","struct","enum","fn","type","static","trait","impl","tymethod","method","structfield","variant","macro","primitive","associatedtype","constant","associatedconstant","union","foreigntype","keyword","existential","attr","derive","traitalias",];var TY_PRIMITIVE=itemTypes.indexOf("primitive");var TY_KEYWORD=itemTypes.indexOf("keyword");function printTab(nb){if(nb===0||nb===1||nb===2){searchState.currentTab=nb}var nb_copy=nb;onEachLazy(document.getElementById("titles").childNodes,function(elem){if(nb_copy===0){addClass(elem,"selected")}else{removeClass(elem,"selected")}nb_copy-=1});onEachLazy(document.getElementById("results").childNodes,function(elem){if(nb===0){addClass(elem,"active")}else{removeClass(elem,"active")}nb-=1})}function removeEmptyStringsFromArray(x){for(var i=0,len=x.length;i-1){var obj=searchIndex[result.id];obj.lev=result.lev;var res=buildHrefAndPath(obj);obj.displayPath=pathSplitter(res[0]);obj.fullPath=obj.displayPath+obj.name;obj.fullPath+="|"+obj.ty;if(duplicates[obj.fullPath]){continue}duplicates[obj.fullPath]=true;obj.href=res[1];out.push(obj);if(out.length>=MAX_RESULTS){break}}}return out}function sortResults(results,isType){var ar=[];for(var entry in results){if(hasOwnPropertyRustdoc(results,entry)){var result=results[entry];result.word=searchWords[result.id];result.item=searchIndex[result.id]||{};ar.push(result)}}results=ar;if(results.length===0){return[]}results.sort(function(aaa,bbb){var a,b;a=(aaa.word!==val);b=(bbb.word!==val);if(a!==b){return a-b}a=(aaa.lev);b=(bbb.lev);if(a!==b){return a-b}a=(aaa.item.crate!==window.currentCrate);b=(bbb.item.crate!==window.currentCrate);if(a!==b){return a-b}a=aaa.word.length;b=bbb.word.length;if(a!==b){return a-b}a=aaa.word;b=bbb.word;if(a!==b){return(a>b?+1:-1)}a=(aaa.index<0);b=(bbb.index<0);if(a!==b){return a-b}a=aaa.index;b=bbb.index;if(a!==b){return a-b}if((aaa.item.ty===TY_PRIMITIVE&&bbb.item.ty!==TY_KEYWORD)||(aaa.item.ty===TY_KEYWORD&&bbb.item.ty!==TY_PRIMITIVE)){return-1}if((bbb.item.ty===TY_PRIMITIVE&&aaa.item.ty!==TY_PRIMITIVE)||(bbb.item.ty===TY_KEYWORD&&aaa.item.ty!==TY_KEYWORD)){return 1}a=(aaa.item.desc==="");b=(bbb.item.desc==="");if(a!==b){return a-b}a=aaa.item.ty;b=bbb.item.ty;if(a!==b){return a-b}a=aaa.item.path;b=bbb.item.path;if(a!==b){return(a>b?+1:-1)}return 0});for(var i=0,len=results.length;i"));return{name:val.substring(0,val.indexOf("<")),generics:values.split(/\s*,\s*/),}}return{name:val,generics:[],}}function checkGenerics(obj,val){var tmp_lev,elem_name;if(val.generics.length>0){if(obj.length>GENERICS_DATA&&obj[GENERICS_DATA].length>=val.generics.length){var elems=Object.create(null);var elength=obj[GENERICS_DATA].length;for(var x=0;xGENERICS_DATA&&obj[GENERICS_DATA].length>0){var elems=Object.create(null);len=obj[GENERICS_DATA].length;for(x=0;xGENERICS_DATA&&obj[GENERICS_DATA].length!==0){tmp_lev=checkGenerics(obj,val);if(tmp_lev<=MAX_LEV_DISTANCE){return tmp_lev}}}}else if(literalSearch){var found=false;if((!val.generics||val.generics.length===0)&&obj.length>GENERICS_DATA&&obj[GENERICS_DATA].length>0){found=obj[GENERICS_DATA].some(function(gen){return gen[NAME]===val.name})}return found?0:MAX_LEV_DISTANCE+1}lev_distance=Math.min(levenshtein(obj[NAME],val.name),lev_distance);if(lev_distance<=MAX_LEV_DISTANCE){lev_distance=Math.ceil((checkGenerics(obj,val)+lev_distance)/2)}if(obj.length>GENERICS_DATA&&obj[GENERICS_DATA].length>0){var olength=obj[GENERICS_DATA].length;for(x=0;x0){var length=obj.type[INPUTS_DATA].length;for(var i=0;iOUTPUT_DATA){var ret=obj.type[OUTPUT_DATA];if(typeof ret[0]==="string"){ret=[ret]}for(var x=0,len=ret.length;xlength){return MAX_LEV_DISTANCE+1}for(var i=0;ilength){break}var lev_total=0;var aborted=false;for(var x=0;xMAX_LEV_DISTANCE){aborted=true;break}lev_total+=lev}if(!aborted){ret_lev=Math.min(ret_lev,Math.round(lev_total/clength))}}return ret_lev}function typePassesFilter(filter,type){if(filter<=NO_TYPE_FILTER)return true;if(filter===type)return true;var name=itemTypes[type];switch(itemTypes[filter]){case"constant":return name==="associatedconstant";case"fn":return name==="method"||name==="tymethod";case"type":return name==="primitive"||name==="associatedtype";case"trait":return name==="traitalias"}return false}function createAliasFromItem(item){return{crate:item.crate,name:item.name,path:item.path,desc:item.desc,ty:item.ty,parent:item.parent,type:item.type,is_alias:true,}}function handleAliases(ret,query,filterCrates){var aliases=[];var crateAliases=[];if(filterCrates!==undefined){if(ALIASES[filterCrates]&&ALIASES[filterCrates][query.search]){var query_aliases=ALIASES[filterCrates][query.search];var len=query_aliases.length;for(var i=0;iMAX_RESULTS){ret.others.pop()}};onEach(aliases,pushFunc);onEach(crateAliases,pushFunc)}function addIntoResults(isExact,res,fullId,id,index,lev){if(lev===0||(!isExact&&lev<=MAX_LEV_DISTANCE)){if(res[fullId]!==undefined){var result=res[fullId];if(result.dontValidate||result.lev<=lev){return}}res[fullId]={id:id,index:index,dontValidate:isExact,lev:lev,}}}var nSearchWords=searchWords.length;var i,it;var ty;var fullId;var returned;var in_args;var len;if((val.charAt(0)==="\""||val.charAt(0)==="'")&&val.charAt(val.length-1)===val.charAt(0)){val=extractGenerics(val.substr(1,val.length-2));for(i=0;i")>-1){var trimmer=function(s){return s.trim()};var parts=val.split("->").map(trimmer);var input=parts[0];var inputs=input.split(",").map(trimmer).sort();for(i=0,len=inputs.length;i0){firstNonZeroDistance=distance;break}}in_args=firstNonZeroDistance}addIntoResults(true,results_in_args,fullId,i,-1,in_args);addIntoResults(true,results_returned,fullId,i,-1,returned);if(is_module){addIntoResults(true,results,fullId,i,-1,0)}}}query.inputs=inputs.map(function(input){return input.name});query.output=output.name}else{query.inputs=[val];query.output=val;query.search=val;val=val.replace(/_/g,"");var valGenerics=extractGenerics(val);var paths=valLower.split("::");removeEmptyStringsFromArray(paths);val=paths[paths.length-1];var contains=paths.slice(0,paths.length>1?paths.length-1:1);var lev,j;for(j=0;j1){lev=checkPath(contains,paths[paths.length-1],ty);if(lev>MAX_LEV_DISTANCE){continue}else if(lev>0){lev_add=lev/10}}returned=MAX_LEV_DISTANCE+1;in_args=MAX_LEV_DISTANCE+1;var index=-1;lev=MAX_LEV_DISTANCE+1;fullId=ty.id;if(searchWords[j].indexOf(split[i])>-1||searchWords[j].indexOf(val)>-1||ty.normalizedName.indexOf(val)>-1){if(typePassesFilter(typeFilter,ty.ty)&&results[fullId]===undefined){index=ty.normalizedName.indexOf(val)}}if((lev=levenshtein(searchWords[j],val))<=MAX_LEV_DISTANCE){if(typePassesFilter(typeFilter,ty.ty)){lev+=1}else{lev=MAX_LEV_DISTANCE+1}}in_args=findArg(ty,valGenerics,false,typeFilter);returned=checkReturned(ty,valGenerics,false,typeFilter);lev+=lev_add;if(lev>0&&val.length>3&&searchWords[j].indexOf(val)>-1){if(val.length<6){lev-=1}else{lev=0}}addIntoResults(false,results_in_args,fullId,j,index,in_args);addIntoResults(false,results_returned,fullId,j,index,returned);if(typePassesFilter(typeFilter,ty.ty)&&(index!==-1||lev<=MAX_LEV_DISTANCE)){if(index!==-1&&paths.length<2){lev=0}addIntoResults(false,results,fullId,j,index,lev)}}}var ret={"in_args":sortResults(results_in_args,true),"returned":sortResults(results_returned,true),"others":sortResults(results,false),};handleAliases(ret,query,filterCrates);return ret}function validateResult(name,path,keys,parent){for(var i=0,len=keys.length;i-1||path.indexOf(keys[i])>-1||(parent!==undefined&&parent.name!==undefined&&parent.name.toLowerCase().indexOf(keys[i])>-1)||levenshtein(name,keys[i])<=MAX_LEV_DISTANCE)){return false}}return true}function getQuery(raw){var matches,type="",query;query=raw;matches=query.match(/^(fn|mod|struct|enum|trait|type|const|macro)\s*:\s*/i);if(matches){type=matches[1].replace(/^const$/,"constant");query=query.substring(matches[0].length)}return{raw:raw,query:query,type:type,id:query+type}}function nextTab(direction){var next=(searchState.currentTab+direction+3)%searchState.focusedByTab.length;searchState.focusedByTab[searchState.currentTab]=document.activeElement;printTab(next);focusSearchResult()}function focusSearchResult(){var target=searchState.focusedByTab[searchState.currentTab]||document.querySelectorAll(".search-results.active a").item(0)||document.querySelectorAll("#titles > button").item(searchState.currentTab);if(target){target.focus()}}function buildHrefAndPath(item){var displayPath;var href;var type=itemTypes[item.ty];var name=item.name;var path=item.path;if(type==="mod"){displayPath=path+"::";href=window.rootPath+path.replace(/::/g,"/")+"/"+name+"/index.html"}else if(type==="primitive"||type==="keyword"){displayPath="";href=window.rootPath+path.replace(/::/g,"/")+"/"+type+"."+name+".html"}else if(type==="externcrate"){displayPath="";href=window.rootPath+name+"/index.html"}else if(item.parent!==undefined){var myparent=item.parent;var anchor="#"+type+"."+name;var parentType=itemTypes[myparent.ty];var pageType=parentType;var pageName=myparent.name;if(parentType==="primitive"){displayPath=myparent.name+"::"}else if(type==="structfield"&&parentType==="variant"){var enumNameIdx=item.path.lastIndexOf("::");var enumName=item.path.substr(enumNameIdx+2);path=item.path.substr(0,enumNameIdx);displayPath=path+"::"+enumName+"::"+myparent.name+"::";anchor="#variant."+myparent.name+".field."+name;pageType="enum";pageName=enumName}else{displayPath=path+"::"+myparent.name+"::"}href=window.rootPath+path.replace(/::/g,"/")+"/"+pageType+"."+pageName+".html"+anchor}else{displayPath=item.path+"::";href=window.rootPath+item.path.replace(/::/g,"/")+"/"+type+"."+name+".html"}return[displayPath,href]}function escape(content){var h1=document.createElement("h1");h1.textContent=content;return h1.innerHTML}function pathSplitter(path){var tmp=""+path.replace(/::/g,"::");if(tmp.endsWith("")){return tmp.slice(0,tmp.length-6)}return tmp}function addTab(array,query,display){var extraClass="";if(display===true){extraClass=" active"}var output=document.createElement("div");var length=0;if(array.length>0){output.className="search-results "+extraClass;array.forEach(function(item){var name=item.name;var type=itemTypes[item.ty];length+=1;var extra="";if(type==="primitive"){extra=" (primitive type)"}else if(type==="keyword"){extra=" (keyword)"}var link=document.createElement("a");link.className="result-"+type;link.href=item.href;var wrapper=document.createElement("div");var resultName=document.createElement("div");resultName.className="result-name";if(item.is_alias){var alias=document.createElement("span");alias.className="alias";var bold=document.createElement("b");bold.innerText=item.alias;alias.appendChild(bold);alias.insertAdjacentHTML("beforeend"," - see ");resultName.appendChild(alias)}resultName.insertAdjacentHTML("beforeend",item.displayPath+""+name+extra+"");wrapper.appendChild(resultName);var description=document.createElement("div");description.className="desc";var spanDesc=document.createElement("span");spanDesc.insertAdjacentHTML("beforeend",item.desc);description.appendChild(spanDesc);wrapper.appendChild(description);link.appendChild(wrapper);output.appendChild(link)})}else{output.className="search-failed"+extraClass;output.innerHTML="No results :( "+"Try on DuckDuckGo?
"+"Or try looking in one of these:
The Rust Reference "+" for technical details about the language.
+
\ No newline at end of file
diff --git a/ch9-log/src/os/config.rs.html b/ch9-log/src/os/config.rs.html
new file mode 100644
index 00000000..7e23b86e
--- /dev/null
+++ b/ch9-log/src/os/config.rs.html
@@ -0,0 +1,32 @@
+config.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/console.rs.html b/ch9-log/src/os/console.rs.html
new file mode 100644
index 00000000..cc36963b
--- /dev/null
+++ b/ch9-log/src/os/console.rs.html
@@ -0,0 +1,127 @@
+console.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/drivers/block/mod.rs.html b/ch9-log/src/os/drivers/block/mod.rs.html
new file mode 100644
index 00000000..7e4024dd
--- /dev/null
+++ b/ch9-log/src/os/drivers/block/mod.rs.html
@@ -0,0 +1,66 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/drivers/block/virtio_blk.rs.html b/ch9-log/src/os/drivers/block/virtio_blk.rs.html
new file mode 100644
index 00000000..34bbbac8
--- /dev/null
+++ b/ch9-log/src/os/drivers/block/virtio_blk.rs.html
@@ -0,0 +1,266 @@
+virtio_blk.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/drivers/chardev/mod.rs.html b/ch9-log/src/os/drivers/chardev/mod.rs.html
new file mode 100644
index 00000000..b98696d2
--- /dev/null
+++ b/ch9-log/src/os/drivers/chardev/mod.rs.html
@@ -0,0 +1,40 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/drivers/chardev/ns16550a.rs.html b/ch9-log/src/os/drivers/chardev/ns16550a.rs.html
new file mode 100644
index 00000000..28026916
--- /dev/null
+++ b/ch9-log/src/os/drivers/chardev/ns16550a.rs.html
@@ -0,0 +1,358 @@
+ns16550a.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/drivers/mod.rs.html b/ch9-log/src/os/drivers/mod.rs.html
new file mode 100644
index 00000000..c7fcb12d
--- /dev/null
+++ b/ch9-log/src/os/drivers/mod.rs.html
@@ -0,0 +1,18 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/drivers/plic.rs.html b/ch9-log/src/os/drivers/plic.rs.html
new file mode 100644
index 00000000..a5bcfab8
--- /dev/null
+++ b/ch9-log/src/os/drivers/plic.rs.html
@@ -0,0 +1,254 @@
+plic.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/fs/inode.rs.html b/ch9-log/src/os/fs/inode.rs.html
new file mode 100644
index 00000000..1412f8bf
--- /dev/null
+++ b/ch9-log/src/os/fs/inode.rs.html
@@ -0,0 +1,294 @@
+inode.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/fs/mod.rs.html b/ch9-log/src/os/fs/mod.rs.html
new file mode 100644
index 00000000..a96810d9
--- /dev/null
+++ b/ch9-log/src/os/fs/mod.rs.html
@@ -0,0 +1,38 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/fs/pipe.rs.html b/ch9-log/src/os/fs/pipe.rs.html
new file mode 100644
index 00000000..a513e20d
--- /dev/null
+++ b/ch9-log/src/os/fs/pipe.rs.html
@@ -0,0 +1,338 @@
+pipe.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/fs/stdio.rs.html b/ch9-log/src/os/fs/stdio.rs.html
new file mode 100644
index 00000000..9323b00e
--- /dev/null
+++ b/ch9-log/src/os/fs/stdio.rs.html
@@ -0,0 +1,96 @@
+stdio.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/lang_items.rs.html b/ch9-log/src/os/lang_items.rs.html
new file mode 100644
index 00000000..3510fcf6
--- /dev/null
+++ b/ch9-log/src/os/lang_items.rs.html
@@ -0,0 +1,80 @@
+lang_items.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/main.rs.html b/ch9-log/src/os/main.rs.html
new file mode 100644
index 00000000..9d53e75b
--- /dev/null
+++ b/ch9-log/src/os/main.rs.html
@@ -0,0 +1,146 @@
+main.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/mm/address.rs.html b/ch9-log/src/os/mm/address.rs.html
new file mode 100644
index 00000000..ae243b29
--- /dev/null
+++ b/ch9-log/src/os/mm/address.rs.html
@@ -0,0 +1,522 @@
+address.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/mm/frame_allocator.rs.html b/ch9-log/src/os/mm/frame_allocator.rs.html
new file mode 100644
index 00000000..c075728d
--- /dev/null
+++ b/ch9-log/src/os/mm/frame_allocator.rs.html
@@ -0,0 +1,264 @@
+frame_allocator.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/mm/heap_allocator.rs.html b/ch9-log/src/os/mm/heap_allocator.rs.html
new file mode 100644
index 00000000..08e1edf8
--- /dev/null
+++ b/ch9-log/src/os/mm/heap_allocator.rs.html
@@ -0,0 +1,100 @@
+heap_allocator.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/mm/memory_set.rs.html b/ch9-log/src/os/mm/memory_set.rs.html
new file mode 100644
index 00000000..3122c554
--- /dev/null
+++ b/ch9-log/src/os/mm/memory_set.rs.html
@@ -0,0 +1,778 @@
+memory_set.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/mm/mod.rs.html b/ch9-log/src/os/mm/mod.rs.html
new file mode 100644
index 00000000..fba00402
--- /dev/null
+++ b/ch9-log/src/os/mm/mod.rs.html
@@ -0,0 +1,54 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/mm/page_table.rs.html b/ch9-log/src/os/mm/page_table.rs.html
new file mode 100644
index 00000000..da976c57
--- /dev/null
+++ b/ch9-log/src/os/mm/page_table.rs.html
@@ -0,0 +1,504 @@
+page_table.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/sbi.rs.html b/ch9-log/src/os/sbi.rs.html
new file mode 100644
index 00000000..3d51abc8
--- /dev/null
+++ b/ch9-log/src/os/sbi.rs.html
@@ -0,0 +1,96 @@
+sbi.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/sync/condvar.rs.html b/ch9-log/src/os/sync/condvar.rs.html
new file mode 100644
index 00000000..07ebb0e3
--- /dev/null
+++ b/ch9-log/src/os/sync/condvar.rs.html
@@ -0,0 +1,116 @@
+condvar.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/sync/mod.rs.html b/ch9-log/src/os/sync/mod.rs.html
new file mode 100644
index 00000000..e265a3f8
--- /dev/null
+++ b/ch9-log/src/os/sync/mod.rs.html
@@ -0,0 +1,24 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/sync/mutex.rs.html b/ch9-log/src/os/sync/mutex.rs.html
new file mode 100644
index 00000000..5f35adda
--- /dev/null
+++ b/ch9-log/src/os/sync/mutex.rs.html
@@ -0,0 +1,182 @@
+mutex.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/sync/semaphore.rs.html b/ch9-log/src/os/sync/semaphore.rs.html
new file mode 100644
index 00000000..71a9239d
--- /dev/null
+++ b/ch9-log/src/os/sync/semaphore.rs.html
@@ -0,0 +1,96 @@
+semaphore.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/sync/up.rs.html b/ch9-log/src/os/sync/up.rs.html
new file mode 100644
index 00000000..89047359
--- /dev/null
+++ b/ch9-log/src/os/sync/up.rs.html
@@ -0,0 +1,274 @@
+up.rs - source
+
usecore::cell::{RefCell, RefMut, UnsafeCell};
+usecore::ops::{Deref, DerefMut};
+useriscv::register::sstatus;
+uselazy_static::*;
+
+/*
+/// Wrap a static data structure inside it so that we are
+/// able to access it without any `unsafe`.
+///
+/// We should only use it in uniprocessor.
+///
+/// In order to get mutable reference of inner data, call
+/// `exclusive_access`.
+pub struct UPSafeCell<T> {
+ /// inner data
+ inner: RefCell<T>,
+}
+
+unsafe impl<T> Sync for UPSafeCell<T> {}
+
+impl<T> UPSafeCell<T> {
+ /// User is responsible to guarantee that inner struct is only used in
+ /// uniprocessor.
+ pub unsafe fn new(value: T) -> Self {
+ Self {
+ inner: RefCell::new(value),
+ }
+ }
+ /// Panic if the data has been borrowed.
+ pub fn exclusive_access(&self) -> RefMut<'_, T> {
+ self.inner.borrow_mut()
+ }
+}
+*/
+
+pubstructUPSafeCellRaw<T> {
+ inner: UnsafeCell<T>,
+}
+
+unsafeimpl<T>SyncforUPSafeCellRaw<T> {}
+
+impl<T>UPSafeCellRaw<T> {
+ pubunsafefnnew(value: T) -> Self {
+ Self {
+ inner: UnsafeCell::new(value),
+ }
+ }
+ pubfnget_mut(&self) -> &mutT {
+ unsafe { &mut (*self.inner.get()) }
+ }
+}
+
+pubstructIntrMaskingInfo {
+ nested_level: usize,
+ sie_before_masking: bool,
+}
+
+lazy_static! {
+ staticrefINTR_MASKING_INFO: UPSafeCellRaw<IntrMaskingInfo>=unsafe {
+ UPSafeCellRaw::new(IntrMaskingInfo::new())
+ };
+}
+
+implIntrMaskingInfo {
+ pubfnnew() -> Self {
+ Self {
+ nested_level: 0,
+ sie_before_masking: false,
+ }
+ }
+
+ pubfnenter(&mutself) {
+ letsie=sstatus::read().sie();
+ unsafe { sstatus::clear_sie(); }
+ ifself.nested_level==0 {
+ self.sie_before_masking=sie;
+ }
+ self.nested_level+=1;
+ }
+
+ pubfnexit(&mutself) {
+ self.nested_level-=1;
+ ifself.nested_level==0&&self.sie_before_masking {
+ unsafe { sstatus::set_sie(); }
+ }
+ }
+}
+
+pubstructUPIntrFreeCell<T> {
+ /// inner data
+ inner: RefCell<T>,
+}
+
+unsafeimpl<T>SyncforUPIntrFreeCell<T> {}
+
+pubstructUPIntrRefMut<'a, T>(Option<RefMut<'a, T>>);
+
+impl<T>UPIntrFreeCell<T> {
+ pubunsafefnnew(value: T) -> Self {
+ Self {
+ inner: RefCell::new(value),
+ }
+ }
+ /// Panic if the data has been borrowed.
+ pubfnexclusive_access(&self) -> UPIntrRefMut<'_, T> {
+ INTR_MASKING_INFO.get_mut().enter();
+ UPIntrRefMut(Some(self.inner.borrow_mut()))
+ }
+
+ pubfnexclusive_session<F, V>(&self, f: F) -> VwhereF: FnOnce(&mutT) -> V {
+ letmutinner=self.exclusive_access();
+ f(inner.deref_mut())
+ }
+}
+
+impl<'a, T>DropforUPIntrRefMut<'a, T> {
+ fndrop(&mutself) {
+ self.0=None;
+ INTR_MASKING_INFO.get_mut().exit();
+ }
+}
+
+impl<'a, T>DerefforUPIntrRefMut<'a, T> {
+ typeTarget=T;
+ fnderef(&self) -> &Self::Target {
+ self.0.as_ref().unwrap().deref()
+ }
+}
+impl<'a, T>DerefMutforUPIntrRefMut<'a, T> {
+ fnderef_mut(&mutself) -> &mutSelf::Target {
+ self.0.as_mut().unwrap().deref_mut()
+ }
+}
+
+
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/syscall/fs.rs.html b/ch9-log/src/os/syscall/fs.rs.html
new file mode 100644
index 00000000..e334025a
--- /dev/null
+++ b/ch9-log/src/os/syscall/fs.rs.html
@@ -0,0 +1,226 @@
+fs.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/syscall/mod.rs.html b/ch9-log/src/os/syscall/mod.rs.html
new file mode 100644
index 00000000..5c9a16f7
--- /dev/null
+++ b/ch9-log/src/os/syscall/mod.rs.html
@@ -0,0 +1,223 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/syscall/process.rs.html b/ch9-log/src/os/syscall/process.rs.html
new file mode 100644
index 00000000..5ec1c1cc
--- /dev/null
+++ b/ch9-log/src/os/syscall/process.rs.html
@@ -0,0 +1,258 @@
+process.rs - source
+
usecrate::fs::{open_file, OpenFlags};
+usecrate::mm::{translated_ref, translated_refmut, translated_str};
+usecrate::task::{
+ current_process, current_task, current_user_token, exit_current_and_run_next, pid2process,
+ suspend_current_and_run_next, SignalFlags,
+};
+usecrate::timer::get_time_ms;
+usealloc::string::String;
+usealloc::sync::Arc;
+usealloc::vec::Vec;
+
+pubfnsys_exit(exit_code: i32) -> ! {
+ kprintln!("[KERN] syscall::process::sys_exit begin");
+ exit_current_and_run_next(exit_code);
+ panic!("Unreachable in sys_exit!");
+}
+
+pubfnsys_yield() -> isize {
+ suspend_current_and_run_next();
+ 0
+}
+
+pubfnsys_get_time() -> isize {
+ kprintln!("[KERN] syscall::process::sys_get_time begin");
+ get_time_ms() asisize
+}
+
+pubfnsys_getpid() -> isize {
+ kprintln!("[KERN] syscall::process::sys_getpid begin");
+ current_task().unwrap().process.upgrade().unwrap().getpid() asisize
+}
+
+pubfnsys_fork() -> isize {
+ kprintln!("[KERN] syscall::process::sys_fork begin");
+ letcurrent_process=current_process();
+ letnew_process=current_process.fork();
+ letnew_pid=new_process.getpid();
+ // modify trap context of new_task, because it returns immediately after switching
+ letnew_process_inner=new_process.inner_exclusive_access();
+ lettask=new_process_inner.tasks[0].as_ref().unwrap();
+ lettrap_cx=task.inner_exclusive_access().get_trap_cx();
+ // we do not have to move to next instruction since we have done it before
+ // for child process, fork returns 0
+ trap_cx.x[10] =0;
+ kprintln!("[KERN] syscall::process::sys_fork end");
+ new_pidasisize
+}
+
+pubfnsys_exec(path: *constu8, mutargs: *constusize) -> isize {
+ kprintln!("[KERN] syscall::process::sys_exec begin");
+ lettoken=current_user_token();
+ letpath=translated_str(token, path);
+ letmutargs_vec: Vec<String>=Vec::new();
+ loop {
+ letarg_str_ptr=*translated_ref(token, args);
+ ifarg_str_ptr==0 {
+ break;
+ }
+ args_vec.push(translated_str(token, arg_str_ptras*constu8));
+ unsafe {
+ args=args.add(1);
+ }
+ }
+ ifletSome(app_inode) =open_file(path.as_str(), OpenFlags::RDONLY) {
+ letall_data=app_inode.read_all();
+ letprocess=current_process();
+ letargc=args_vec.len();
+ process.exec(all_data.as_slice(), args_vec);
+ kprintln!("[KERN] syscall::process::sys_exec end");
+ // return argc because cx.x[10] will be covered with it later
+ argcasisize
+ } else {
+ -1
+ }
+}
+
+/// If there is not a child process whose pid is same as given, return -1.
+/// Else if there is a child process but it is still running, return -2.
+pubfnsys_waitpid(pid: isize, exit_code_ptr: *muti32) -> isize {
+ //kprintln!("[KERN] syscall::process::sys_waitpid begin");
+ letprocess=current_process();
+ // find a child process
+
+ letmutinner=process.inner_exclusive_access();
+ if!inner
+ .children
+ .iter()
+ .any(|p|pid==-1||pidasusize==p.getpid())
+ {
+ return-1;
+ // ---- release current PCB
+ }
+ letpair=inner.children.iter().enumerate().find(|(_, p)| {
+ // ++++ temporarily access child PCB exclusively
+ p.inner_exclusive_access().is_zombie&& (pid==-1||pidasusize==p.getpid())
+ // ++++ release child PCB
+ });
+ ifletSome((idx, _)) =pair {
+ letchild=inner.children.remove(idx);
+ // confirm that child will be deallocated after being removed from children list
+ assert_eq!(Arc::strong_count(&child), 1);
+ letfound_pid=child.getpid();
+ // ++++ temporarily access child PCB exclusively
+ letexit_code=child.inner_exclusive_access().exit_code;
+ // ++++ release child PCB
+ *translated_refmut(inner.memory_set.token(), exit_code_ptr) =exit_code;
+ found_pidasisize
+ } else {
+ -2
+ }
+ // ---- release current PCB automatically
+}
+
+pubfnsys_kill(pid: usize, signal: u32) -> isize {
+ kprintln!("[KERN] syscall::process::sys_kill begin");
+ ifletSome(process) =pid2process(pid) {
+ ifletSome(flag) =SignalFlags::from_bits(signal) {
+ process.inner_exclusive_access().signals|=flag;
+ 0
+ } else {
+ -1
+ }
+ } else {
+ -1
+ }
+}
+
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/syscall/sync.rs.html b/ch9-log/src/os/syscall/sync.rs.html
new file mode 100644
index 00000000..9ea3b4d6
--- /dev/null
+++ b/ch9-log/src/os/syscall/sync.rs.html
@@ -0,0 +1,296 @@
+sync.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/syscall/thread.rs.html b/ch9-log/src/os/syscall/thread.rs.html
new file mode 100644
index 00000000..0002ea15
--- /dev/null
+++ b/ch9-log/src/os/syscall/thread.rs.html
@@ -0,0 +1,184 @@
+thread.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/context.rs.html b/ch9-log/src/os/task/context.rs.html
new file mode 100644
index 00000000..61884b80
--- /dev/null
+++ b/ch9-log/src/os/task/context.rs.html
@@ -0,0 +1,56 @@
+context.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/id.rs.html b/ch9-log/src/os/task/id.rs.html
new file mode 100644
index 00000000..b35ce17c
--- /dev/null
+++ b/ch9-log/src/os/task/id.rs.html
@@ -0,0 +1,452 @@
+id.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/manager.rs.html b/ch9-log/src/os/task/manager.rs.html
new file mode 100644
index 00000000..865d186c
--- /dev/null
+++ b/ch9-log/src/os/task/manager.rs.html
@@ -0,0 +1,122 @@
+manager.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/mod.rs.html b/ch9-log/src/os/task/mod.rs.html
new file mode 100644
index 00000000..0079ce67
--- /dev/null
+++ b/ch9-log/src/os/task/mod.rs.html
@@ -0,0 +1,290 @@
+mod.rs - source
+
modcontext;
+modid;
+modmanager;
+modprocess;
+modprocessor;
+modsignal;
+modswitch;
+#[allow(clippy::module_inception)]
+modtask;
+
+usecrate::fs::{open_file, OpenFlags};
+usealloc::sync::Arc;
+uselazy_static::*;
+usemanager::fetch_task;
+useprocess::ProcessControlBlock;
+useswitch::__switch;
+
+pubusecontext::TaskContext;
+pubuseid::{kstack_alloc, pid_alloc, KernelStack, PidHandle};
+pubusemanager::{add_task, pid2process, remove_from_pid2process};
+pubuseprocessor::{
+ current_kstack_top, current_process, current_task, current_trap_cx, current_trap_cx_user_va,
+ current_user_token, run_tasks, schedule, take_current_task,
+};
+pubusesignal::SignalFlags;
+pubusetask::{TaskControlBlock, TaskStatus};
+
+pubfnsuspend_current_and_run_next() {
+ // There must be an application running.
+ //kprintln!("[KERN] task::suspend_current_and_run_next() begin");
+ lettask=take_current_task().unwrap();
+
+ // ---- access current TCB exclusively
+ letmuttask_inner=task.inner_exclusive_access();
+ lettask_cx_ptr=&muttask_inner.task_cxas*mutTaskContext;
+ // Change status to Ready
+ task_inner.task_status=TaskStatus::Ready;
+ drop(task_inner);
+ // ---- release current TCB
+
+ // push back to ready queue.
+ add_task(task);
+ // jump to scheduling cycle
+ //kprintln!("[KERN] task::suspend_current_and_run_next() end");
+ schedule(task_cx_ptr);
+}
+
+/// This function must be followed by a schedule
+pubfnblock_current_task() -> *mutTaskContext {
+ //kprintln!("[KERN] task::block_current_task() begin");
+ lettask=take_current_task().unwrap();
+ letmuttask_inner=task.inner_exclusive_access();
+ task_inner.task_status=TaskStatus::Blocking;
+ //kprintln!("[KERN] task::block_current_task() end");
+ &muttask_inner.task_cxas*mutTaskContext
+}
+
+pubfnblock_current_and_run_next() {
+ lettask_cx_ptr=block_current_task();
+ schedule(task_cx_ptr);
+}
+
+pubfnexit_current_and_run_next(exit_code: i32) {
+ kprintln!("[KERN] task::exit_current_and_run_next() begin");
+ lettask=take_current_task().unwrap();
+ letmuttask_inner=task.inner_exclusive_access();
+ letprocess=task.process.upgrade().unwrap();
+ lettid=task_inner.res.as_ref().unwrap().tid;
+ // record exit code
+ task_inner.exit_code=Some(exit_code);
+ task_inner.res=None;
+ // here we do not remove the thread since we are still using the kstack
+ // it will be deallocated when sys_waittid is called
+ drop(task_inner);
+ drop(task);
+ // however, if this is the main thread of current process
+ // the process should terminate at once
+ iftid==0 {
+ remove_from_pid2process(process.getpid());
+ letmutprocess_inner=process.inner_exclusive_access();
+ // mark this process as a zombie process
+ process_inner.is_zombie=true;
+ // record exit code of main process
+ process_inner.exit_code=exit_code;
+
+ {
+ // move all child processes under init process
+ letmutinitproc_inner=INITPROC.inner_exclusive_access();
+ forchildinprocess_inner.children.iter() {
+ child.inner_exclusive_access().parent=Some(Arc::downgrade(&INITPROC));
+ initproc_inner.children.push(child.clone());
+ }
+ }
+
+ // deallocate user res (including tid/trap_cx/ustack) of all threads
+ // it has to be done before we dealloc the whole memory_set
+ // otherwise they will be deallocated twice
+ fortaskinprocess_inner.tasks.iter().filter(|t|t.is_some()) {
+ lettask=task.as_ref().unwrap();
+ letmuttask_inner=task.inner_exclusive_access();
+ task_inner.res=None;
+ }
+
+ process_inner.children.clear();
+ // deallocate other data in user space i.e. program code/data section
+ process_inner.memory_set.recycle_data_pages();
+ // drop file descriptors
+ process_inner.fd_table.clear();
+ }
+ drop(process);
+ // we do not have to save task context
+ letmut_unused=TaskContext::zero_init();
+ kprintln!("[KERN] task::exit_current_and_run_next() end");
+ schedule(&mut_unusedas*mut_);
+}
+
+lazy_static! {
+ pubstaticrefINITPROC: Arc<ProcessControlBlock>= {
+ kprintln!("[KERN] task::lazy_static!INITPROC begin");
+ letinode=open_file("initproc", OpenFlags::RDONLY).unwrap();
+ letv=inode.read_all();
+ ProcessControlBlock::new(v.as_slice())
+ };
+}
+
+pubfnadd_initproc() {
+ kprintln!("[KERN] task::add_initproc() begin");
+ let_initproc=INITPROC.clone();
+ kprintln!("[KERN] task::add_initproc() end");
+}
+
+pubfncheck_signals_of_current() -> Option<(i32, &'staticstr)> {
+ letprocess=current_process();
+ letprocess_inner=process.inner_exclusive_access();
+ process_inner.signals.check_error()
+}
+
+pubfncurrent_add_signal(signal: SignalFlags) {
+ letprocess=current_process();
+ letmutprocess_inner=process.inner_exclusive_access();
+ process_inner.signals|=signal;
+}
+
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/process.rs.html b/ch9-log/src/os/task/process.rs.html
new file mode 100644
index 00000000..b49380a2
--- /dev/null
+++ b/ch9-log/src/os/task/process.rs.html
@@ -0,0 +1,534 @@
+process.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/processor.rs.html b/ch9-log/src/os/task/processor.rs.html
new file mode 100644
index 00000000..65716c49
--- /dev/null
+++ b/ch9-log/src/os/task/processor.rs.html
@@ -0,0 +1,214 @@
+processor.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/signal.rs.html b/ch9-log/src/os/task/signal.rs.html
new file mode 100644
index 00000000..31594845
--- /dev/null
+++ b/ch9-log/src/os/task/signal.rs.html
@@ -0,0 +1,64 @@
+signal.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/switch.rs.html b/ch9-log/src/os/task/switch.rs.html
new file mode 100644
index 00000000..416474a8
--- /dev/null
+++ b/ch9-log/src/os/task/switch.rs.html
@@ -0,0 +1,22 @@
+switch.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/task/task.rs.html b/ch9-log/src/os/task/task.rs.html
new file mode 100644
index 00000000..1466394e
--- /dev/null
+++ b/ch9-log/src/os/task/task.rs.html
@@ -0,0 +1,164 @@
+task.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/timer.rs.html b/ch9-log/src/os/timer.rs.html
new file mode 100644
index 00000000..b77c4880
--- /dev/null
+++ b/ch9-log/src/os/timer.rs.html
@@ -0,0 +1,156 @@
+timer.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/trap/context.rs.html b/ch9-log/src/os/trap/context.rs.html
new file mode 100644
index 00000000..6e0a6d4c
--- /dev/null
+++ b/ch9-log/src/os/trap/context.rs.html
@@ -0,0 +1,88 @@
+context.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/src/os/trap/mod.rs.html b/ch9-log/src/os/trap/mod.rs.html
new file mode 100644
index 00000000..e0d93444
--- /dev/null
+++ b/ch9-log/src/os/trap/mod.rs.html
@@ -0,0 +1,352 @@
+mod.rs - source
+
+
\ No newline at end of file
diff --git a/ch9-log/storage.js b/ch9-log/storage.js
new file mode 100644
index 00000000..c090e1f3
--- /dev/null
+++ b/ch9-log/storage.js
@@ -0,0 +1 @@
+var darkThemes=["dark","ayu"];window.currentTheme=document.getElementById("themeStyle");window.mainTheme=document.getElementById("mainThemeStyle");var settingsDataset=(function(){var settingsElement=document.getElementById("default-settings");if(settingsElement===null){return null}var dataset=settingsElement.dataset;if(dataset===undefined){return null}return dataset})();function getSettingValue(settingName){var current=getCurrentValue('rustdoc-'+settingName);if(current!==null){return current}if(settingsDataset!==null){var def=settingsDataset[settingName.replace(/-/g,'_')];if(def!==undefined){return def}}return null}var localStoredTheme=getSettingValue("theme");var savedHref=[];function hasClass(elem,className){return elem&&elem.classList&&elem.classList.contains(className)}function addClass(elem,className){if(!elem||!elem.classList){return}elem.classList.add(className)}function removeClass(elem,className){if(!elem||!elem.classList){return}elem.classList.remove(className)}function onEach(arr,func,reversed){if(arr&&arr.length>0&&func){var length=arr.length;var i;if(reversed){for(i=length-1;i>=0;--i){if(func(arr[i])){return true}}}else{for(i=0;i=0){updateLocalStorage("rustdoc-preferred-dark-theme",localStoredTheme)}updateSystemTheme()}else{switchTheme(window.currentTheme,window.mainTheme,getSettingValue("theme")||"light",false)}
\ No newline at end of file
diff --git a/ch9-log/toggle-minus.svg b/ch9-log/toggle-minus.svg
new file mode 100644
index 00000000..73154788
--- /dev/null
+++ b/ch9-log/toggle-minus.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/ch9-log/toggle-plus.svg b/ch9-log/toggle-plus.svg
new file mode 100644
index 00000000..08b17033
--- /dev/null
+++ b/ch9-log/toggle-plus.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/ch9-log/wheel.svg b/ch9-log/wheel.svg
new file mode 100644
index 00000000..01da3b24
--- /dev/null
+++ b/ch9-log/wheel.svg
@@ -0,0 +1 @@
+
\ No newline at end of file