sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget9/translations/zh_CN/driver-api/coco/measurement-registersmodnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget9/translations/zh_TW/driver-api/coco/measurement-registersmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget9/translations/it_IT/driver-api/coco/measurement-registersmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget9/translations/ja_JP/driver-api/coco/measurement-registersmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget9/translations/ko_KR/driver-api/coco/measurement-registersmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hPortuguese (Brazilian)}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget9/translations/pt_BR/driver-api/coco/measurement-registersmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget9/translations/sp_SP/driver-api/coco/measurement-registersmodnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhcomment)}(h SPDX-License-Identifier: GPL-2.0h]h SPDX-License-Identifier: GPL-2.0}hhsbah}(h]h ]h"]h$]h&] xml:spacepreserveuh1hhhhhhS/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers.rsthKubh)}(h4This data file has been placed in the public domain.h]h4This data file has been placed in the public domain.}hhsbah}(h]h ]h"]h$]h&]hhuh1hhhhhho/srv/docbuild/lib/venvs/build-kernel-docs/lib64/python3.9/site-packages/docutils/parsers/rst/include/isonum.txthKubh)}(hDerived from the Unicode character mappings available from . Processed by unicode2rstsubs.py, part of Docutils: .h]hDerived from the Unicode character mappings available from . Processed by unicode2rstsubs.py, part of Docutils: .}hhsbah}(h]h ]h"]h$]h&]hhuh1hhhhhhhhKubhsubstitution_definition)}(h*.. |amp| unicode:: U+00026 .. AMPERSANDh]h&}hhsbah}(h]h ]h"]ampah$]h&]uh1hhhhKhhhhubh)}(h+.. |apos| unicode:: U+00027 .. APOSTROPHEh]h'}hhsbah}(h]h ]h"]aposah$]h&]uh1hhhhKhhhhubh)}(h).. |ast| unicode:: U+0002A .. ASTERISKh]h*}hjsbah}(h]h ]h"]astah$]h&]uh1hhhhK hhhhubh)}(h+.. |brvbar| unicode:: U+000A6 .. BROKEN BARh]h¦}hjsbah}(h]h ]h"]brvbarah$]h&]uh1hhhhK hhhhubh)}(h0.. |bsol| unicode:: U+0005C .. REVERSE SOLIDUSh]h\}hj#sbah}(h]h ]h"]bsolah$]h&]uh1hhhhK hhhhubh)}(h*.. |cent| unicode:: U+000A2 .. CENT SIGNh]h¢}hj2sbah}(h]h ]h"]centah$]h&]uh1hhhhK hhhhubh)}(h&.. |colon| unicode:: U+0003A .. COLONh]h:}hjAsbah}(h]h ]h"]colonah$]h&]uh1hhhhK hhhhubh)}(h&.. |comma| unicode:: U+0002C .. COMMAh]h,}hjPsbah}(h]h ]h"]commaah$]h&]uh1hhhhKhhhhubh)}(h... |commat| unicode:: U+00040 .. COMMERCIAL ATh]h@}hj_sbah}(h]h ]h"]commatah$]h&]uh1hhhhKhhhhubh)}(h/.. |copy| unicode:: U+000A9 .. COPYRIGHT SIGNh]h©}hjnsbah}(h]h ]h"]copyah$]h&]uh1hhhhKhhhhubh)}(h... |curren| unicode:: U+000A4 .. CURRENCY SIGNh]h¤}hj}sbah}(h]h ]h"]currenah$]h&]uh1hhhhKhhhhubh)}(h0.. |darr| unicode:: U+02193 .. DOWNWARDS ARROWh]h↓}hjsbah}(h]h ]h"]darrah$]h&]uh1hhhhKhhhhubh)}(h,.. |deg| unicode:: U+000B0 .. DEGREE SIGNh]h°}hjsbah}(h]h ]h"]degah$]h&]uh1hhhhKhhhhubh)}(h... |divide| unicode:: U+000F7 .. DIVISION SIGNh]h÷}hjsbah}(h]h ]h"]divideah$]h&]uh1hhhhKhhhhubh)}(h,.. |dollar| unicode:: U+00024 .. DOLLAR SIGNh]h$}hjsbah}(h]h ]h"]dollarah$]h&]uh1hhhhKhhhhubh)}(h,.. |equals| unicode:: U+0003D .. EQUALS SIGNh]h=}hjsbah}(h]h ]h"]equalsah$]h&]uh1hhhhKhhhhubh)}(h1.. |excl| unicode:: U+00021 .. EXCLAMATION MARKh]h!}hjsbah}(h]h ]h"]exclah$]h&]uh1hhhhKhhhhubh)}(h9.. |frac12| unicode:: U+000BD .. VULGAR FRACTION ONE HALFh]h½}hjsbah}(h]h ]h"]frac12ah$]h&]uh1hhhhKhhhhubh)}(h<.. |frac14| unicode:: U+000BC .. VULGAR FRACTION ONE QUARTERh]h¼}hjsbah}(h]h ]h"]frac14ah$]h&]uh1hhhhKhhhhubh)}(h;.. |frac18| unicode:: U+0215B .. VULGAR FRACTION ONE EIGHTHh]h⅛}hjsbah}(h]h ]h"]frac18ah$]h&]uh1hhhhKhhhhubh)}(h?.. |frac34| unicode:: U+000BE .. VULGAR FRACTION THREE QUARTERSh]h¾}hjsbah}(h]h ]h"]frac34ah$]h&]uh1hhhhKhhhhubh)}(h>.. |frac38| unicode:: U+0215C .. VULGAR FRACTION THREE EIGHTHSh]h⅜}hj"sbah}(h]h ]h"]frac38ah$]h&]uh1hhhhKhhhhubh)}(h=.. |frac58| unicode:: U+0215D .. VULGAR FRACTION FIVE EIGHTHSh]h⅝}hj1sbah}(h]h ]h"]frac58ah$]h&]uh1hhhhKhhhhubh)}(h>.. |frac78| unicode:: U+0215E .. VULGAR FRACTION SEVEN EIGHTHSh]h⅞}hj@sbah}(h]h ]h"]frac78ah$]h&]uh1hhhhKhhhhubh)}(h2.. |gt| unicode:: U+0003E .. GREATER-THAN SIGNh]h>}hjOsbah}(h]h ]h"]gtah$]h&]uh1hhhhKhhhhubh)}(h9.. |half| unicode:: U+000BD .. VULGAR FRACTION ONE HALFh]h½}hj^sbah}(h]h ]h"]halfah$]h&]uh1hhhhK hhhhubh)}(h/.. |horbar| unicode:: U+02015 .. HORIZONTAL BARh]h―}hjmsbah}(h]h ]h"]horbarah$]h&]uh1hhhhK!hhhhubh)}(h'.. |hyphen| unicode:: U+02010 .. HYPHENh]h‐}hj|sbah}(h]h ]h"]hyphenah$]h&]uh1hhhhK"hhhhubh)}(h:.. |iexcl| unicode:: U+000A1 .. INVERTED EXCLAMATION MARKh]h¡}hjsbah}(h]h ]h"]iexclah$]h&]uh1hhhhK#hhhhubh)}(h7.. |iquest| unicode:: U+000BF .. INVERTED QUESTION MARKh]h¿}hjsbah}(h]h ]h"]iquestah$]h&]uh1hhhhK$hhhhubh)}(hJ.. |laquo| unicode:: U+000AB .. LEFT-POINTING DOUBLE ANGLE QUOTATION MARKh]h«}hjsbah}(h]h ]h"]laquoah$]h&]uh1hhhhK%hhhhubh)}(h0.. |larr| unicode:: U+02190 .. LEFTWARDS ARROWh]h←}hjsbah}(h]h ]h"]larrah$]h&]uh1hhhhK&hhhhubh)}(h3.. |lcub| unicode:: U+0007B .. LEFT CURLY BRACKETh]h{}hjsbah}(h]h ]h"]lcubah$]h&]uh1hhhhK'hhhhubh)}(h;.. |ldquo| unicode:: U+0201C .. LEFT DOUBLE QUOTATION MARKh]h“}hjsbah}(h]h ]h"]ldquoah$]h&]uh1hhhhK(hhhhubh)}(h).. |lowbar| unicode:: U+0005F .. LOW LINEh]h_}hjsbah}(h]h ]h"]lowbarah$]h&]uh1hhhhK)hhhhubh)}(h1.. |lpar| unicode:: U+00028 .. LEFT PARENTHESISh]h(}hjsbah}(h]h ]h"]lparah$]h&]uh1hhhhK*hhhhubh)}(h4.. |lsqb| unicode:: U+0005B .. LEFT SQUARE BRACKETh]h[}hjsbah}(h]h ]h"]lsqbah$]h&]uh1hhhhK+hhhhubh)}(h;.. |lsquo| unicode:: U+02018 .. LEFT SINGLE QUOTATION MARKh]h‘}hjsbah}(h]h ]h"]lsquoah$]h&]uh1hhhhK,hhhhubh)}(h/.. |lt| unicode:: U+0003C .. LESS-THAN SIGNh]h<}hj!sbah}(h]h ]h"]ltah$]h&]uh1hhhhK-hhhhubh)}(h+.. |micro| unicode:: U+000B5 .. MICRO SIGNh]hµ}hj0sbah}(h]h ]h"]microah$]h&]uh1hhhhK.hhhhubh)}(h+.. |middot| unicode:: U+000B7 .. MIDDLE DOTh]h·}hj?sbah}(h]h ]h"]middotah$]h&]uh1hhhhK/hhhhubh)}(h/.. |nbsp| unicode:: U+000A0 .. NO-BREAK SPACEh]h }hjNsbah}(h]h ]h"]nbspah$]h&]uh1hhhhK0hhhhubh)}(h).. |not| unicode:: U+000AC .. NOT SIGNh]h¬}hj]sbah}(h]h ]h"]notah$]h&]uh1hhhhK1hhhhubh)}(h,.. |num| unicode:: U+00023 .. NUMBER SIGNh]h#}hjlsbah}(h]h ]h"]numah$]h&]uh1hhhhK2hhhhubh)}(h).. |ohm| unicode:: U+02126 .. OHM SIGNh]hΩ}hj{sbah}(h]h ]h"]ohmah$]h&]uh1hhhhK3hhhhubh)}(h;.. |ordf| unicode:: U+000AA .. FEMININE ORDINAL INDICATORh]hª}hjsbah}(h]h ]h"]ordfah$]h&]uh1hhhhK4hhhhubh)}(h<.. |ordm| unicode:: U+000BA .. MASCULINE ORDINAL INDICATORh]hº}hjsbah}(h]h ]h"]ordmah$]h&]uh1hhhhK5hhhhubh)}(h-.. |para| unicode:: U+000B6 .. PILCROW SIGNh]h¶}hjsbah}(h]h ]h"]paraah$]h&]uh1hhhhK6hhhhubh)}(h-.. |percnt| unicode:: U+00025 .. PERCENT SIGNh]h%}hjsbah}(h]h ]h"]percntah$]h&]uh1hhhhK7hhhhubh)}(h*.. |period| unicode:: U+0002E .. FULL STOPh]h.}hjsbah}(h]h ]h"]periodah$]h&]uh1hhhhK8hhhhubh)}(h*.. |plus| unicode:: U+0002B .. PLUS SIGNh]h+}hjsbah}(h]h ]h"]plusah$]h&]uh1hhhhK9hhhhubh)}(h0.. |plusmn| unicode:: U+000B1 .. PLUS-MINUS SIGNh]h±}hjsbah}(h]h ]h"]plusmnah$]h&]uh1hhhhK:hhhhubh)}(h+.. |pound| unicode:: U+000A3 .. POUND SIGNh]h£}hjsbah}(h]h ]h"]poundah$]h&]uh1hhhhK;hhhhubh)}(h... |quest| unicode:: U+0003F .. QUESTION MARKh]h?}hjsbah}(h]h ]h"]questah$]h&]uh1hhhhKhhhhubh)}(h1.. |rarr| unicode:: U+02192 .. RIGHTWARDS ARROWh]h→}hj/sbah}(h]h ]h"]rarrah$]h&]uh1hhhhK?hhhhubh)}(h4.. |rcub| unicode:: U+0007D .. RIGHT CURLY BRACKETh]h}}hj>sbah}(h]h ]h"]rcubah$]h&]uh1hhhhK@hhhhubh)}(h<.. |rdquo| unicode:: U+0201D .. RIGHT DOUBLE QUOTATION MARKh]h”}hjMsbah}(h]h ]h"]rdquoah$]h&]uh1hhhhKAhhhhubh)}(h0.. |reg| unicode:: U+000AE .. REGISTERED SIGNh]h®}hj\sbah}(h]h ]h"]regah$]h&]uh1hhhhKBhhhhubh)}(h2.. |rpar| unicode:: U+00029 .. RIGHT PARENTHESISh]h)}hjksbah}(h]h ]h"]rparah$]h&]uh1hhhhKChhhhubh)}(h5.. |rsqb| unicode:: U+0005D .. RIGHT SQUARE BRACKETh]h]}hjzsbah}(h]h ]h"]rsqbah$]h&]uh1hhhhKDhhhhubh)}(h<.. |rsquo| unicode:: U+02019 .. RIGHT SINGLE QUOTATION MARKh]h’}hjsbah}(h]h ]h"]rsquoah$]h&]uh1hhhhKEhhhhubh)}(h-.. |sect| unicode:: U+000A7 .. SECTION SIGNh]h§}hjsbah}(h]h ]h"]sectah$]h&]uh1hhhhKFhhhhubh)}(h*.. |semi| unicode:: U+0003B .. SEMICOLONh]h;}hjsbah}(h]h ]h"]semiah$]h&]uh1hhhhKGhhhhubh)}(h,.. |shy| unicode:: U+000AD .. SOFT HYPHENh]h­}hjsbah}(h]h ]h"]shyah$]h&]uh1hhhhKHhhhhubh)}(h(.. |sol| unicode:: U+0002F .. SOLIDUSh]h/}hjsbah}(h]h ]h"]solah$]h&]uh1hhhhKIhhhhubh)}(h,.. |sung| unicode:: U+0266A .. EIGHTH NOTEh]h♪}hjsbah}(h]h ]h"]sungah$]h&]uh1hhhhKJhhhhubh)}(h0.. |sup1| unicode:: U+000B9 .. SUPERSCRIPT ONEh]h¹}hjsbah}(h]h ]h"]sup1ah$]h&]uh1hhhhKKhhhhubh)}(h0.. |sup2| unicode:: U+000B2 .. SUPERSCRIPT TWOh]h²}hjsbah}(h]h ]h"]sup2ah$]h&]uh1hhhhKLhhhhubh)}(h2.. |sup3| unicode:: U+000B3 .. SUPERSCRIPT THREEh]h³}hjsbah}(h]h ]h"]sup3ah$]h&]uh1hhhhKMhhhhubh)}(h4.. |times| unicode:: U+000D7 .. MULTIPLICATION SIGNh]h×}hjsbah}(h]h ]h"]timesah$]h&]uh1hhhhKNhhhhubh)}(h0.. |trade| unicode:: U+02122 .. TRADE MARK SIGNh]h™}hjsbah}(h]h ]h"]tradeah$]h&]uh1hhhhKOhhhhubh)}(h... |uarr| unicode:: U+02191 .. UPWARDS ARROWh]h↑}hj.sbah}(h]h ]h"]uarrah$]h&]uh1hhhhKPhhhhubh)}(h... |verbar| unicode:: U+0007C .. VERTICAL LINEh]h|}hj=sbah}(h]h ]h"]verbarah$]h&]uh1hhhhKQhhhhubh)}(h*.. |yen| unicode:: U+000A5 .. YEN SIGN h]h¥}hjLsbah}(h]h ]h"]yenah$]h&]uh1hhhhKRhhhhubhsection)}(hhh](htitle)}(hMeasurement Registersh]hMeasurement Registers}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1j`hj]hhhhhKubhindex)}(hhh]h}(h]h ]h"]h$]h&]entries](single#tsm_measurement_register (C struct)c.tsm_measurement_registerhNtauh1jphj]hhhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhNubhdesc)}(hhh](hdesc_signature)}(htsm_measurement_registerh]hdesc_signature_line)}(hstruct tsm_measurement_registerh](hdesc_sig_keyword)}(hstructh]hstruct}(hjhhhNhNubah}(h]h ]kah"]h$]h&]uh1jhjhhhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKubhdesc_sig_space)}(h h]h }(hjhhhNhNubah}(h]h ]wah"]h$]h&]uh1jhjhhhjhKubh desc_name)}(htsm_measurement_registerh]h desc_sig_name)}(hjh]htsm_measurement_register}(hjhhhNhNubah}(h]h ]nah"]h$]h&]uh1jhjubah}(h]h ](sig-namedescnameeh"]h$]h&]hhuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]hhƌ add_permalinkuh1jsphinx_line_type declaratorhjhhhjhKubah}(h]jah ](sig sig-objecteh"]h$]h&] is_multiline _toc_parts) _toc_namehuh1jhjhKhjhhubh desc_content)}(hhh]h paragraph)}(h4describes an architectural measurement register (MR)h]h4describes an architectural measurement register (MR)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK hjhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](cstructeh"]h$]h&]domainjobjtypejdesctypejnoindex noindexentrynocontentsentryuh1jhhhj]hjhNubh container)}(hX**Definition**:: struct tsm_measurement_register { const char *mr_name; void *mr_value; u32 mr_size; u32 mr_flags; enum hash_algo mr_hash; }; **Members** ``mr_name`` name of the MR ``mr_value`` buffer containing the current value of the MR ``mr_size`` size of the MR - typically the digest size of **mr_hash** ``mr_flags`` bitwise OR of one or more flags, detailed below ``mr_hash`` optional hash identifier defined in include/uapi/linux/hash_info.h.h](j)}(h**Definition**::h](hstrong)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK hjubh literal_block)}(hstruct tsm_measurement_register { const char *mr_name; void *mr_value; u32 mr_size; u32 mr_flags; enum hash_algo mr_hash; };h]hstruct tsm_measurement_register { const char *mr_name; void *mr_value; u32 mr_size; u32 mr_flags; enum hash_algo mr_hash; };}hj9sbah}(h]h ]h"]h$]h&]hhuh1j7hl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhjubj)}(h **Members**h]j)}(hjJh]hMembers}(hjLhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjHubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhjubhdefinition_list)}(hhh](hdefinition_list_item)}(h``mr_name`` name of the MR h](hterm)}(h ``mr_name``h]hliteral)}(hjoh]hmr_name}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjmubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK hjgubh definition)}(hhh]j)}(hname of the MRh]hname of the MR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhK hjubah}(h]h ]h"]h$]h&]uh1jhjgubeh}(h]h ]h"]h$]h&]uh1jehjhK hjbubjf)}(h;``mr_value`` buffer containing the current value of the MR h](jl)}(h ``mr_value``h]jr)}(hjh]hmr_value}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK hjubj)}(hhh]j)}(h-buffer containing the current value of the MRh]h-buffer containing the current value of the MR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhK hjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jehjhK hjbubjf)}(hF``mr_size`` size of the MR - typically the digest size of **mr_hash** h](jl)}(h ``mr_size``h]jr)}(hjh]hmr_size}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhjubj)}(hhh]j)}(h9size of the MR - typically the digest size of **mr_hash**h](h.size of the MR - typically the digest size of }(hjhhhNhNubj)}(h **mr_hash**h]hmr_hash}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jehjhKhjbubjf)}(h=``mr_flags`` bitwise OR of one or more flags, detailed below h](jl)}(h ``mr_flags``h]jr)}(hj,h]hmr_flags}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj*ubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj&ubj)}(hhh]j)}(h/bitwise OR of one or more flags, detailed belowh]h/bitwise OR of one or more flags, detailed below}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjAhKhjBubah}(h]h ]h"]h$]h&]uh1jhj&ubeh}(h]h ]h"]h$]h&]uh1jehjAhKhjbubjf)}(hO``mr_hash`` optional hash identifier defined in include/uapi/linux/hash_info.h.h](jl)}(h ``mr_hash``h]jr)}(hjeh]hmr_hash}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjcubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj_ubj)}(hhh]j)}(hCoptional hash identifier defined in include/uapi/linux/hash_info.h.h]hCoptional hash identifier defined in include/uapi/linux/hash_info.h.}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj{ubah}(h]h ]h"]h$]h&]uh1jhj_ubeh}(h]h ]h"]h$]h&]uh1jehjzhKhjbubeh}(h]h ]h"]h$]h&]uh1j`hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj]hhhjhNubj)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj]hhubj)}(hA CC guest driver encloses an array of this structure in struct tsm_measurements to detail the measurement facility supported by the underlying CC hardware.h]hA CC guest driver encloses an array of this structure in struct tsm_measurements to detail the measurement facility supported by the underlying CC hardware.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj]hhubj)}(hV**mr_name** and **mr_value** must stay valid until this structure is no longer in use.h](j)}(h **mr_name**h]hmr_name}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh and }(hjhhhNhNubj)}(h **mr_value**h]hmr_value}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh: must stay valid until this structure is no longer in use.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj]hhubj)}(hB**mr_flags** is the bitwise-OR of zero or more of the flags below.h](j)}(h **mr_flags**h]hmr_flags}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh6 is the bitwise-OR of zero or more of the flags below.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj]hhubh bullet_list)}(hhh](h list_item)}(hQ``TSM_MR_F_READABLE`` - the sysfs attribute corresponding to this MR is readable.h]j)}(hj"h](jr)}(h``TSM_MR_F_READABLE``h]hTSM_MR_F_READABLE}(hj'hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj$ubh< - the sysfs attribute corresponding to this MR is readable.}(hj$hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj ubah}(h]h ]h"]h$]h&]uh1jhjubj)}(h``TSM_MR_F_WRITABLE`` - the sysfs attribute corresponding to this MR is writable. The semantics is typically to extend the MR but could vary depending on the architecture and the MR.h]j)}(h``TSM_MR_F_WRITABLE`` - the sysfs attribute corresponding to this MR is writable. The semantics is typically to extend the MR but could vary depending on the architecture and the MR.h](jr)}(h``TSM_MR_F_WRITABLE``h]hTSM_MR_F_WRITABLE}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjJubh - the sysfs attribute corresponding to this MR is writable. The semantics is typically to extend the MR but could vary depending on the architecture and the MR.}(hjJhhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhjFubah}(h]h ]h"]h$]h&]uh1jhjubj)}(h``TSM_MR_F_LIVE`` - this MR's value may differ from the last value written, so must be read back from the underlying CC hardware/firmware.h]j)}(h``TSM_MR_F_LIVE`` - this MR's value may differ from the last value written, so must be read back from the underlying CC hardware/firmware.h](jr)}(h``TSM_MR_F_LIVE``h]h TSM_MR_F_LIVE}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjqubh{ - this MR’s value may differ from the last value written, so must be read back from the underlying CC hardware/firmware.}(hjqhhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhjmubah}(h]h ]h"]h$]h&]uh1jhjubj)}(hN``TSM_MR_F_RTMR`` - bitwise-OR of ``TSM_MR_F_LIVE`` and ``TSM_MR_F_WRITABLE``.h]j)}(hjh](jr)}(h``TSM_MR_F_RTMR``h]h TSM_MR_F_RTMR}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjubh - bitwise-OR of }(hjhhhNhNubjr)}(h``TSM_MR_F_LIVE``h]h TSM_MR_F_LIVE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjubh and }(hjhhhNhNubjr)}(h``TSM_MR_F_WRITABLE``h]hTSM_MR_F_WRITABLE}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhjubah}(h]h ]h"]h$]h&]uh1jhjubj)}(h``TSM_MR_F_NOHASH`` - this MR does NOT have an associated hash algorithm. **mr_hash** will be ignored when this flag is set. h]j)}(h|``TSM_MR_F_NOHASH`` - this MR does NOT have an associated hash algorithm. **mr_hash** will be ignored when this flag is set.h](jr)}(h``TSM_MR_F_NOHASH``h]hTSM_MR_F_NOHASH}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjubh7 - this MR does NOT have an associated hash algorithm. }(hjhhhNhNubj)}(h **mr_hash**h]hmr_hash}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh' will be ignored when this flag is set.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK hjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]bullet*uh1jhj?hKhj]hhubjq)}(hhh]h}(h]h ]h"]h$]h&]entries](j}tsm_measurements (C struct)c.tsm_measurementshNtauh1jphj]hhhjhNubj)}(hhh](j)}(htsm_measurementsh]j)}(hstruct tsm_measurementsh](j)}(hjh]hstruct}(hj8 hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4 hhhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK&ubj)}(h h]h }(hjF hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj4 hhhjE hK&ubj)}(htsm_measurementsh]j)}(hj2 h]htsm_measurements}(hjX hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjT ubah}(h]h ](jjeh"]h$]h&]hhuh1jhj4 hhhjE hK&ubeh}(h]h ]h"]h$]h&]hhjuh1jjjhj0 hhhjE hK&ubah}(h]j+ ah ](jjeh"]h$]h&]jj)jhuh1jhjE hK&hj- hhubj)}(hhh]j)}(hndefines the CC architecture specific measurement facility and methods for updating measurement registers (MRs)h]hndefines the CC architecture specific measurement facility and methods for updating measurement registers (MRs)}(hjz hhhNhNubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK7hjw hhubah}(h]h ]h"]h$]h&]uh1jhj- hhhjE hK&ubeh}(h]h ](jstructeh"]h$]h&]j jj j jj jjjuh1jhhhj]hjhNubj)}(hX**Definition**:: struct tsm_measurements { const struct tsm_measurement_register *mrs; size_t nr_mrs; int (*refresh)(const struct tsm_measurements *tm); int (*write)(const struct tsm_measurements *tm, const struct tsm_measurement_register *mr, const u8 *data); }; **Members** ``mrs`` Array of MR definitions. ``nr_mrs`` Number of elements in **mrs**. ``refresh`` Callback function to load/sync all MRs from TVM hardware/firmware into the kernel cache. ``write`` Callback function to write to the MR specified by the parameter **mr**. Typically, writing to an MR extends the input buffer to that MR.h](j)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh:}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK;hj ubj8)}(hXstruct tsm_measurements { const struct tsm_measurement_register *mrs; size_t nr_mrs; int (*refresh)(const struct tsm_measurements *tm); int (*write)(const struct tsm_measurements *tm, const struct tsm_measurement_register *mr, const u8 *data); };h]hXstruct tsm_measurements { const struct tsm_measurement_register *mrs; size_t nr_mrs; int (*refresh)(const struct tsm_measurements *tm); int (*write)(const struct tsm_measurements *tm, const struct tsm_measurement_register *mr, const u8 *data); };}hj sbah}(h]h ]h"]h$]h&]hhuh1j7hl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK=hj ubj)}(h **Members**h]j)}(hj h]hMembers}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKDhj ubja)}(hhh](jf)}(h!``mrs`` Array of MR definitions. h](jl)}(h``mrs``h]jr)}(hj h]hmrs}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj ubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK:hj ubj)}(hhh]j)}(hArray of MR definitions.h]hArray of MR definitions.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj hK:hj ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jehj hK:hj ubjf)}(h*``nr_mrs`` Number of elements in **mrs**. h](jl)}(h ``nr_mrs``h]jr)}(hj h]hnr_mrs}(hj" hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj ubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK;hj ubj)}(hhh]j)}(hNumber of elements in **mrs**.h](hNumber of elements in }(hj9 hhhNhNubj)}(h**mrs**h]hmrs}(hjA hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj9 ubh.}(hj9 hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhj5 hK;hj6 ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jehj5 hK;hj ubjf)}(he``refresh`` Callback function to load/sync all MRs from TVM hardware/firmware into the kernel cache. h](jl)}(h ``refresh``h]jr)}(hjk h]hrefresh}(hjm hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhji ubah}(h]h ]h"]h$]h&]uh1jkhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK=hje ubj)}(hhh]j)}(hXCallback function to load/sync all MRs from TVM hardware/firmware into the kernel cache.h]hXCallback function to load/sync all MRs from TVM hardware/firmware into the kernel cache.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKhj ubj)}(hhh]j)}(hCallback function to write to the MR specified by the parameter **mr**. Typically, writing to an MR extends the input buffer to that MR.h](h@Callback function to write to the MR specified by the parameter }(hj hhhNhNubj)}(h**mr**h]hmr}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhB. Typically, writing to an MR extends the input buffer to that MR.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhj hK>hj ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jehj hK>hj ubeh}(h]h ]h"]h$]h&]uh1j`hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj]hhhjhNubj)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKBhj]hhubj)}(hThe **refresh** callback is invoked when an MR with ``TSM_MR_F_LIVE`` set is being read and the cache is stale. It must reload all MRs with ``TSM_MR_F_LIVE`` set. The function parameter **tm** is a pointer pointing back to this structure.h](hThe }(hj hhhNhNubj)}(h **refresh**h]hrefresh}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh% callback is invoked when an MR with }(hj hhhNhNubjr)}(h``TSM_MR_F_LIVE``h]h TSM_MR_F_LIVE}(hj) hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj ubhG set is being read and the cache is stale. It must reload all MRs with }(hj hhhNhNubjr)}(h``TSM_MR_F_LIVE``h]h TSM_MR_F_LIVE}(hj; hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj ubh set. The function parameter }(hj hhhNhNubj)}(h**tm**h]htm}(hjM hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh. is a pointer pointing back to this structure.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhK?hj]hhubj)}(huThe **write** callback is invoked whenever an MR is being written. It takes two additional parameters besides **tm**:h](hThe }(hjf hhhNhNubj)}(h **write**h]hwrite}(hjn hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjf ubha callback is invoked whenever an MR is being written. It takes two additional parameters besides }(hjf hhhNhNubj)}(h**tm**h]htm}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjf ubh:}(hjf hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKChj]hhubj)}(hhh](j)}(hD**mr** - points to the MR (an element of **tm->mrs**) being written.h]j)}(hj h](j)}(h**mr**h]hmr}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh# - points to the MR (an element of }(hj hhhNhNubj)}(h **tm->mrs**h]htm->mrs}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh) being written.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKFhj ubah}(h]h ]h"]h$]h&]uh1jhj ubj)}(hJ**data** - contains the bytes to write and whose size is **mr->mr_size**. h]j)}(hI**data** - contains the bytes to write and whose size is **mr->mr_size**.h](j)}(h**data**h]hdata}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh1 - contains the bytes to write and whose size is }(hj hhhNhNubj)}(h**mr->mr_size**h]h mr->mr_size}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKGhj ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]j j uh1jhj hKFhj]hhubj)}(hcBoth **refresh** and **write** should return 0 on success and an appropriate error code on failure.h](hBoth }(hj hhhNhNubj)}(h **refresh**h]hrefresh}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubh and }(hj hhhNhNubj)}(h **write**h]hwrite}(hj- hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubhE should return 0 on success and an appropriate error code on failure.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhl/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:94: ./include/linux/tsm-mr.hhKIhj]hhubjq)}(hhh]h}(h]h ]h"]h$]h&]entries](j}*tsm_mr_create_attribute_group (C function)c.tsm_mr_create_attribute_grouphNtauh1jphj]hhhNhNubj)}(hhh](j)}(h`const struct attribute_group * tsm_mr_create_attribute_group (const struct tsm_measurements *tm)h]j)}(h^const struct attribute_group *tsm_mr_create_attribute_group(const struct tsm_measurements *tm)h](j)}(hconsth]hconst}(hj_ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ hhhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chK{ubj)}(h h]h }(hjn hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ hhhjm hK{ubj)}(hjh]hstruct}(hj| hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ hhhjm hK{ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ hhhjm hK{ubh)}(hhh]j)}(hattribute_grouph]hattribute_group}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&] refdomainjreftype identifier reftargetj modnameN classnameN c:parent_keysphinx.domains.c LookupKey)}data]j ASTIdentifier)}j tsm_mr_create_attribute_groupsbc.tsm_mr_create_attribute_groupasbuh1hhj[ hhhjm hK{ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj[ hhhjm hK{ubhdesc_sig_punctuation)}(hj h]h*}(hj hhhNhNubah}(h]h ]pah"]h$]h&]uh1j hj[ hhhjm hK{ubj)}(htsm_mr_create_attribute_grouph]j)}(hj h]htsm_mr_create_attribute_group}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]hhuh1jhj[ hhhjm hK{ubhdesc_parameterlist)}(h#(const struct tsm_measurements *tm)h]hdesc_parameter)}(h!const struct tsm_measurements *tmh](j)}(hja h]hconst}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(hjh]hstruct}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj)}(h h]h }(hj, hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubh)}(hhh]j)}(htsm_measurementsh]htsm_measurements}(hj= hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj: ubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetj? modnameN classnameNj j )}j ]j c.tsm_mr_create_attribute_groupasbuh1hhj ubj)}(h h]h }(hj[ hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubj )}(hj h]h*}(hji hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hj ubj)}(htmh]htm}(hjv hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]noemphhhuh1j hj ubah}(h]h ]h"]h$]h&]hhuh1j hj[ hhhjm hK{ubeh}(h]h ]h"]h$]h&]hhjuh1jjjhjW hhhjm hK{ubah}(h]jR ah ](jjeh"]h$]h&]jj)jhuh1jhjm hK{hjT hhubj)}(hhh]j)}(h:creates an attribute group for measurement registers (MRs)h]h:creates an attribute group for measurement registers (MRs)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chK{hj hhubah}(h]h ]h"]h$]h&]uh1jhjT hhhjm hK{ubeh}(h]h ](jfunctioneh"]h$]h&]j jj j jj jjjuh1jhhhj]hNhNubj)}(hXz**Parameters** ``const struct tsm_measurements *tm`` pointer to :c:type:`struct tsm_measurements ` containing the MR definitions. **Description** This function creates attributes corresponding to the MR definitions provided by **tm->mrs**. The created attributes will reference **tm** and its members. The caller must not free **tm** until after tsm_mr_free_attribute_group() is called. **Context** Process context. May sleep due to memory allocation. **Return** * On success, the pointer to a an attribute group is returned; otherwise * ``-EINVAL`` - Invalid MR definitions. * ``-ENOMEM`` - Out of memory.h](j)}(h**Parameters**h]j)}(hj h]h Parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj ubja)}(hhh]jf)}(h``const struct tsm_measurements *tm`` pointer to :c:type:`struct tsm_measurements ` containing the MR definitions. h](jl)}(h%``const struct tsm_measurements *tm``h]jr)}(hj h]h!const struct tsm_measurements *tm}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj ubah}(h]h ]h"]h$]h&]uh1jkhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chK}hj ubj)}(hhh]j)}(h^pointer to :c:type:`struct tsm_measurements ` containing the MR definitions.h](h pointer to }(hj hhhNhNubh)}(h4:c:type:`struct tsm_measurements `h]jr)}(hjh]hstruct tsm_measurements}(hjhhhNhNubah}(h]h ](xrefjc-typeeh"]h$]h&]uh1jqhjubah}(h]h ]h"]h$]h&]refdoc%driver-api/coco/measurement-registers refdomainjreftypetype refexplicitrefwarnj j )}j ]sb reftargettsm_measurementsuh1hhj hK}hj ubh containing the MR definitions.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhj hK}hj ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jehj hK}hj ubah}(h]h ]h"]h$]h&]uh1j`hj ubj)}(h**Description**h]j)}(hjEh]h Description}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjCubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj ubj)}(h]This function creates attributes corresponding to the MR definitions provided by **tm->mrs**.h](hQThis function creates attributes corresponding to the MR definitions provided by }(hj[hhhNhNubj)}(h **tm->mrs**h]htm->mrs}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1jhj[ubh.}(hj[hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chK~hj ubj)}(hThe created attributes will reference **tm** and its members. The caller must not free **tm** until after tsm_mr_free_attribute_group() is called.h](h&The created attributes will reference }(hj|hhhNhNubj)}(h**tm**h]htm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh+ and its members. The caller must not free }(hj|hhhNhNubj)}(h**tm**h]htm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhj|ubh5 until after tsm_mr_free_attribute_group() is called.}(hj|hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj ubj)}(h **Context**h]j)}(hjh]hContext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj ubj)}(h4Process context. May sleep due to memory allocation.h]h4Process context. May sleep due to memory allocation.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj ubj)}(h **Return**h]j)}(hjh]hReturn}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj ubj)}(hhh](j)}(hFOn success, the pointer to a an attribute group is returned; otherwiseh]j)}(hjh]hFOn success, the pointer to a an attribute group is returned; otherwise}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhjubah}(h]h ]h"]h$]h&]uh1jhjubj)}(h%``-EINVAL`` - Invalid MR definitions.h]j)}(hj h](jr)}(h ``-EINVAL``h]h-EINVAL}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj ubh - Invalid MR definitions.}(hj hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj ubah}(h]h ]h"]h$]h&]uh1jhjubj)}(h``-ENOMEM`` - Out of memory.h]j)}(hj1h](jr)}(h ``-ENOMEM``h]h-ENOMEM}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jqhj3ubh - Out of memory.}(hj3hhhNhNubeh}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhj/ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]j j uh1jhjhKhj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj]hhhNhNubjq)}(hhh]h}(h]h ]h"]h$]h&]entries](j}(tsm_mr_free_attribute_group (C function)c.tsm_mr_free_attribute_grouphNtauh1jphj]hhhNhNubj)}(hhh](j)}(hIvoid tsm_mr_free_attribute_group (const struct attribute_group *attr_grp)h]j)}(hHvoid tsm_mr_free_attribute_group(const struct attribute_group *attr_grp)h](hdesc_sig_keyword_type)}(hvoidh]hvoid}(hj}hhhNhNubah}(h]h ]ktah"]h$]h&]uh1j{hjwhhhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwhhhjhKubj)}(htsm_mr_free_attribute_grouph]j)}(htsm_mr_free_attribute_grouph]htsm_mr_free_attribute_group}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]hhuh1jhjwhhhjhKubj )}(h((const struct attribute_group *attr_grp)h]j )}(h&const struct attribute_group *attr_grph](j)}(hja h]hconst}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(hjh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hattribute_grouph]hattribute_group}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNj j )}j ]j )}j jsbc.tsm_mr_free_attribute_groupasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj )}(hj h]h*}(hj"hhhNhNubah}(h]h ]j ah"]h$]h&]uh1j hjubj)}(hattr_grph]hattr_grp}(hj/hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphhhuh1j hjubah}(h]h ]h"]h$]h&]hhuh1j hjwhhhjhKubeh}(h]h ]h"]h$]h&]hhjuh1jjjhjshhhjhKubah}(h]jnah ](jjeh"]h$]h&]jj)jhuh1jhjhKhjphhubj)}(hhh]j)}(hEfrees the attribute group returned by tsm_mr_create_attribute_group()h]hEfrees the attribute group returned by tsm_mr_create_attribute_group()}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhjVhhubah}(h]h ]h"]h$]h&]uh1jhjphhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]j jj jqjjqjjjuh1jhhhj]hNhNubj)}(h**Parameters** ``const struct attribute_group *attr_grp`` attribute group returned by tsm_mr_create_attribute_group() **Context** Process context.h](j)}(h**Parameters**h]j)}(hj{h]h Parameters}(hj}hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjyubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhjuubja)}(hhh]jf)}(hg``const struct attribute_group *attr_grp`` attribute group returned by tsm_mr_create_attribute_group() h](jl)}(h*``const struct attribute_group *attr_grp``h]jr)}(hjh]h&const struct attribute_group *attr_grp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jqhjubah}(h]h ]h"]h$]h&]uh1jkhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhjubj)}(hhh]j)}(h;attribute group returned by tsm_mr_create_attribute_group()h]h;attribute group returned by tsm_mr_create_attribute_group()}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jehjhKhjubah}(h]h ]h"]h$]h&]uh1j`hjuubj)}(h **Context**h]j)}(hjh]hContext}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhjuubj)}(hProcess context.h]hProcess context.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhv/var/lib/git/docbuild/linux/Documentation/driver-api/coco/measurement-registers:97: ./drivers/virt/coco/guest/tsm-mr.chKhjuubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj]hhhNhNubeh}(h]measurement-registersah ]h"]measurement registersah$]h&]uh1j[hhhhhhhKubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(j`N generatorN datestampN source_linkN source_urlN toc_backlinksentryfootnote_backlinksK sectnum_xformKstrip_commentsNstrip_elements_with_classesN strip_classesN report_levelK halt_levelKexit_status_levelKdebugNwarning_streamN tracebackinput_encoding utf-8-siginput_encoding_error_handlerstrictoutput_encodingutf-8output_encoding_error_handlerj,error_encodingutf-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourcehnj _destinationN _config_files]7/var/lib/git/docbuild/linux/Documentation/docutils.confafile_insertion_enabled raw_enabledKline_length_limitM'pep_referencesN pep_base_urlhttps://peps.python.org/pep_file_url_templatepep-%04drfc_referencesN rfc_base_url&https://datatracker.ietf.org/doc/html/ tab_widthKtrim_footnote_reference_spacesyntax_highlightlong smart_quotessmartquotes_locales]character_level_inline_markupdoctitle_xform docinfo_xformKsectsubtitle_xform image_loadinglinkembed_stylesheetcloak_email_addressessection_self_linkenvNubreporterNindirect_targets]substitution_defs}(hhjhjjj jj/j#j>j2jMjAj\jPjkj_jzjnjj}jjjjjjjjjjjjjjjjjjjjj.j"j=j1jLj@j[jOjjj^jyjmjj|jjjjjjjjjjjjjjjjjjjjj-j!j<j0jKj?jZjNjij]jxjljj{jjjjjjjjjjjjjjjjjjjjj,j j;j/jJj>jYjMjhj\jwjkjjzjjjjjjjjjjjjjjjjj jjjj+jj:j.jIj=jXjLusubstitution_names}(amphaposjastjbrvbarj bsolj/centj>colonjMcommaj\commatjkcopyjzcurrenjdarrjdegjdividejdollarjequalsjexcljfrac12jfrac14jfrac18jfrac34jfrac38j.frac58j=frac78jLgtj[halfjjhorbarjyhyphenjiexcljiquestjlaquojlarrjlcubjldquojlowbarjlparjlsqbjlsquojltj-microj<middotjKnbspjZnotjinumjxohmjordfjordmjparajpercntjperiodjplusjplusmnjpoundjquestjquotjraquoj,rarrj;rcubjJrdquojYregjhrparjwrsqbjrsquojsectjsemijshyjsoljsungjsup1jsup2jsup3j timesjtradej+uarrj:verbarjIyenjXurefnames}refids}nameids}jjs nametypes}jsh}(jj]jjj+ j0 jR jW jnjsu footnote_refs} citation_refs} autofootnotes]autofootnote_refs]symbol_footnotes]symbol_footnote_refs] footnotes] citations]autofootnote_startKsymbol_footnote_startK id_counter collectionsCounter}Rparse_messages]transform_messages] transformerN include_log]7Documentation/driver-api/coco/measurement-registers.rst(NNNNta decorationNhhub.