€•¥€Œ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/process/maintainer-soc”Œ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/process/maintainer-soc”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒItalian”…””}”hhFsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ*/translations/it_IT/process/maintainer-soc”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒJapanese”…””}”hhZsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ*/translations/ja_JP/process/maintainer-soc”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒKorean”…””}”hhnsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ*/translations/ko_KR/process/maintainer-soc”Œ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/process/maintainer-soc”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubeh}”(h]”h ]”h"]”h$]”h&]”Œcurrent_language”ŒEnglish”uh1h hhŒ _document”hŒsource”NŒline”NubhŒcomment”“”)”}”(hŒ SPDX-License-Identifier: GPL-2.0”h]”hŒ SPDX-License-Identifier: GPL-2.0”…””}”hh£sbah}”(h]”h ]”h"]”h$]”h&]”Œ xml:space”Œpreserve”uh1h¡hhhžhhŸŒD/var/lib/git/docbuild/linux/Documentation/process/maintainer-soc.rst”h KubhŒsection”“”)”}”(hhh]”(hŒtitle”“”)”}”(hŒ SoC Subsystem”h]”hŒ SoC Subsystem”…””}”(hh»hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¹hh¶hžhhŸh³h Kubhµ)”}”(hhh]”(hº)”}”(hŒOverview”h]”hŒOverview”…””}”(hhÌhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¹hhÉhžhhŸh³h KubhŒ paragraph”“”)”}”(hŒlThe SoC subsystem is a place of aggregation for SoC-specific code. The main components of the subsystem are:”h]”hŒlThe SoC subsystem is a place of aggregation for SoC-specific code. The main components of the subsystem are:”…””}”(hhÜhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K hhÉhžhubhŒ bullet_list”“”)”}”(hhh]”(hŒ list_item”“”)”}”(hŒ+devicetrees for 32- & 64-bit ARM and RISC-V”h]”hÛ)”}”(hhóh]”hŒ+devicetrees for 32- & 64-bit ARM and RISC-V”…””}”(hhõhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K hhñubah}”(h]”h ]”h"]”h$]”h&]”uh1hïhhìhžhhŸh³h Nubhð)”}”(hŒ'32-bit ARM board files (arch/arm/mach*)”h]”hÛ)”}”(hj h]”hŒ'32-bit ARM board files (arch/arm/mach*)”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h Khjubah}”(h]”h ]”h"]”h$]”h&]”uh1hïhhìhžhhŸh³h Nubhð)”}”(hŒ32- & 64-bit ARM defconfigs”h]”hÛ)”}”(hj!h]”hŒ32- & 64-bit ARM defconfigs”…””}”(hj#hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h Khjubah}”(h]”h ]”h"]”h$]”h&]”uh1hïhhìhžhhŸh³h Nubhð)”}”(hŒdSoC-specific drivers across architectures, in particular for 32- & 64-bit ARM, RISC-V and Loongarch ”h]”hÛ)”}”(hŒcSoC-specific drivers across architectures, in particular for 32- & 64-bit ARM, RISC-V and Loongarch”h]”hŒcSoC-specific drivers across architectures, in particular for 32- & 64-bit ARM, RISC-V and Loongarch”…””}”(hj:hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h Khj6ubah}”(h]”h ]”h"]”h$]”h&]”uh1hïhhìhžhhŸh³h Nubeh}”(h]”h ]”h"]”h$]”h&]”Œbullet”Œ*”uh1hêhŸh³h K hhÉhžhubhÛ)”}”(hX>These "SoC-specific drivers" do not include clock, GPIO etc drivers that have other top-level maintainers. The drivers/soc/ directory is generally meant for kernel-internal drivers that are used by other drivers to provide SoC- specific functionality like identifying an SoC revision or interfacing with power domains.”h]”hXBThese “SoC-specific drivers†do not include clock, GPIO etc drivers that have other top-level maintainers. The drivers/soc/ directory is generally meant for kernel-internal drivers that are used by other drivers to provide SoC- specific functionality like identifying an SoC revision or interfacing with power domains.”…””}”(hjVhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h KhhÉhžhubhÛ)”}”(hXThe SoC subsystem also serves as an intermediate location for changes to drivers/bus, drivers/firmware, drivers/reset and drivers/memory. The addition of new platforms, or the removal of existing ones, often go through the SoC tree as a dedicated branch covering multiple subsystems.”h]”hXThe SoC subsystem also serves as an intermediate location for changes to drivers/bus, drivers/firmware, drivers/reset and drivers/memory. The addition of new platforms, or the removal of existing ones, often go through the SoC tree as a dedicated branch covering multiple subsystems.”…””}”(hjdhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h KhhÉhžhubhŒdefinition_list”“”)”}”(hhh]”hŒdefinition_list_item”“”)”}”(hŒlThe main SoC tree is housed on git.kernel.org: https://git.kernel.org/pub/scm/linux/kernel/git/soc/soc.git/ ”h]”(hŒterm”“”)”}”(hŒ.The main SoC tree is housed on git.kernel.org:”h]”hŒ.The main SoC tree is housed on git.kernel.org:”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1j}hŸh³h KhjyubhŒ definition”“”)”}”(hhh]”hÛ)”}”(hŒhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h Kœhjhžhubeh}”(h]”Œdevicetree-naming-convention”ah ]”h"]”Œdevicetree naming convention”ah$]”h&]”uh1h´hjùhžhhŸh³h Kubhµ)”}”(hhh]”(hº)”}”(hŒValidating Devicetree Files”h]”hŒValidating Devicetree Files”…””}”(hjWhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¹hjThžhhŸh³h K ubhÛ)”}”(hX``make dtbs_check`` can be used to validate that devicetree files are compliant with the dt-bindings that describe the ABI. Please read the section "Running checks" of Documentation/devicetree/bindings/writing-schema.rst for more information on the validation of devicetrees.”h]”(hŒliteral”“”)”}”(hŒ``make dtbs_check``”h]”hŒmake dtbs_check”…””}”(hjkhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jihjeubhX can be used to validate that devicetree files are compliant with the dt-bindings that describe the ABI. Please read the section “Running checks†of Documentation/devicetree/bindings/writing-schema.rst for more information on the validation of devicetrees.”…””}”(hjehžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K¢hjThžhubhÛ)”}”(hXFor new platforms, or additions to existing ones, ``make dtbs_check`` should not add any new warnings. For RISC-V and Samsung SoC, ``make dtbs_check W=1`` is required to not add any new warnings. If in any doubt about a devicetree change, reach out to the devicetree maintainers.”h]”(hŒ2For new platforms, or additions to existing ones, ”…””}”(hjƒhžhhŸNh Nubjj)”}”(hŒ``make dtbs_check``”h]”hŒmake dtbs_check”…””}”(hj‹hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jihjƒubhŒ? should not add any new warnings. For RISC-V and Samsung SoC, ”…””}”(hjƒhžhhŸNh Nubjj)”}”(hŒ``make dtbs_check W=1``”h]”hŒmake dtbs_check W=1”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jihjƒubhŒ} is required to not add any new warnings. If in any doubt about a devicetree change, reach out to the devicetree maintainers.”…””}”(hjƒhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K§hjThžhubeh}”(h]”Œvalidating-devicetree-files”ah ]”h"]”Œvalidating devicetree files”ah$]”h&]”uh1h´hjùhžhhŸh³h K ubhµ)”}”(hhh]”(hº)”}”(hŒBranches and Pull Requests”h]”hŒBranches and Pull Requests”…””}”(hjÀhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h¹hj½hžhhŸh³h K®ubhÛ)”}”(hXgJust as the main SoC tree has several branches, it is expected that submaintainers will do the same. Driver, defconfig and devicetree changes should all be split into separate branches and appear in separate pull requests to the SoC maintainers. Each branch should be usable by itself and avoid regressions that originate from dependencies on other branches.”h]”hXgJust as the main SoC tree has several branches, it is expected that submaintainers will do the same. Driver, defconfig and devicetree changes should all be split into separate branches and appear in separate pull requests to the SoC maintainers. Each branch should be usable by itself and avoid regressions that originate from dependencies on other branches.”…””}”(hjÎhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K°hj½hžhubhÛ)”}”(hŒnSmall sets of patches can also be sent as separate emails to soc@kernel.org, grouped into the same categories.”h]”(hŒ=Small sets of patches can also be sent as separate emails to ”…””}”(hjÜhžhhŸNh Nubj—)”}”(hŒsoc@kernel.org”h]”hŒsoc@kernel.org”…””}”(hjähžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œmailto:soc@kernel.org”uh1j–hjÜubhŒ#, grouped into the same categories.”…””}”(hjÜhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K¶hj½hžhubhÛ)”}”(hŒ½If changes do not fit into the normal patterns, there can be additional top-level branches, e.g. for a treewide rework, or the addition of new SoC platforms including dts files and drivers.”h]”hŒ½If changes do not fit into the normal patterns, there can be additional top-level branches, e.g. for a treewide rework, or the addition of new SoC platforms including dts files and drivers.”…””}”(hjþhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K¹hj½hžhubhÛ)”}”(hXBranches with a lot of changes can benefit from getting split up into separate topics branches, even if they end up getting merged into the same branch of the SoC tree. An example here would be one branch for devicetree warning fixes, one for a rework and one for newly added boards.”h]”hXBranches with a lot of changes can benefit from getting split up into separate topics branches, even if they end up getting merged into the same branch of the SoC tree. An example here would be one branch for devicetree warning fixes, one for a rework and one for newly added boards.”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h K½hj½hžhubhÛ)”}”(hX2Another common way to split up changes is to send an early pull request with the majority of the changes at some point between rc1 and rc4, following up with one or more smaller pull requests towards the end of the cycle that can add late changes or address problems identified while testing the first set.”h]”hX2Another common way to split up changes is to send an early pull request with the majority of the changes at some point between rc1 and rc4, following up with one or more smaller pull requests towards the end of the cycle that can add late changes or address problems identified while testing the first set.”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h KÂhj½hžhubhÛ)”}”(hŒ„While there is no cut-off time for late pull requests, it helps to only send small branches as time gets closer to the merge window.”h]”hŒ„While there is no cut-off time for late pull requests, it helps to only send small branches as time gets closer to the merge window.”…””}”(hj(hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h KÇhj½hžhubhÛ)”}”(hŒ¿Pull requests for bugfixes for the current release can be sent at any time, but again having multiple smaller branches is better than trying to combine too many patches into one pull request.”h]”hŒ¿Pull requests for bugfixes for the current release can be sent at any time, but again having multiple smaller branches is better than trying to combine too many patches into one pull request.”…””}”(hj6hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h KÊhj½hžhubhÛ)”}”(hX0The subject line of a pull request should begin with "[GIT PULL]" and made using a signed tag, rather than a branch. This tag should contain a short description summarising the changes in the pull request. For more detail on sending pull requests, please see Documentation/maintainer/pull-requests.rst.”h]”hX4The subject line of a pull request should begin with “[GIT PULL]†and made using a signed tag, rather than a branch. This tag should contain a short description summarising the changes in the pull request. For more detail on sending pull requests, please see Documentation/maintainer/pull-requests.rst.”…””}”(hjDhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÚhŸh³h KÎhj½hžhubeh}”(h]”Œbranches-and-pull-requests”ah ]”h"]”Œbranches and pull requests”ah$]”h&]”uh1h´hjùhžhhŸh³h K®ubeh}”(h]”Œ"information-for-new-submaintainers”ah ]”h"]”Œ$information for (new) submaintainers”ah$]”h&]”uh1h´hh¶hžhhŸh³h KWubeh}”(h]”Œ soc-subsystem”ah ]”h"]”Œ soc subsystem”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”}”(jgjdjÃjÀjöjój%j"jîjëj_j\jJjGjj jQjNjºj·jWjTuŒ nametypes”}”(jg‰jÉjö‰j%‰jî‰j_‰jJ‰j‰jQ‰jº‰jW‰uh}”(jdh¶jÀhÉjójÆj"jjëj(j\jùjGjj jMjNjj·jTjTj½uŒ 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.