€•¼EŒ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”Œ3/translations/zh_CN/admin-guide/mm/shrinker_debugfs”Œmodname”NŒ classname”NŒ refexplicit”ˆuŒtagname”hhh ubh)”}”(hhh]”hŒChinese (Traditional)”…””}”hh2sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ3/translations/zh_TW/admin-guide/mm/shrinker_debugfs”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒItalian”…””}”hhFsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ3/translations/it_IT/admin-guide/mm/shrinker_debugfs”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒJapanese”…””}”hhZsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ3/translations/ja_JP/admin-guide/mm/shrinker_debugfs”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒKorean”…””}”hhnsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ3/translations/ko_KR/admin-guide/mm/shrinker_debugfs”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒPortuguese (Brazilian)”…””}”hh‚sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ3/translations/pt_BR/admin-guide/mm/shrinker_debugfs”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒSpanish”…””}”hh–sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ3/translations/sp_SP/admin-guide/mm/shrinker_debugfs”Œ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ŒShrinker Debugfs Interface”h]”hŒShrinker Debugfs Interface”…””}”(hh¼h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hºhh·h²hh³ŒM/var/lib/git/docbuild/linux/Documentation/admin-guide/mm/shrinker_debugfs.rst”h´KubhŒ paragraph”“”)”}”(hŒ¬Shrinker debugfs interface provides a visibility into the kernel memory shrinkers subsystem and allows to get information about individual shrinkers and interact with them.”h]”hŒ¬Shrinker debugfs interface provides a visibility into the kernel memory shrinkers subsystem and allows to get information about individual shrinkers and interact with them.”…””}”(hhÍh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´Khh·h²hubhÌ)”}”(hŒÑFor each shrinker registered in the system a directory in **/shrinker/** is created. The directory's name is composed from the shrinker's name and an unique id: e.g. *kfree_rcu-0* or *sb-xfs:vda1-36*.”h]”(hŒ:For each shrinker registered in the system a directory in ”…””}”(hhÛh²hh³Nh´NubhŒstrong”“”)”}”(hŒ**/shrinker/**”h]”hŒ/shrinker/”…””}”(hhåh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hãhhÛubhŒb is created. The directory’s name is composed from the shrinker’s name and an unique id: e.g. ”…””}”(hhÛh²hh³Nh´NubhŒemphasis”“”)”}”(hŒ *kfree_rcu-0*”h]”hŒ kfree_rcu-0”…””}”(hhùh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hhÛubhŒ or ”…””}”(hhÛh²hh³Nh´Nubhø)”}”(hŒ*sb-xfs:vda1-36*”h]”hŒsb-xfs:vda1-36”…””}”(hj h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hhÛubhŒ.”…””}”(hhÛh²hh³Nh´Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K hh·h²hubhÌ)”}”(hŒ´Each shrinker directory contains **count** and **scan** files, which allow to trigger *count_objects()* and *scan_objects()* callbacks for each memcg and numa node (if applicable).”h]”(hŒ!Each shrinker directory contains ”…””}”(hj#h²hh³Nh´Nubhä)”}”(hŒ **count**”h]”hŒcount”…””}”(hj+h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hãhj#ubhŒ and ”…””}”(hj#h²hh³Nh´Nubhä)”}”(hŒ**scan**”h]”hŒscan”…””}”(hj=h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hãhj#ubhŒ files, which allow to trigger ”…””}”(hj#h²hh³Nh´Nubhø)”}”(hŒ*count_objects()*”h]”hŒcount_objects()”…””}”(hjOh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hj#ubhŒ and ”…””}”hj#sbhø)”}”(hŒ*scan_objects()*”h]”hŒscan_objects()”…””}”(hjah²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hj#ubhŒ8 callbacks for each memcg and numa node (if applicable).”…””}”(hj#h²hh³Nh´Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K hh·h²hubh¶)”}”(hhh]”(h»)”}”(hŒUsage:”h]”hŒUsage:”…””}”(hj|h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hºhjyh²hh³hÊh´KubhŒenumerated_list”“”)”}”(hhh]”hŒ list_item”“”)”}”(hŒ*List registered shrinkers* ”h]”hÌ)”}”(hŒ*List registered shrinkers*”h]”hø)”}”(hj—h]”hŒList registered shrinkers”…””}”(hj™h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hj•ubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´Khj‘ubah}”(h]”h ]”h"]”h$]”h&]”uh1jhjŒh²hh³hÊh´Nubah}”(h]”h ]”h"]”h$]”h&]”Œenumtype”Œarabic”Œprefix”hŒsuffix”Œ.”uh1jŠhjyh²hh³hÊh´KubhŒ block_quote”“”)”}”(hX:: $ cd /sys/kernel/debug/shrinker/ $ ls dquota-cache-16 sb-devpts-28 sb-proc-47 sb-tmpfs-42 mm-shadow-18 sb-devtmpfs-5 sb-proc-48 sb-tmpfs-43 mm-zspool:zram0-34 sb-hugetlbfs-17 sb-pstore-31 sb-tmpfs-44 rcu-kfree-0 sb-hugetlbfs-33 sb-rootfs-2 sb-tmpfs-49 sb-aio-20 sb-iomem-12 sb-securityfs-6 sb-tracefs-13 sb-anon_inodefs-15 sb-mqueue-21 sb-selinuxfs-22 sb-xfs:vda1-36 sb-bdev-3 sb-nsfs-4 sb-sockfs-8 sb-zsmalloc-19 sb-bpf-32 sb-pipefs-14 sb-sysfs-26 thp-deferred_split-10 sb-btrfs:vda2-24 sb-proc-25 sb-tmpfs-1 thp-zero-9 sb-cgroup2-30 sb-proc-39 sb-tmpfs-27 xfs-buf:vda1-37 sb-configfs-23 sb-proc-41 sb-tmpfs-29 xfs-inodegc:vda1-38 sb-dax-11 sb-proc-45 sb-tmpfs-35 sb-debugfs-7 sb-proc-46 sb-tmpfs-40 ”h]”hŒ literal_block”“”)”}”(hXz$ cd /sys/kernel/debug/shrinker/ $ ls dquota-cache-16 sb-devpts-28 sb-proc-47 sb-tmpfs-42 mm-shadow-18 sb-devtmpfs-5 sb-proc-48 sb-tmpfs-43 mm-zspool:zram0-34 sb-hugetlbfs-17 sb-pstore-31 sb-tmpfs-44 rcu-kfree-0 sb-hugetlbfs-33 sb-rootfs-2 sb-tmpfs-49 sb-aio-20 sb-iomem-12 sb-securityfs-6 sb-tracefs-13 sb-anon_inodefs-15 sb-mqueue-21 sb-selinuxfs-22 sb-xfs:vda1-36 sb-bdev-3 sb-nsfs-4 sb-sockfs-8 sb-zsmalloc-19 sb-bpf-32 sb-pipefs-14 sb-sysfs-26 thp-deferred_split-10 sb-btrfs:vda2-24 sb-proc-25 sb-tmpfs-1 thp-zero-9 sb-cgroup2-30 sb-proc-39 sb-tmpfs-27 xfs-buf:vda1-37 sb-configfs-23 sb-proc-41 sb-tmpfs-29 xfs-inodegc:vda1-38 sb-dax-11 sb-proc-45 sb-tmpfs-35 sb-debugfs-7 sb-proc-46 sb-tmpfs-40”h]”hXz$ cd /sys/kernel/debug/shrinker/ $ ls dquota-cache-16 sb-devpts-28 sb-proc-47 sb-tmpfs-42 mm-shadow-18 sb-devtmpfs-5 sb-proc-48 sb-tmpfs-43 mm-zspool:zram0-34 sb-hugetlbfs-17 sb-pstore-31 sb-tmpfs-44 rcu-kfree-0 sb-hugetlbfs-33 sb-rootfs-2 sb-tmpfs-49 sb-aio-20 sb-iomem-12 sb-securityfs-6 sb-tracefs-13 sb-anon_inodefs-15 sb-mqueue-21 sb-selinuxfs-22 sb-xfs:vda1-36 sb-bdev-3 sb-nsfs-4 sb-sockfs-8 sb-zsmalloc-19 sb-bpf-32 sb-pipefs-14 sb-sysfs-26 thp-deferred_split-10 sb-btrfs:vda2-24 sb-proc-25 sb-tmpfs-1 thp-zero-9 sb-cgroup2-30 sb-proc-39 sb-tmpfs-27 xfs-buf:vda1-37 sb-configfs-23 sb-proc-41 sb-tmpfs-29 xfs-inodegc:vda1-38 sb-dax-11 sb-proc-45 sb-tmpfs-35 sb-debugfs-7 sb-proc-46 sb-tmpfs-40”…””}”hjÅsbah}”(h]”h ]”h"]”h$]”h&]”Œ xml:space”Œpreserve”uh1jÃh³hÊh´Khj¿ubah}”(h]”h ]”h"]”h$]”h&]”uh1j½h³hÊh´Khjyh²hubj‹)”}”(hhh]”j)”}”(hŒ,*Get information about a specific shrinker* ”h]”hÌ)”}”(hŒ+*Get information about a specific shrinker*”h]”hø)”}”(hjäh]”hŒ)Get information about a specific shrinker”…””}”(hjæh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hjâubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K(hjÞubah}”(h]”h ]”h"]”h$]”h&]”uh1jhjÛh²hh³hÊh´Nubah}”(h]”h ]”h"]”h$]”h&]”j¸j¹jºhj»j¼Œstart”Kuh1jŠhjyh²hh³hÊh´K(ubj¾)”}”(hŒ=:: $ cd sb-btrfs\:vda2-24/ $ ls count scan ”h]”jÄ)”}”(hŒ2$ cd sb-btrfs\:vda2-24/ $ ls count scan”h]”hŒ2$ cd sb-btrfs\:vda2-24/ $ ls count scan”…””}”hj sbah}”(h]”h ]”h"]”h$]”h&]”jÓjÔuh1jÃh³hÊh´K,hjubah}”(h]”h ]”h"]”h$]”h&]”uh1j½h³hÊh´K*hjyh²hubj‹)”}”(hhh]”j)”}”(hŒ*Count objects* ”h]”hÌ)”}”(hŒ*Count objects*”h]”hø)”}”(hj'h]”hŒ Count objects”…””}”(hj)h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hj%ubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K0hj!ubah}”(h]”h ]”h"]”h$]”h&]”uh1jhjh²hh³hÊh´Nubah}”(h]”h ]”h"]”h$]”h&]”j¸j¹jºhj»j¼jKuh1jŠhjyh²hh³hÊh´K0ubj¾)”}”(hXÛEach line in the output has the following format:: ... ... ... If there are no objects on all numa nodes, a line is omitted. If there are no objects at all, the output might be empty. If the shrinker is not memcg-aware or CONFIG_MEMCG is off, 0 is printed as cgroup inode id. If the shrinker is not numa-aware, 0's are printed for all nodes except the first one. :: $ cat count 1 224 2 21 98 0 55 818 10 2367 2 0 2401 30 0 225 13 0 599 35 0 939 124 0 1041 3 0 1075 1 0 1109 1 0 1279 60 0 1313 7 0 1347 39 0 1381 3 0 1449 14 0 1483 63 0 1517 53 0 1551 6 0 1585 1 0 1619 6 0 1653 40 0 1687 11 0 1721 8 0 1755 4 0 1789 52 0 1823 888 0 1857 1 0 1925 2 0 1959 32 0 2027 22 0 2061 9 0 2469 799 0 2537 861 0 2639 1 0 2707 70 0 2775 4 0 2877 84 0 293 1 0 735 8 0 ”h]”(hÌ)”}”(hŒ2Each line in the output has the following format::”h]”hŒ1Each line in the output has the following format:”…””}”(hjLh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K2hjHubjÄ)”}”(hŒ— ... ... ...”h]”hŒ— ... ... ...”…””}”hjZsbah}”(h]”h ]”h"]”h$]”h&]”jÓjÔuh1jÃh³hÊh´K4hjHubhÌ)”}”(hŒxIf there are no objects on all numa nodes, a line is omitted. If there are no objects at all, the output might be empty.”h]”hŒxIf there are no objects on all numa nodes, a line is omitted. If there are no objects at all, the output might be empty.”…””}”(hjhh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K8hjHubhÌ)”}”(hŒµIf the shrinker is not memcg-aware or CONFIG_MEMCG is off, 0 is printed as cgroup inode id. If the shrinker is not numa-aware, 0's are printed for all nodes except the first one. ::”h]”hŒ´If the shrinker is not memcg-aware or CONFIG_MEMCG is off, 0 is printed as cgroup inode id. If the shrinker is not numa-aware, 0’s are printed for all nodes except the first one.”…””}”(hjvh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´K;hjHubjÄ)”}”(hX„$ cat count 1 224 2 21 98 0 55 818 10 2367 2 0 2401 30 0 225 13 0 599 35 0 939 124 0 1041 3 0 1075 1 0 1109 1 0 1279 60 0 1313 7 0 1347 39 0 1381 3 0 1449 14 0 1483 63 0 1517 53 0 1551 6 0 1585 1 0 1619 6 0 1653 40 0 1687 11 0 1721 8 0 1755 4 0 1789 52 0 1823 888 0 1857 1 0 1925 2 0 1959 32 0 2027 22 0 2061 9 0 2469 799 0 2537 861 0 2639 1 0 2707 70 0 2775 4 0 2877 84 0 293 1 0 735 8 0”h]”hX„$ cat count 1 224 2 21 98 0 55 818 10 2367 2 0 2401 30 0 225 13 0 599 35 0 939 124 0 1041 3 0 1075 1 0 1109 1 0 1279 60 0 1313 7 0 1347 39 0 1381 3 0 1449 14 0 1483 63 0 1517 53 0 1551 6 0 1585 1 0 1619 6 0 1653 40 0 1687 11 0 1721 8 0 1755 4 0 1789 52 0 1823 888 0 1857 1 0 1925 2 0 1959 32 0 2027 22 0 2061 9 0 2469 799 0 2537 861 0 2639 1 0 2707 70 0 2775 4 0 2877 84 0 293 1 0 735 8 0”…””}”hj„sbah}”(h]”h ]”h"]”h$]”h&]”jÓjÔuh1jÃh³hÊh´K@hjHubeh}”(h]”h ]”h"]”h$]”h&]”uh1j½h³hÊh´K2hjyh²hubj‹)”}”(hhh]”j)”}”(hŒ*Scan objects* ”h]”hÌ)”}”(hŒ*Scan objects*”h]”hø)”}”(hj¡h]”hŒ Scan objects”…””}”(hj£h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h÷hjŸubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´Kjhj›ubah}”(h]”h ]”h"]”h$]”h&]”uh1jhj˜h²hh³hÊh´Nubah}”(h]”h ]”h"]”h$]”h&]”j¸j¹jºhj»j¼jKuh1jŠhjyh²hh³hÊh´Kjubj¾)”}”(hX½The expected input format:: For a non-memcg-aware shrinker or on a system with no memory cgrups **0** should be passed as cgroup id. :: $ cd /sys/kernel/debug/shrinker/ $ cd sb-btrfs\:vda2-24/ $ cat count | head -n 5 1 212 0 21 97 0 55 802 5 2367 2 0 225 13 0 $ echo "55 0 200" > scan $ cat count | head -n 5 1 212 0 21 96 0 55 752 5 2367 2 0 225 13 0”h]”(hÌ)”}”(hŒThe expected input format::”h]”hŒThe expected input format:”…””}”(hjÆh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´KlhjÂubjÄ)”}”(hŒ7 ”h]”hŒ7 ”…””}”hjÔsbah}”(h]”h ]”h"]”h$]”h&]”jÓjÔuh1jÃh³hÊh´KnhjÂubhÌ)”}”(hŒkFor a non-memcg-aware shrinker or on a system with no memory cgrups **0** should be passed as cgroup id. ::”h]”(hŒDFor a non-memcg-aware shrinker or on a system with no memory cgrups ”…””}”(hjâh²hh³Nh´Nubhä)”}”(hŒ**0**”h]”hŒ0”…””}”(hjêh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hãhjâubhŒ should be passed as cgroup id.”…””}”(hjâh²hh³Nh´Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1hËh³hÊh´KphjÂubjÄ)”}”(hŒÚ$ cd /sys/kernel/debug/shrinker/ $ cd sb-btrfs\:vda2-24/ $ cat count | head -n 5 1 212 0 21 97 0 55 802 5 2367 2 0 225 13 0 $ echo "55 0 200" > scan $ cat count | head -n 5 1 212 0 21 96 0 55 752 5 2367 2 0 225 13 0”h]”hŒÚ$ cd /sys/kernel/debug/shrinker/ $ cd sb-btrfs\:vda2-24/ $ cat count | head -n 5 1 212 0 21 97 0 55 802 5 2367 2 0 225 13 0 $ echo "55 0 200" > scan $ cat count | head -n 5 1 212 0 21 96 0 55 752 5 2367 2 0 225 13 0”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”jÓjÔuh1jÃh³hÊh´KthjÂubeh}”(h]”h ]”h"]”h$]”h&]”uh1j½h³hÊh´Klhjyh²hubeh}”(h]”Œusage”ah ]”h"]”Œusage:”ah$]”h&]”uh1hµhh·h²hh³hÊh´Kubeh}”(h]”Œshrinker-debugfs-interface”ah ]”h"]”Œshrinker debugfs interface”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”jIŒ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 jjuŒ nametypes”}”(j#‰j‰uh}”(j h·jjyuŒ 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”]”(hŒsystem_message”“”)”}”(hhh]”hÌ)”}”(hŒ:Enumerated list start value not ordinal-1: "2" (ordinal 2)”h]”hŒ>Enumerated list start value not ordinal-1: “2†(ordinal 2)”…””}”(hj°h²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËhj­ubah}”(h]”h ]”h"]”h$]”h&]”Œlevel”KŒtype”ŒINFO”Œsource”hÊŒline”Kuh1j«hjyh²hh³hÊh´K(ubj¬)”}”(hhh]”hÌ)”}”(hŒ:Enumerated list start value not ordinal-1: "3" (ordinal 3)”h]”hŒ>Enumerated list start value not ordinal-1: “3†(ordinal 3)”…””}”(hjÌh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËhjÉubah}”(h]”h ]”h"]”h$]”h&]”Œlevel”KŒtype”jÆŒsource”hÊŒline”Kuh1j«hjyh²hh³hÊh´K0ubj¬)”}”(hhh]”hÌ)”}”(hŒ:Enumerated list start value not ordinal-1: "4" (ordinal 4)”h]”hŒ>Enumerated list start value not ordinal-1: “4†(ordinal 4)”…””}”(hjçh²hh³Nh´Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hËhjäubah}”(h]”h ]”h"]”h$]”h&]”Œlevel”KŒtype”jÆŒsource”hÊŒline”Kuh1j«hjyh²hh³hÊh´KjubeŒtransform_messages”]”Œ transformer”NŒ include_log”]”Œ decoration”Nh²hub.