€•1ZŒsphinx.addnodes”Œdocument”“”)”}”(Œ rawsource”Œ”Œchildren”]”(Œ translations”Œ LanguagesNode”“”)”}”(hhh]”(hŒ pending_xref”“”)”}”(hhh]”Œdocutils.nodes”ŒText”“”ŒChinese (Simplified)”…””}”Œparent”hsbaŒ attributes”}”(Œids”]”Œclasses”]”Œnames”]”Œdupnames”]”Œbackrefs”]”Œ refdomain”Œstd”Œreftype”Œdoc”Œ reftarget”Œ./translations/zh_CN/core-api/symbol-namespaces”Œmodname”NŒ classname”NŒ refexplicit”ˆuŒtagname”hhh ubh)”}”(hhh]”hŒChinese (Traditional)”…””}”hh2sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/zh_TW/core-api/symbol-namespaces”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒItalian”…””}”hhFsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/it_IT/core-api/symbol-namespaces”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒJapanese”…””}”hhZsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/ja_JP/core-api/symbol-namespaces”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒKorean”…””}”hhnsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/ko_KR/core-api/symbol-namespaces”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒSpanish”…””}”hh‚sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/sp_SP/core-api/symbol-namespaces”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubeh}”(h]”h ]”h"]”h$]”h&]”Œcurrent_language”ŒEnglish”uh1h hhŒ _document”hŒsource”NŒline”NubhŒsection”“”)”}”(hhh]”(hŒtitle”“”)”}”(hŒSymbol Namespaces”h]”hŒSymbol Namespaces”…””}”(hh¨hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hh£hžhhŸŒH/var/lib/git/docbuild/linux/Documentation/core-api/symbol-namespaces.rst”h KubhŒ paragraph”“”)”}”(hŒ©The following document describes how to use Symbol Namespaces to structure the export surface of in-kernel symbols exported through the family of EXPORT_SYMBOL() macros.”h]”hŒ©The following document describes how to use Symbol Namespaces to structure the export surface of in-kernel symbols exported through the family of EXPORT_SYMBOL() macros.”…””}”(hh¹hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h Khh£hžhubhŒcomment”“”)”}”(hXETable of Contents === 1 Introduction === 2 How to define Symbol Namespaces --- 2.1 Using the EXPORT_SYMBOL macros --- 2.2 Using the DEFAULT_SYMBOL_NAMESPACE define === 3 How to use Symbols exported in Namespaces === 4 Loading Modules that use namespaced Symbols === 5 Automatically creating MODULE_IMPORT_NS statements”h]”hXETable of Contents === 1 Introduction === 2 How to define Symbol Namespaces --- 2.1 Using the EXPORT_SYMBOL macros --- 2.2 Using the DEFAULT_SYMBOL_NAMESPACE define === 3 How to use Symbols exported in Namespaces === 4 Loading Modules that use namespaced Symbols === 5 Automatically creating MODULE_IMPORT_NS statements”…””}”hhÉsbah}”(h]”h ]”h"]”h$]”h&]”Œ xml:space”Œpreserve”uh1hÇhh£hžhhŸh¶h Kubh¢)”}”(hhh]”(h§)”}”(hŒ1. Introduction”h]”hŒ1. Introduction”…””}”(hhÜhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hhÙhžhhŸh¶h Kubh¸)”}”(hX^Symbol Namespaces have been introduced as a means to structure the export surface of the in-kernel API. It allows subsystem maintainers to partition their exported symbols into separate namespaces. That is useful for documentation purposes (think of the SUBSYSTEM_DEBUG namespace) as well as for limiting the availability of a set of symbols for use in other parts of the kernel. As of today, modules that make use of symbols exported into namespaces, are required to import the namespace. Otherwise the kernel will, depending on its configuration, reject loading the module or warn about a missing import.”h]”hX^Symbol Namespaces have been introduced as a means to structure the export surface of the in-kernel API. It allows subsystem maintainers to partition their exported symbols into separate namespaces. That is useful for documentation purposes (think of the SUBSYSTEM_DEBUG namespace) as well as for limiting the availability of a set of symbols for use in other parts of the kernel. As of today, modules that make use of symbols exported into namespaces, are required to import the namespace. Otherwise the kernel will, depending on its configuration, reject loading the module or warn about a missing import.”…””}”(hhêhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h KhhÙhžhubeh}”(h]”Œ introduction”ah ]”h"]”Œ1. introduction”ah$]”h&]”uh1h¡hh£hžhhŸh¶h Kubh¢)”}”(hhh]”(h§)”}”(hŒ"2. How to define Symbol Namespaces”h]”hŒ"2. How to define Symbol Namespaces”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjhžhhŸh¶h K ubh¸)”}”(hŒ¦Symbols can be exported into namespace using different methods. All of them are changing the way EXPORT_SYMBOL and friends are instrumented to create ksymtab entries.”h]”hŒ¦Symbols can be exported into namespace using different methods. All of them are changing the way EXPORT_SYMBOL and friends are instrumented to create ksymtab entries.”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K"hjhžhubeh}”(h]”Œhow-to-define-symbol-namespaces”ah ]”h"]”Œ"2. how to define symbol namespaces”ah$]”h&]”uh1h¡hh£hžhhŸh¶h K ubh¢)”}”(hhh]”(h§)”}”(hŒ"2.1 Using the EXPORT_SYMBOL macros”h]”hŒ"2.1 Using the EXPORT_SYMBOL macros”…””}”(hj*hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hj'hžhhŸh¶h K'ubh¸)”}”(hXÔIn addition to the macros EXPORT_SYMBOL() and EXPORT_SYMBOL_GPL(), that allow exporting of kernel symbols to the kernel symbol table, variants of these are available to export symbols into a certain namespace: EXPORT_SYMBOL_NS() and EXPORT_SYMBOL_NS_GPL(). They take one additional argument: the namespace as a string constant. Note that this string must not contain whitespaces. E.g. to export the symbol ``usb_stor_suspend`` into the namespace ``USB_STORAGE``, use::”h]”(hX–In addition to the macros EXPORT_SYMBOL() and EXPORT_SYMBOL_GPL(), that allow exporting of kernel symbols to the kernel symbol table, variants of these are available to export symbols into a certain namespace: EXPORT_SYMBOL_NS() and EXPORT_SYMBOL_NS_GPL(). They take one additional argument: the namespace as a string constant. Note that this string must not contain whitespaces. E.g. to export the symbol ”…””}”(hj8hžhhŸNh NubhŒliteral”“”)”}”(hŒ``usb_stor_suspend``”h]”hŒusb_stor_suspend”…””}”(hjBhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hj8ubhŒ into the namespace ”…””}”(hj8hžhhŸNh NubjA)”}”(hŒ``USB_STORAGE``”h]”hŒ USB_STORAGE”…””}”(hjThžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hj8ubhŒ, use:”…””}”(hj8hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K)hj'hžhubhŒ literal_block”“”)”}”(hŒ2EXPORT_SYMBOL_NS(usb_stor_suspend, "USB_STORAGE");”h]”hŒ2EXPORT_SYMBOL_NS(usb_stor_suspend, "USB_STORAGE");”…””}”hjnsbah}”(h]”h ]”h"]”h$]”h&]”h×hØuh1jlhŸh¶h K1hj'hžhubh¸)”}”(hXQThe corresponding ksymtab entry struct ``kernel_symbol`` will have the member ``namespace`` set accordingly. A symbol that is exported without a namespace will refer to ``NULL``. There is no default namespace if none is defined. ``modpost`` and kernel/module/main.c make use the namespace at build time or module load time, respectively.”h]”(hŒ'The corresponding ksymtab entry struct ”…””}”(hj|hžhhŸNh NubjA)”}”(hŒ``kernel_symbol``”h]”hŒ kernel_symbol”…””}”(hj„hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hj|ubhŒ will have the member ”…””}”(hj|hžhhŸNh NubjA)”}”(hŒ ``namespace``”h]”hŒ namespace”…””}”(hj–hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hj|ubhŒN set accordingly. A symbol that is exported without a namespace will refer to ”…””}”(hj|hžhhŸNh NubjA)”}”(hŒ``NULL``”h]”hŒNULL”…””}”(hj¨hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hj|ubhŒ4. There is no default namespace if none is defined. ”…””}”(hj|hžhhŸNh NubjA)”}”(hŒ ``modpost``”h]”hŒmodpost”…””}”(hjºhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hj|ubhŒa and kernel/module/main.c make use the namespace at build time or module load time, respectively.”…””}”(hj|hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K3hj'hžhubeh}”(h]”Œusing-the-export-symbol-macros”ah ]”h"]”Œ"2.1 using the export_symbol macros”ah$]”h&]”uh1h¡hh£hžhhŸh¶h K'ubh¢)”}”(hhh]”(h§)”}”(hŒ-2.2 Using the DEFAULT_SYMBOL_NAMESPACE define”h]”hŒ-2.2 Using the DEFAULT_SYMBOL_NAMESPACE define”…””}”(hjÝhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjÚhžhhŸh¶h K:ubh¸)”}”(hX7Defining namespaces for all symbols of a subsystem can be very verbose and may become hard to maintain. Therefore a default define (DEFAULT_SYMBOL_NAMESPACE) is been provided, that, if set, will become the default for all EXPORT_SYMBOL() and EXPORT_SYMBOL_GPL() macro expansions that do not specify a namespace.”h]”hX7Defining namespaces for all symbols of a subsystem can be very verbose and may become hard to maintain. Therefore a default define (DEFAULT_SYMBOL_NAMESPACE) is been provided, that, if set, will become the default for all EXPORT_SYMBOL() and EXPORT_SYMBOL_GPL() macro expansions that do not specify a namespace.”…””}”(hjëhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K. Typically it's placed before the first #include statement.”h]”hŒwithin the corresponding compilation unit before the #include for . Typically it’s placed before the first #include statement.”…””}”(hjQhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h KShjÚhžhubeh}”(h]”Œ)using-the-default-symbol-namespace-define”ah ]”h"]”Œ-2.2 using the default_symbol_namespace define”ah$]”h&]”uh1h¡hh£hžhhŸh¶h K:ubh¢)”}”(hhh]”(h§)”}”(hŒ,3. How to use Symbols exported in Namespaces”h]”hŒ,3. How to use Symbols exported in Namespaces”…””}”(hjjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjghžhhŸh¶h KWubh¸)”}”(hX‘In order to use symbols that are exported into namespaces, kernel modules need to explicitly import these namespaces. Otherwise the kernel might reject to load the module. The module code is required to use the macro MODULE_IMPORT_NS for the namespaces it uses symbols from. E.g. a module using the usb_stor_suspend symbol from above, needs to import the namespace USB_STORAGE using a statement like::”h]”hXIn order to use symbols that are exported into namespaces, kernel modules need to explicitly import these namespaces. Otherwise the kernel might reject to load the module. The module code is required to use the macro MODULE_IMPORT_NS for the namespaces it uses symbols from. E.g. a module using the usb_stor_suspend symbol from above, needs to import the namespace USB_STORAGE using a statement like:”…””}”(hjxhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h KYhjghžhubjm)”}”(hŒ MODULE_IMPORT_NS("USB_STORAGE");”h]”hŒ MODULE_IMPORT_NS("USB_STORAGE");”…””}”hj†sbah}”(h]”h ]”h"]”h$]”h&]”h×hØuh1jlhŸh¶h K`hjghžhubh¸)”}”(hŒ°This will create a ``modinfo`` tag in the module for each imported namespace. This has the side effect, that the imported namespaces of a module can be inspected with modinfo::”h]”(hŒThis will create a ”…””}”(hj”hžhhŸNh NubjA)”}”(hŒ ``modinfo``”h]”hŒmodinfo”…””}”(hjœhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hj”ubhŒ‘ tag in the module for each imported namespace. This has the side effect, that the imported namespaces of a module can be inspected with modinfo:”…””}”(hj”hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h Kbhjghžhubjm)”}”(hŒR$ modinfo drivers/usb/storage/ums-karma.ko [...] import_ns: USB_STORAGE [...]”h]”hŒR$ modinfo drivers/usb/storage/ums-karma.ko [...] import_ns: USB_STORAGE [...]”…””}”hj´sbah}”(h]”h ]”h"]”h$]”h&]”h×hØuh1jlhŸh¶h Kfhjghžhubh¸)”}”(hŒÝIt is advisable to add the MODULE_IMPORT_NS() statement close to other module metadata definitions like MODULE_AUTHOR() or MODULE_LICENSE(). Refer to section 5. for a way to create missing import statements automatically.”h]”hŒÝIt is advisable to add the MODULE_IMPORT_NS() statement close to other module metadata definitions like MODULE_AUTHOR() or MODULE_LICENSE(). Refer to section 5. for a way to create missing import statements automatically.”…””}”(hjÂhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h Klhjghžhubeh}”(h]”Œ)how-to-use-symbols-exported-in-namespaces”ah ]”h"]”Œ,3. how to use symbols exported in namespaces”ah$]”h&]”uh1h¡hh£hžhhŸh¶h KWubh¢)”}”(hhh]”(h§)”}”(hŒ.4. Loading Modules that use namespaced Symbols”h]”hŒ.4. Loading Modules that use namespaced Symbols”…””}”(hjÛhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjØhžhhŸh¶h Kqubh¸)”}”(hXPAt module loading time (e.g. ``insmod``), the kernel will check each symbol referenced from the module for its availability and whether the namespace it might be exported to has been imported by the module. The default behaviour of the kernel is to reject loading modules that don't specify sufficient imports. An error will be logged and loading will be failed with EINVAL. In order to allow loading of modules that don't satisfy this precondition, a configuration option is available: Setting MODULE_ALLOW_MISSING_NAMESPACE_IMPORTS=y will enable loading regardless, but will emit a warning.”h]”(hŒAt module loading time (e.g. ”…””}”(hjéhžhhŸNh NubjA)”}”(hŒ ``insmod``”h]”hŒinsmod”…””}”(hjñhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hjéubhX-), the kernel will check each symbol referenced from the module for its availability and whether the namespace it might be exported to has been imported by the module. The default behaviour of the kernel is to reject loading modules that don’t specify sufficient imports. An error will be logged and loading will be failed with EINVAL. In order to allow loading of modules that don’t satisfy this precondition, a configuration option is available: Setting MODULE_ALLOW_MISSING_NAMESPACE_IMPORTS=y will enable loading regardless, but will emit a warning.”…””}”(hjéhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h KshjØhžhubeh}”(h]”Œ+loading-modules-that-use-namespaced-symbols”ah ]”h"]”Œ.4. loading modules that use namespaced symbols”ah$]”h&]”uh1h¡hh£hžhhŸh¶h Kqubh¢)”}”(hhh]”(h§)”}”(hŒ55. Automatically creating MODULE_IMPORT_NS statements”h]”hŒ55. Automatically creating MODULE_IMPORT_NS statements”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjhžhhŸh¶h K}ubh¸)”}”(hXÇMissing namespaces imports can easily be detected at build time. In fact, modpost will emit a warning if a module uses a symbol from a namespace without importing it. MODULE_IMPORT_NS() statements will usually be added at a definite location (along with other module meta data). To make the life of module authors (and subsystem maintainers) easier, a script and make target is available to fixup missing imports. Fixing missing imports can be done with::”h]”hXÆMissing namespaces imports can easily be detected at build time. In fact, modpost will emit a warning if a module uses a symbol from a namespace without importing it. MODULE_IMPORT_NS() statements will usually be added at a definite location (along with other module meta data). To make the life of module authors (and subsystem maintainers) easier, a script and make target is available to fixup missing imports. Fixing missing imports can be done with:”…””}”(hj"hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h Khjhžhubjm)”}”(hŒ $ make nsdeps”h]”hŒ $ make nsdeps”…””}”hj0sbah}”(h]”h ]”h"]”h$]”h&]”h×hØuh1jlhŸh¶h K‡hjhžhubh¸)”}”(hŒ0A typical scenario for module authors would be::”h]”hŒ/A typical scenario for module authors would be:”…””}”(hj>hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K‰hjhžhubjm)”}”(hŒÒ- write code that depends on a symbol from a not imported namespace - ``make`` - notice the warning of modpost telling about a missing import - run ``make nsdeps`` to add the import to the correct code location”h]”hŒÒ- write code that depends on a symbol from a not imported namespace - ``make`` - notice the warning of modpost telling about a missing import - run ``make nsdeps`` to add the import to the correct code location”…””}”hjLsbah}”(h]”h ]”h"]”h$]”h&]”h×hØuh1jlhŸh¶h K‹hjhžhubh¸)”}”(hŒ­For subsystem maintainers introducing a namespace, the steps are very similar. Again, ``make nsdeps`` will eventually add the missing namespace imports for in-tree modules::”h]”(hŒVFor subsystem maintainers introducing a namespace, the steps are very similar. Again, ”…””}”(hjZhžhhŸNh NubjA)”}”(hŒ``make nsdeps``”h]”hŒ make nsdeps”…””}”(hjbhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j@hjZubhŒG will eventually add the missing namespace imports for in-tree modules:”…””}”(hjZhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h Khjhžhubjm)”}”(hX- move or add symbols to a namespace (e.g. with EXPORT_SYMBOL_NS()) - ``make`` (preferably with an allmodconfig to cover all in-kernel modules) - notice the warning of modpost telling about a missing import - run ``make nsdeps`` to add the import to the correct code location”h]”hX- move or add symbols to a namespace (e.g. with EXPORT_SYMBOL_NS()) - ``make`` (preferably with an allmodconfig to cover all in-kernel modules) - notice the warning of modpost telling about a missing import - run ``make nsdeps`` to add the import to the correct code location”…””}”hjzsbah}”(h]”h ]”h"]”h$]”h&]”h×hØuh1jlhŸh¶h K”hjhžhubh¸)”}”(hŒHYou can also run nsdeps for external module builds. A typical usage is::”h]”hŒGYou can also run nsdeps for external module builds. A typical usage is:”…””}”(hjˆhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h Kšhjhžhubjm)”}”(hŒ,$ make -C M=$PWD nsdeps”h]”hŒ,$ make -C M=$PWD nsdeps”…””}”hj–sbah}”(h]”h ]”h"]”h$]”h&]”h×hØuh1jlhŸh¶h Kœhjhžhubeh}”(h]”Œ2automatically-creating-module-import-ns-statements”ah ]”h"]”Œ55. automatically creating module_import_ns statements”ah$]”h&]”uh1h¡hh£hžhhŸh¶h K}ubeh}”(h]”Œsymbol-namespaces”ah ]”h"]”Œsymbol namespaces”ah$]”h&]”uh1h¡hhhžhhŸh¶h Kubeh}”(h]”h ]”h"]”h$]”h&]”Œsource”h¶uh1hŒcurrent_source”NŒ current_line”NŒsettings”Œdocutils.frontend”ŒValues”“”)”}”(h¦NŒ generator”NŒ datestamp”NŒ source_link”NŒ source_url”NŒ toc_backlinks”Œentry”Œfootnote_backlinks”KŒ sectnum_xform”KŒstrip_comments”NŒstrip_elements_with_classes”NŒ strip_classes”NŒ report_level”KŒ halt_level”KŒexit_status_level”KŒdebug”NŒwarning_stream”NŒ traceback”ˆŒinput_encoding”Œ utf-8-sig”Œinput_encoding_error_handler”Œstrict”Œoutput_encoding”Œutf-8”Œoutput_encoding_error_handler”j׌error_encoding”Œutf-8”Œerror_encoding_error_handler”Œbackslashreplace”Œ language_code”Œen”Œrecord_dependencies”NŒconfig”NŒ id_prefix”hŒauto_id_prefix”Œid”Œ dump_settings”NŒdump_internals”NŒdump_transforms”NŒdump_pseudo_xml”NŒexpose_internals”NŒstrict_visitor”NŒ_disable_config”NŒ_source”h¶Œ _destination”NŒ _config_files”]”Œ7/var/lib/git/docbuild/linux/Documentation/docutils.conf”aŒfile_insertion_enabled”ˆŒ raw_enabled”KŒline_length_limit”M'Œpep_references”NŒ pep_base_url”Œhttps://peps.python.org/”Œpep_file_url_template”Œpep-%04d”Œrfc_references”NŒ rfc_base_url”Œ&https://datatracker.ietf.org/doc/html/”Œ tab_width”KŒtrim_footnote_reference_space”‰Œsyntax_highlight”Œlong”Œ smart_quotes”ˆŒsmartquotes_locales”]”Œcharacter_level_inline_markup”‰Œdoctitle_xform”‰Œ docinfo_xform”KŒsectsubtitle_xform”‰Œ image_loading”Œlink”Œembed_stylesheet”‰Œcloak_email_addresses”ˆŒsection_self_link”‰Œenv”NubŒreporter”NŒindirect_targets”]”Œsubstitution_defs”}”Œsubstitution_names”}”Œrefnames”}”Œrefids”}”Œnameids”}”(j±j®hýhúj$j!j×jÔjdjajÕjÒjj j©j¦uŒ nametypes”}”(j±‰hý‰j$‰j׉jd‰jÕ‰j‰j©‰uh}”(j®h£húhÙj!jjÔj'jajÚjÒjgj jØj¦juŒ footnote_refs”}”Œ citation_refs”}”Œ autofootnotes”]”Œautofootnote_refs”]”Œsymbol_footnotes”]”Œsymbol_footnote_refs”]”Œ footnotes”]”Œ citations”]”Œautofootnote_start”KŒsymbol_footnote_start”KŒ id_counter”Œ collections”ŒCounter”“”}”…”R”Œparse_messages”]”Œtransform_messages”]”Œ transformer”NŒ include_log”]”Œ decoration”Nhžhub.