€•ÚDŒ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Œ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”…””}”(hh÷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 ”…””}”(hjhžhhŸNh NubhÐ)”}”(hŒ **count**”h]”hŒcount”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÏhjubhŒ and ”…””}”(hjhžhhŸNh NubhÐ)”}”(hŒ**scan**”h]”hŒscan”…””}”(hj)hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÏhjubhŒ files, which allow to trigger ”…””}”(hjhžhhŸNh Nubhä)”}”(hŒ*count_objects()*”h]”hŒcount_objects()”…””}”(hj;hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hãhjubhŒ and ”…””}”hjsbhä)”}”(hŒ*scan_objects()*”h]”hŒscan_objects()”…””}”(hjMhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hãhjubhŒ8 callbacks for each memcg and numa node (if applicable).”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K hh£hžhubh¢)”}”(hhh]”(h§)”}”(hŒUsage:”h]”hŒUsage:”…””}”(hjhhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¦hjehž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ãhjubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h Khj}ubah}”(h]”h ]”h"]”h$]”h&]”uh1j{hjxhžhhŸh¶h Nubah}”(h]”h ]”h"]”h$]”h&]”Œenumtype”Œarabic”Œprefix”hŒsuffix”Œ.”uh1jvhjehž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 Khjehžhubjw)”}”(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&]”uh1j{hjÇhžhhŸh¶h Nubah}”(h]”h ]”h"]”h$]”h&]”j¤j¥j¦hj§j¨Œstart”Kuh1jvhjehž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,hjòubah}”(h]”h ]”h"]”h$]”h&]”uh1j©hŸh¶h K*hjehžhubjw)”}”(hhh]”j|)”}”(hŒ*Count objects* ”h]”h¸)”}”(hŒ*Count objects*”h]”hä)”}”(hjh]”hŒ Count objects”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hãhjubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K0hj ubah}”(h]”h ]”h"]”h$]”h&]”uh1j{hj hžhhŸh¶h Nubah}”(h]”h ]”h"]”h$]”h&]”j¤j¥j¦hj§j¨jñKuh1jvhjehž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:”…””}”(hj8hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K2hj4ubj°)”}”(hŒ— ... ... ...”h]”hŒ— ... ... ...”…””}”hjFsbah}”(h]”h ]”h"]”h$]”h&]”j¿jÀuh1j¯hŸh¶h K4hj4ubh¸)”}”(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.”…””}”(hjThžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K8hj4ubh¸)”}”(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.”…””}”(hjbhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h·hŸh¶h K;hj4ubj°)”}”(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”…””}”hjpsbah}”(h]”h ]”h"]”h$]”h&]”j¿jÀuh1j¯hŸh¶h K@hj4ubeh}”(h]”h ]”h"]”h$]”h&]”uh1j©hŸh¶h K2hjehžhubjw)”}”(hhh]”j|)”}”(hŒ*Scan objects* ”h]”h¸)”}”(hŒ*Scan objects*”h]”hä)”}”(hjh]”hŒ Scan objects”…””}”(hjhž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&]”uh1j{hj„hžhhŸh¶h Nubah}”(h]”h ]”h"]”h$]”h&]”j¤j¥j¦hj§j¨jñKuh1jvhjehž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”…””}”hjîsbah}”(h]”h ]”h"]”h$]”h&]”j¿jÀuh1j¯hŸh¶h Kthj®ubeh}”(h]”h ]”h"]”h$]”h&]”uh1j©hŸh¶h Klhjehž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”j5Œ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”}”(jj jjuŒ nametypes”}”(j‰j‰uh}”(j h£jjeuŒ 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—hjehž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—hjehž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—hjehžhhŸh¶h KjubeŒtransform_messages”]”Œ transformer”NŒ include_log”]”Œ decoration”Nhžhub.