sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget4/translations/zh_CN/driver-api/media/drivers/ccs/ccsmodnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget4/translations/zh_TW/driver-api/media/drivers/ccs/ccsmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget4/translations/it_IT/driver-api/media/drivers/ccs/ccsmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget4/translations/ja_JP/driver-api/media/drivers/ccs/ccsmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget4/translations/ko_KR/driver-api/media/drivers/ccs/ccsmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget4/translations/sp_SP/driver-api/media/drivers/ccs/ccsmodnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhcomment)}(h5SPDX-License-Identifier: GPL-2.0-only OR BSD-3-Clauseh]h5SPDX-License-Identifier: GPL-2.0-only OR BSD-3-Clause}hhsbah}(h]h ]h"]h$]h&] xml:spacepreserveuh1hhhhhhN/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs.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*}hhsbah}(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\}hjsbah}(h]h ]h"]bsolah$]h&]uh1hhhhK hhhhubh)}(h*.. |cent| unicode:: U+000A2 .. CENT SIGNh]h¢}hjsbah}(h]h ]h"]centah$]h&]uh1hhhhK hhhhubh)}(h&.. |colon| unicode:: U+0003A .. COLONh]h:}hj-sbah}(h]h ]h"]colonah$]h&]uh1hhhhK hhhhubh)}(h&.. |comma| unicode:: U+0002C .. COMMAh]h,}hj<sbah}(h]h ]h"]commaah$]h&]uh1hhhhKhhhhubh)}(h... |commat| unicode:: U+00040 .. COMMERCIAL ATh]h@}hjKsbah}(h]h ]h"]commatah$]h&]uh1hhhhKhhhhubh)}(h/.. |copy| unicode:: U+000A9 .. COPYRIGHT SIGNh]h©}hjZsbah}(h]h ]h"]copyah$]h&]uh1hhhhKhhhhubh)}(h... |curren| unicode:: U+000A4 .. CURRENCY SIGNh]h¤}hjisbah}(h]h ]h"]currenah$]h&]uh1hhhhKhhhhubh)}(h0.. |darr| unicode:: U+02193 .. DOWNWARDS ARROWh]h↓}hjxsbah}(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⅜}hjsbah}(h]h ]h"]frac38ah$]h&]uh1hhhhKhhhhubh)}(h=.. |frac58| unicode:: U+0215D .. VULGAR FRACTION FIVE EIGHTHSh]h⅝}hjsbah}(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>}hj;sbah}(h]h ]h"]gtah$]h&]uh1hhhhKhhhhubh)}(h9.. |half| unicode:: U+000BD .. VULGAR FRACTION ONE HALFh]h½}hjJsbah}(h]h ]h"]halfah$]h&]uh1hhhhK hhhhubh)}(h/.. |horbar| unicode:: U+02015 .. HORIZONTAL BARh]h―}hjYsbah}(h]h ]h"]horbarah$]h&]uh1hhhhK!hhhhubh)}(h'.. |hyphen| unicode:: U+02010 .. HYPHENh]h‐}hjhsbah}(h]h ]h"]hyphenah$]h&]uh1hhhhK"hhhhubh)}(h:.. |iexcl| unicode:: U+000A1 .. INVERTED EXCLAMATION MARKh]h¡}hjwsbah}(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µ}hjsbah}(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 }hj:sbah}(h]h ]h"]nbspah$]h&]uh1hhhhK0hhhhubh)}(h).. |not| unicode:: U+000AC .. NOT SIGNh]h¬}hjIsbah}(h]h ]h"]notah$]h&]uh1hhhhK1hhhhubh)}(h,.. |num| unicode:: U+00023 .. NUMBER SIGNh]h#}hjXsbah}(h]h ]h"]numah$]h&]uh1hhhhK2hhhhubh)}(h).. |ohm| unicode:: U+02126 .. OHM SIGNh]hΩ}hjgsbah}(h]h ]h"]ohmah$]h&]uh1hhhhK3hhhhubh)}(h;.. |ordf| unicode:: U+000AA .. FEMININE ORDINAL INDICATORh]hª}hjvsbah}(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→}hjsbah}(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”}hj9sbah}(h]h ]h"]rdquoah$]h&]uh1hhhhKAhhhhubh)}(h0.. |reg| unicode:: U+000AE .. REGISTERED SIGNh]h®}hjHsbah}(h]h ]h"]regah$]h&]uh1hhhhKBhhhhubh)}(h2.. |rpar| unicode:: U+00029 .. RIGHT PARENTHESISh]h)}hjWsbah}(h]h ]h"]rparah$]h&]uh1hhhhKChhhhubh)}(h5.. |rsqb| unicode:: U+0005D .. RIGHT SQUARE BRACKETh]h]}hjfsbah}(h]h ]h"]rsqbah$]h&]uh1hhhhKDhhhhubh)}(h<.. |rsquo| unicode:: U+02019 .. RIGHT SINGLE QUOTATION MARKh]h’}hjusbah}(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™}hj sbah}(h]h ]h"]tradeah$]h&]uh1hhhhKOhhhhubh)}(h... |uarr| unicode:: U+02191 .. UPWARDS ARROWh]h↑}hjsbah}(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¥}hj8sbah}(h]h ]h"]yenah$]h&]uh1hhhhKRhhhhubhtarget)}(h.. _media-ccs-driver:h]h}(h]h ]h"]h$]h&]refidmedia-ccs-driveruh1jGhK[hhhhhhubhsection)}(hhh](htitle)}(hMIPI CCS camera sensor driverh]hMIPI CCS camera sensor driver}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jZhjWhhhhhKubh paragraph)}(hThe MIPI CCS camera sensor driver is a generic driver for `MIPI CCS `_ compliant camera sensors.h](h:The MIPI CCS camera sensor driver is a generic driver for }(hjlhhhNhNubh reference)}(hD`MIPI CCS `_h]hMIPI CCS}(hjvhhhNhNubah}(h]h ]h"]h$]h&]nameMIPI CCSrefuri6https://www.mipi.org/specifications/camera-command-setuh1jthjlubjH)}(h9 h]h}(h]mipi-ccsah ]h"]mipi ccsah$]h&]refurijuh1jG referencedKhjlubh compliant camera sensors.}(hjlhhhNhNubeh}(h]h ]h"]h$]h&]uh1jjhhhK hjWhhubjk)}(hCAlso see :ref:`the CCS driver UAPI documentation `.h](h Also see }(hjhhhNhNubh)}(h9:ref:`the CCS driver UAPI documentation `h]hinline)}(hjh]h!the CCS driver UAPI documentation}(hjhhhNhNubah}(h]h ](xrefstdstd-refeh"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]refdoc driver-api/media/drivers/ccs/ccs refdomainjreftyperef refexplicitrefwarn reftargetmedia-ccs-uapiuh1hhhhKhjubh.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jjhhhKhjWhhubjV)}(hhh](j[)}(hCCS static datah]hCCS static data}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jZhjhhhhhKubjk)}(hThe MIPI CCS driver supports CCS static data for all compliant devices, including not just those compliant with CCS 1.1 but also CCS 1.0 and SMIA(++). For CCS the file names are formed ash]hThe MIPI CCS driver supports CCS static data for all compliant devices, including not just those compliant with CCS 1.1 but also CCS 1.0 and SMIA(++). For CCS the file names are formed as}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhKhjhhubh block_quote)}(hYccs/ccs-sensor-vvvv-mmmm-rrrr.fw (sensor) and ccs/ccs-module-vvvv-mmmm-rrrr.fw (module). h]jk)}(hXccs/ccs-sensor-vvvv-mmmm-rrrr.fw (sensor) and ccs/ccs-module-vvvv-mmmm-rrrr.fw (module).h]hXccs/ccs-sensor-vvvv-mmmm-rrrr.fw (sensor) and ccs/ccs-module-vvvv-mmmm-rrrr.fw (module).}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhKhjubah}(h]h ]h"]h$]h&]uh1jhhhKhjhhubjk)}(h=For SMIA++ compliant devices the corresponding file names areh]h=For SMIA++ compliant devices the corresponding file names are}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhKhjhhubj)}(hYccs/smiapp-sensor-vv-mmmm-rr.fw (sensor) and ccs/smiapp-module-vv-mmmm-rrrr.fw (module). h]jk)}(hXccs/smiapp-sensor-vv-mmmm-rr.fw (sensor) and ccs/smiapp-module-vv-mmmm-rrrr.fw (module).h]hXccs/smiapp-sensor-vv-mmmm-rr.fw (sensor) and ccs/smiapp-module-vv-mmmm-rrrr.fw (module).}(hj"hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhKhjubah}(h]h ]h"]h$]h&]uh1jhhhKhjhhubjk)}(h@For SMIA (non-++) compliant devices the static data file name ish]h@For SMIA (non-++) compliant devices the static data file name is}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhKhjhhubj)}(h(ccs/smia-sensor-vv-mmmm-rr.fw (sensor). h]jk)}(h'ccs/smia-sensor-vv-mmmm-rr.fw (sensor).h]h'ccs/smia-sensor-vv-mmmm-rr.fw (sensor).}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhK!hjDubah}(h]h ]h"]h$]h&]uh1jhhhK!hjhhubjk)}(hmvvvv or vv denotes MIPI and SMIA manufacturer IDs respectively, mmmm model ID and rrrr or rr revision number.h]hmvvvv or vv denotes MIPI and SMIA manufacturer IDs respectively, mmmm model ID and rrrr or rr revision number.}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhK#hjhhubjV)}(hhh](j[)}(h CCS toolsh]h CCS tools}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1jZhjjhhhhhK'ubjk)}(h`CCS tools `_ is a set of tools for working with CCS static data files. CCS tools includes a definition of the human-readable CCS static data YAML format and includes a program to convert it to a binary.h](ju)}(h:`CCS tools `_h]h CCS tools}(hjhhhNhNubah}(h]h ]h"]h$]h&]name CCS toolsj+https://github.com/MIPI-Alliance/ccs-tools/uh1jthj{ubjH)}(h. h]h}(h]id1ah ]h"] ccs toolsah$]h&]refurijuh1jGjKhj{ubh is a set of tools for working with CCS static data files. CCS tools includes a definition of the human-readable CCS static data YAML format and includes a program to convert it to a binary.}(hj{hhhNhNubeh}(h]h ]h"]h$]h&]uh1jjhhhK)hjjhhubeh}(h] ccs-toolsah ]h"]h$]jah&]uh1jUhjhhhhhK'jKubeh}(h]ccs-static-dataah ]h"]ccs static dataah$]h&]uh1jUhjWhhhhhKubjV)}(hhh](j[)}(hRegister definition generatorh]hRegister definition generator}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jZhjhhhhhK/ubjk)}(hXaThe ccs-regs.asc file contains MIPI CCS register definitions that are used to produce C source code files for definitions that can be better used by programs written in C language. As there are many dependencies between the produced files, please do not modify them manually as it's error-prone and in vain, but instead change the script producing them.h]hXcThe ccs-regs.asc file contains MIPI CCS register definitions that are used to produce C source code files for definitions that can be better used by programs written in C language. As there are many dependencies between the produced files, please do not modify them manually as it’s error-prone and in vain, but instead change the script producing them.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhK1hjhhubjV)}(hhh](j[)}(hUsageh]hUsage}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jZhjhhhhhK8ubjk)}(hRConventionally the script is called this way to update the CCS driver definitions:h]hRConventionally the script is called this way to update the CCS driver definitions:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhK:hjhhubh literal_block)}(hX$ Documentation/driver-api/media/drivers/ccs/mk-ccs-regs -k \ -e drivers/media/i2c/ccs/ccs-regs.h \ -L drivers/media/i2c/ccs/ccs-limits.h \ -l drivers/media/i2c/ccs/ccs-limits.c \ -c Documentation/driver-api/media/drivers/ccs/ccs-regs.asch]hX$ Documentation/driver-api/media/drivers/ccs/mk-ccs-regs -k \ -e drivers/media/i2c/ccs/ccs-regs.h \ -L drivers/media/i2c/ccs/ccs-limits.h \ -l drivers/media/i2c/ccs/ccs-limits.c \ -c Documentation/driver-api/media/drivers/ccs/ccs-regs.asc}hjsbah}(h]h ]h"]h$]h&]hhforcelanguagenonehighlight_args}uh1jhhhK=hjhhubeh}(h]usageah ]h"]usageah$]h&]uh1jUhjhhhhhK8ubeh}(h]register-definition-generatorah ]h"]register definition generatorah$]h&]uh1jUhjWhhhhhK/ubeh}(h](mipi-ccs-camera-sensor-driverjTeh ]h"](mipi ccs camera sensor drivermedia-ccs-drivereh$]h&]uh1jUhhhhhhhKexpect_referenced_by_name}jjIsexpect_referenced_by_id}jTjIsubjV)}(hhh](j[)}(hCCS PLL calculatorh]hCCS PLL calculator}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jZhj&hhhhhKFubjk)}(hXGThe CCS PLL calculator is used to compute the PLL configuration, given sensor's capabilities as well as board configuration and user specified configuration. As the configuration space that encompasses all these configurations is vast, the PLL calculator isn't entirely trivial. Yet it is relatively simple to use for a driver.h]hXKThe CCS PLL calculator is used to compute the PLL configuration, given sensor’s capabilities as well as board configuration and user specified configuration. As the configuration space that encompasses all these configurations is vast, the PLL calculator isn’t entirely trivial. Yet it is relatively simple to use for a driver.}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhKHhj&hhubjk)}(hLThe PLL model implemented by the PLL calculator corresponds to MIPI CCS 1.1.h]hLThe PLL model implemented by the PLL calculator corresponds to MIPI CCS 1.1.}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhhhKNhj&hhubhindex)}(hhh]h}(h]h ]h"]h$]h&]entries](singleccs_pll_branch_fr (C struct)c.ccs_pll_branch_frhNtauh1jShj&hhhNhNubhdesc)}(hhh](hdesc_signature)}(hccs_pll_branch_frh]hdesc_signature_line)}(hstruct ccs_pll_branch_frh](hdesc_sig_keyword)}(hstructh]hstruct}(hjwhhhNhNubah}(h]h ]kah"]h$]h&]uh1juhjqhhhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKubhdesc_sig_space)}(h h]h }(hjhhhNhNubah}(h]h ]wah"]h$]h&]uh1jhjqhhhjhKubh desc_name)}(hccs_pll_branch_frh]h desc_sig_name)}(hjmh]hccs_pll_branch_fr}(hjhhhNhNubah}(h]h ]nah"]h$]h&]uh1jhjubah}(h]h ](sig-namedescnameeh"]h$]h&]hhuh1jhjqhhhjhKubeh}(h]h ]h"]h$]h&]hh add_permalinkuh1josphinx_line_type declaratorhjkhhhjhKubah}(h]jbah ](sig sig-objecteh"]h$]h&] is_multiline _toc_parts) _toc_namehuh1jihjhKhjfhhubh desc_content)}(hhh]jk)}(hCCS PLL configuration (front)h]hCCS PLL configuration (front)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK:hjhhubah}(h]h ]h"]h$]h&]uh1jhjfhhhjhKubeh}(h]h ](cstructeh"]h$]h&]domainjobjtypejdesctypejnoindex noindexentrynocontentsentryuh1jdhhhj&hNhNubh container)}(hXl**Definition**:: struct ccs_pll_branch_fr { u16 pre_pll_clk_div; u16 pll_multiplier; u32 pll_ip_clk_freq_hz; u32 pll_op_clk_freq_hz; }; **Members** ``pre_pll_clk_div`` Pre-PLL clock divisor ``pll_multiplier`` PLL multiplier ``pll_ip_clk_freq_hz`` PLL input clock frequency ``pll_op_clk_freq_hz`` PLL output clock frequencyh](jk)}(h**Definition**::h](hstrong)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK>hjubj)}(hstruct ccs_pll_branch_fr { u16 pre_pll_clk_div; u16 pll_multiplier; u32 pll_ip_clk_freq_hz; u32 pll_op_clk_freq_hz; };h]hstruct ccs_pll_branch_fr { u16 pre_pll_clk_div; u16 pll_multiplier; u32 pll_ip_clk_freq_hz; u32 pll_op_clk_freq_hz; };}hjsbah}(h]h ]h"]h$]h&]hhuh1jhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK@hjubjk)}(h **Members**h]j)}(hj(h]hMembers}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj&ubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKGhjubhdefinition_list)}(hhh](hdefinition_list_item)}(h*``pre_pll_clk_div`` Pre-PLL clock divisor h](hterm)}(h``pre_pll_clk_div``h]hliteral)}(hjMh]hpre_pll_clk_div}(hjQhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjKubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK?hjEubh definition)}(hhh]jk)}(hPre-PLL clock divisorh]hPre-PLL clock divisor}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjdhK?hjgubah}(h]h ]h"]h$]h&]uh1jehjEubeh}(h]h ]h"]h$]h&]uh1jChjdhK?hj@ubjD)}(h"``pll_multiplier`` PLL multiplier h](jJ)}(h``pll_multiplier``h]jP)}(hjh]hpll_multiplier}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK@hjubjf)}(hhh]jk)}(hPLL multiplierh]hPLL multiplier}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhK@hjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhK@hj@ubjD)}(h1``pll_ip_clk_freq_hz`` PLL input clock frequency h](jJ)}(h``pll_ip_clk_freq_hz``h]jP)}(hjh]hpll_ip_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKAhjubjf)}(hhh]jk)}(hPLL input clock frequencyh]hPLL input clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKAhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKAhj@ubjD)}(h1``pll_op_clk_freq_hz`` PLL output clock frequencyh](jJ)}(h``pll_op_clk_freq_hz``h]jP)}(hjh]hpll_op_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKAhjubjf)}(hhh]jk)}(hPLL output clock frequencyh]hPLL output clock frequency}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKBhj ubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChj hKAhj@ubeh}(h]h ]h"]h$]h&]uh1j>hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj&hhhNhNubjk)}(h**Description**h]j)}(hj? h]h Description}(hjA hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj= ubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKEhj&hhubjk)}(h.A single branch front-end of the CCS PLL tree.h]h.A single branch front-end of the CCS PLL tree.}(hjU hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK;hj&hhubjT)}(hhh]h}(h]h ]h"]h$]h&]entries](j`ccs_pll_branch_bk (C struct)c.ccs_pll_branch_bkhNtauh1jShj&hhhNhNubje)}(hhh](jj)}(hccs_pll_branch_bkh]jp)}(hstruct ccs_pll_branch_bkh](jv)}(hjyh]hstruct}(hj} hhhNhNubah}(h]h ]jah"]h$]h&]uh1juhjy hhhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK@ubj)}(h h]h }(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjy hhhj hK@ubj)}(hccs_pll_branch_bkh]j)}(hjw h]hccs_pll_branch_bk}(hj hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhj ubah}(h]h ](jjeh"]h$]h&]hhuh1jhjy hhhj hK@ubeh}(h]h ]h"]h$]h&]hhjuh1jojjhju hhhj hK@ubah}(h]jp ah ](jjeh"]h$]h&]jj)jhuh1jihj hK@hjr hhubj)}(hhh]jk)}(hCCS PLL configuration (back)h]hCCS PLL configuration (back)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKKhj hhubah}(h]h ]h"]h$]h&]uh1jhjr hhhj hK@ubeh}(h]h ](jstructeh"]h$]h&]jjjj jj jjjuh1jdhhhj&hNhNubj)}(hXN**Definition**:: struct ccs_pll_branch_bk { u16 sys_clk_div; u16 pix_clk_div; u32 sys_clk_freq_hz; u32 pix_clk_freq_hz; }; **Members** ``sys_clk_div`` System clock divider ``pix_clk_div`` Pixel clock divider ``sys_clk_freq_hz`` System clock frequency ``pix_clk_freq_hz`` Pixel clock frequencyh](jk)}(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&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKOhj ubj)}(hystruct ccs_pll_branch_bk { u16 sys_clk_div; u16 pix_clk_div; u32 sys_clk_freq_hz; u32 pix_clk_freq_hz; };h]hystruct ccs_pll_branch_bk { u16 sys_clk_div; u16 pix_clk_div; u32 sys_clk_freq_hz; u32 pix_clk_freq_hz; };}hj sbah}(h]h ]h"]h$]h&]hhuh1jhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKQhj ubjk)}(h **Members**h]j)}(hj h]hMembers}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKXhj ubj?)}(hhh](jD)}(h%``sys_clk_div`` System clock divider h](jJ)}(h``sys_clk_div``h]jP)}(hj, h]h sys_clk_div}(hj. hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj* ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKPhj& ubjf)}(hhh]jk)}(hSystem clock dividerh]hSystem clock divider}(hjE hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjA hKPhjB ubah}(h]h ]h"]h$]h&]uh1jehj& ubeh}(h]h ]h"]h$]h&]uh1jChjA hKPhj# ubjD)}(h$``pix_clk_div`` Pixel clock divider h](jJ)}(h``pix_clk_div``h]jP)}(hje h]h pix_clk_div}(hjg hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjc ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKQhj_ ubjf)}(hhh]jk)}(hPixel clock dividerh]hPixel clock divider}(hj~ hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjz hKQhj{ ubah}(h]h ]h"]h$]h&]uh1jehj_ ubeh}(h]h ]h"]h$]h&]uh1jChjz hKQhj# ubjD)}(h+``sys_clk_freq_hz`` System clock frequency h](jJ)}(h``sys_clk_freq_hz``h]jP)}(hj h]hsys_clk_freq_hz}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKRhj ubjf)}(hhh]jk)}(hSystem clock frequencyh]hSystem clock frequency}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKRhj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKRhj# ubjD)}(h)``pix_clk_freq_hz`` Pixel clock frequencyh](jJ)}(h``pix_clk_freq_hz``h]jP)}(hj h]hpix_clk_freq_hz}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKRhj ubjf)}(hhh]jk)}(hPixel clock frequencyh]hPixel clock frequency}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKShj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKRhj# ubeh}(h]h ]h"]h$]h&]uh1j>hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj&hhhNhNubjk)}(h**Description**h]j)}(hj h]h Description}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKVhj&hhubjk)}(h-A single branch back-end of the CCS PLL tree.h]h-A single branch back-end of the CCS PLL tree.}(hj0 hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKLhj&hhubjT)}(hhh]h}(h]h ]h"]h$]h&]entries](j`ccs_pll (C struct) c.ccs_pllhNtauh1jShj&hhhNhNubje)}(hhh](jj)}(hccs_pllh]jp)}(hstruct ccs_pllh](jv)}(hjyh]hstruct}(hjX hhhNhNubah}(h]h ]jah"]h$]h&]uh1juhjT hhhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKQubj)}(h h]h }(hjf hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjT hhhje hKQubj)}(hccs_pllh]j)}(hjR h]hccs_pll}(hjx hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjt ubah}(h]h ](jjeh"]h$]h&]hhuh1jhjT hhhje hKQubeh}(h]h ]h"]h$]h&]hhjuh1jojjhjP hhhje hKQubah}(h]jK ah ](jjeh"]h$]h&]jj)jhuh1jihje hKQhjM hhubj)}(hhh]jk)}(hFull CCS PLL configurationh]hFull CCS PLL configuration}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK\hj hhubah}(h]h ]h"]h$]h&]uh1jhjM hhhje hKQubeh}(h]h ](jstructeh"]h$]h&]jjjj jj jjjuh1jdhhhj&hNhNubj)}(hX**Definition**:: struct ccs_pll { u8 bus_type; u8 op_lanes; u8 vt_lanes; struct { u8 lanes; } csi2; u8 binning_horizontal; u8 binning_vertical; u8 scale_m; u8 scale_n; u8 bits_per_pixel; u8 op_bits_per_lane; u16 flags; u32 link_freq; u32 ext_clk_freq_hz; struct ccs_pll_branch_fr vt_fr; struct ccs_pll_branch_bk vt_bk; struct ccs_pll_branch_fr op_fr; struct ccs_pll_branch_bk op_bk; u32 pixel_rate_csi; u32 pixel_rate_pixel_array; }; **Members** ``bus_type`` Type of the data bus, CCS_PLL_BUS_TYPE_* (input) ``op_lanes`` Number of operational lanes (input) ``vt_lanes`` Number of video timing lanes (input) ``csi2`` CSI-2 related parameters ``csi2.lanes`` The number of the CSI-2 data lanes (input) ``binning_horizontal`` Horizontal binning factor (input) ``binning_vertical`` Vertical binning factor (input) ``scale_m`` Downscaling factor, M component, [16, max] (input) ``scale_n`` Downscaling factor, N component, typically 16 (input) ``bits_per_pixel`` Bits per pixel on the output data bus (input) ``op_bits_per_lane`` Number of bits per OP lane (input) ``flags`` CCS_PLL_FLAG_* (input) ``link_freq`` Chosen link frequency (input) ``ext_clk_freq_hz`` External clock frequency, i.e. the sensor's input clock (input) ``vt_fr`` Video timing front-end configuration (output) ``vt_bk`` Video timing back-end configuration (output) ``op_fr`` Operational timing front-end configuration (output) ``op_bk`` Operational timing back-end configuration (output) ``pixel_rate_csi`` Pixel rate on the output data bus (output) ``pixel_rate_pixel_array`` Nominal pixel rate in the sensor's pixel array (output)h](jk)}(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&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhK`hj ubj)}(hXstruct ccs_pll { u8 bus_type; u8 op_lanes; u8 vt_lanes; struct { u8 lanes; } csi2; u8 binning_horizontal; u8 binning_vertical; u8 scale_m; u8 scale_n; u8 bits_per_pixel; u8 op_bits_per_lane; u16 flags; u32 link_freq; u32 ext_clk_freq_hz; struct ccs_pll_branch_fr vt_fr; struct ccs_pll_branch_bk vt_bk; struct ccs_pll_branch_fr op_fr; struct ccs_pll_branch_bk op_bk; u32 pixel_rate_csi; u32 pixel_rate_pixel_array; };h]hXstruct ccs_pll { u8 bus_type; u8 op_lanes; u8 vt_lanes; struct { u8 lanes; } csi2; u8 binning_horizontal; u8 binning_vertical; u8 scale_m; u8 scale_n; u8 bits_per_pixel; u8 op_bits_per_lane; u16 flags; u32 link_freq; u32 ext_clk_freq_hz; struct ccs_pll_branch_fr vt_fr; struct ccs_pll_branch_bk vt_bk; struct ccs_pll_branch_fr op_fr; struct ccs_pll_branch_bk op_bk; u32 pixel_rate_csi; u32 pixel_rate_pixel_array; };}hj sbah}(h]h ]h"]h$]h&]hhuh1jhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKbhj ubjk)}(h **Members**h]j)}(hj h]hMembers}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhj ubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKzhj ubj?)}(hhh](jD)}(h>``bus_type`` Type of the data bus, CCS_PLL_BUS_TYPE_* (input) h](jJ)}(h ``bus_type``h]jP)}(hj h]hbus_type}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKahj ubjf)}(hhh]jk)}(h0Type of the data bus, CCS_PLL_BUS_TYPE_* (input)h]h0Type of the data bus, CCS_PLL_BUS_TYPE_* (input)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKahj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKahj ubjD)}(h1``op_lanes`` Number of operational lanes (input) h](jJ)}(h ``op_lanes``h]jP)}(hj@ h]hop_lanes}(hjB hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj> ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKbhj: ubjf)}(hhh]jk)}(h#Number of operational lanes (input)h]h#Number of operational lanes (input)}(hjY hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjU hKbhjV ubah}(h]h ]h"]h$]h&]uh1jehj: ubeh}(h]h ]h"]h$]h&]uh1jChjU hKbhj ubjD)}(h2``vt_lanes`` Number of video timing lanes (input) h](jJ)}(h ``vt_lanes``h]jP)}(hjy h]hvt_lanes}(hj{ hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjw ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKchjs ubjf)}(hhh]jk)}(h$Number of video timing lanes (input)h]h$Number of video timing lanes (input)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKchj ubah}(h]h ]h"]h$]h&]uh1jehjs ubeh}(h]h ]h"]h$]h&]uh1jChj hKchj ubjD)}(h"``csi2`` CSI-2 related parameters h](jJ)}(h``csi2``h]jP)}(hj h]hcsi2}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKdhj ubjf)}(hhh]jk)}(hCSI-2 related parametersh]hCSI-2 related parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKdhj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKdhj ubjD)}(h:``csi2.lanes`` The number of the CSI-2 data lanes (input) h](jJ)}(h``csi2.lanes``h]jP)}(hj h]h csi2.lanes}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKehj ubjf)}(hhh]jk)}(h*The number of the CSI-2 data lanes (input)h]h*The number of the CSI-2 data lanes (input)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKehj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKehj ubjD)}(h9``binning_horizontal`` Horizontal binning factor (input) h](jJ)}(h``binning_horizontal``h]jP)}(hj$ h]hbinning_horizontal}(hj& hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj" ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKghj ubjf)}(hhh]jk)}(h!Horizontal binning factor (input)h]h!Horizontal binning factor (input)}(hj= hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj9 hKghj: ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj9 hKghj ubjD)}(h5``binning_vertical`` Vertical binning factor (input) h](jJ)}(h``binning_vertical``h]jP)}(hj] h]hbinning_vertical}(hj_ hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj[ ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKfhjW ubjf)}(hhh]jk)}(hVertical binning factor (input)h]hVertical binning factor (input)}(hjv hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjr hKfhjs ubah}(h]h ]h"]h$]h&]uh1jehjW ubeh}(h]h ]h"]h$]h&]uh1jChjr hKfhj ubjD)}(h?``scale_m`` Downscaling factor, M component, [16, max] (input) h](jJ)}(h ``scale_m``h]jP)}(hj h]hscale_m}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhhj ubjf)}(hhh]jk)}(h2Downscaling factor, M component, [16, max] (input)h]h2Downscaling factor, M component, [16, max] (input)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKhhj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKhhj ubjD)}(hB``scale_n`` Downscaling factor, N component, typically 16 (input) h](jJ)}(h ``scale_n``h]jP)}(hj h]hscale_n}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKihj ubjf)}(hhh]jk)}(h5Downscaling factor, N component, typically 16 (input)h]h5Downscaling factor, N component, typically 16 (input)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKihj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKihj ubjD)}(hA``bits_per_pixel`` Bits per pixel on the output data bus (input) h](jJ)}(h``bits_per_pixel``h]jP)}(hjh]hbits_per_pixel}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKjhjubjf)}(hhh]jk)}(h-Bits per pixel on the output data bus (input)h]h-Bits per pixel on the output data bus (input)}(hj!hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKjhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKjhj ubjD)}(h8``op_bits_per_lane`` Number of bits per OP lane (input) h](jJ)}(h``op_bits_per_lane``h]jP)}(hjAh]hop_bits_per_lane}(hjChhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj?ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKkhj;ubjf)}(hhh]jk)}(h"Number of bits per OP lane (input)h]h"Number of bits per OP lane (input)}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjVhKkhjWubah}(h]h ]h"]h$]h&]uh1jehj;ubeh}(h]h ]h"]h$]h&]uh1jChjVhKkhj ubjD)}(h!``flags`` CCS_PLL_FLAG_* (input) h](jJ)}(h ``flags``h]jP)}(hjzh]hflags}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjxubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKlhjtubjf)}(hhh]jk)}(hCCS_PLL_FLAG_* (input)h]hCCS_PLL_FLAG_* (input)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKlhjubah}(h]h ]h"]h$]h&]uh1jehjtubeh}(h]h ]h"]h$]h&]uh1jChjhKlhj ubjD)}(h,``link_freq`` Chosen link frequency (input) h](jJ)}(h ``link_freq``h]jP)}(hjh]h link_freq}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKmhjubjf)}(hhh]jk)}(hChosen link frequency (input)h]hChosen link frequency (input)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKmhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKmhj ubjD)}(hT``ext_clk_freq_hz`` External clock frequency, i.e. the sensor's input clock (input) h](jJ)}(h``ext_clk_freq_hz``h]jP)}(hjh]hext_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKohjubjf)}(hhh]jk)}(h?External clock frequency, i.e. the sensor's input clock (input)h]hAExternal clock frequency, i.e. the sensor’s input clock (input)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKnhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKohj ubjD)}(h8``vt_fr`` Video timing front-end configuration (output) h](jJ)}(h ``vt_fr``h]jP)}(hj&h]hvt_fr}(hj(hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj$ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKphj ubjf)}(hhh]jk)}(h-Video timing front-end configuration (output)h]h-Video timing front-end configuration (output)}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj;hKphj<ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj;hKphj ubjD)}(h7``vt_bk`` Video timing back-end configuration (output) h](jJ)}(h ``vt_bk``h]jP)}(hj_h]hvt_bk}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj]ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKqhjYubjf)}(hhh]jk)}(h,Video timing back-end configuration (output)h]h,Video timing back-end configuration (output)}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjthKqhjuubah}(h]h ]h"]h$]h&]uh1jehjYubeh}(h]h ]h"]h$]h&]uh1jChjthKqhj ubjD)}(h>``op_fr`` Operational timing front-end configuration (output) h](jJ)}(h ``op_fr``h]jP)}(hjh]hop_fr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKrhjubjf)}(hhh]jk)}(h3Operational timing front-end configuration (output)h]h3Operational timing front-end configuration (output)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKrhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKrhj ubjD)}(h=``op_bk`` Operational timing back-end configuration (output) h](jJ)}(h ``op_bk``h]jP)}(hjh]hop_bk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKshjubjf)}(hhh]jk)}(h2Operational timing back-end configuration (output)h]h2Operational timing back-end configuration (output)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKshjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKshj ubjD)}(h>``pixel_rate_csi`` Pixel rate on the output data bus (output) h](jJ)}(h``pixel_rate_csi``h]jP)}(hj h]hpixel_rate_csi}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKthjubjf)}(hhh]jk)}(h*Pixel rate on the output data bus (output)h]h*Pixel rate on the output data bus (output)}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKthj ubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKthj ubjD)}(hR``pixel_rate_pixel_array`` Nominal pixel rate in the sensor's pixel array (output)h](jJ)}(h``pixel_rate_pixel_array``h]jP)}(hjCh]hpixel_rate_pixel_array}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjAubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKuhj=ubjf)}(hhh]jk)}(h7Nominal pixel rate in the sensor's pixel array (output)h]h9Nominal pixel rate in the sensor’s pixel array (output)}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjXhKuhjYubah}(h]h ]h"]h$]h&]uh1jehj=ubeh}(h]h ]h"]h$]h&]uh1jChjXhKuhj ubeh}(h]h ]h"]h$]h&]uh1j>hj ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj&hhhNhNubjk)}(h**Description**h]j)}(hjh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKyhj&hhubjk)}(h``min_pll_op_clk_freq_hz`` Minimum PLL output clock frequency h](jJ)}(h``min_pll_op_clk_freq_hz``h]jP)}(hjh]hmin_pll_op_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h"Minimum PLL output clock frequencyh]h"Minimum PLL output clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjiubjD)}(h=``max_pll_op_clk_freq_hz`` Maximum PLL output clock frequencyh](jJ)}(h``max_pll_op_clk_freq_hz``h]jP)}(hjh]hmax_pll_op_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h"Maximum PLL output clock frequencyh]h"Maximum PLL output clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjiubeh}(h]h ]h"]h$]h&]uh1j>hj!ubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj&hhhNhNubjT)}(hhh]h}(h]h ]h"]h$]h&]entries](j`#ccs_pll_branch_limits_bk (C struct)c.ccs_pll_branch_limits_bkhNtauh1jShj&hhhNhNubje)}(hhh](jj)}(hccs_pll_branch_limits_bkh]jp)}(hstruct ccs_pll_branch_limits_bkh](jv)}(hjyh]hstruct}(hj[hhhNhNubah}(h]h ]jah"]h$]h&|]uh1juhjWhhhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKubj)}(h h]h }(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjWhhhjhhKubj)}(hccs_pll_branch_limits_bkh]j)}(hjUh]hccs_pll_branch_limits_bk}(hj{hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjwubah}(h]h ](jjeh"]h$]h&]hhuh1jhjWhhhjhhKubeh}(h]h ]h"]h$]h&]hhjuh1jojjhjShhhjhhKubah}(h]jNah ](jjeh"]h$]h&]jj)jhuh1jihjhhKhjPhhubj)}(hhh]jk)}(hCCS PLL back-end limitsh]hCCS PLL back-end limits}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjhhubah}(h]h ]h"]h$]h&]uh1jhjPhhhjhhKubeh}(h]h ](jstructeh"]h$]h&]jjjjjjjjjuh1jdhhhj&hNhNubj)}(hX**Definition**:: struct ccs_pll_branch_limits_bk { u16 min_sys_clk_div; u16 max_sys_clk_div; u32 min_sys_clk_freq_hz; u32 max_sys_clk_freq_hz; u16 min_pix_clk_div; u16 max_pix_clk_div; u32 min_pix_clk_freq_hz; u32 max_pix_clk_freq_hz; }; **Members** ``min_sys_clk_div`` Minimum system clock divider ``max_sys_clk_div`` Maximum system clock divider ``min_sys_clk_freq_hz`` Minimum system clock frequency ``max_sys_clk_freq_hz`` Maximum system clock frequency ``min_pix_clk_div`` Minimum pixel clock divider ``max_pix_clk_div`` Maximum pixel clock divider ``min_pix_clk_freq_hz`` Minimum pixel clock frequency ``max_pix_clk_freq_hz`` Maximum pixel clock frequencyh](jk)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh:}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubj)}(hstruct ccs_pll_branch_limits_bk { u16 min_sys_clk_div; u16 max_sys_clk_div; u32 min_sys_clk_freq_hz; u32 max_sys_clk_freq_hz; u16 min_pix_clk_div; u16 max_pix_clk_div; u32 min_pix_clk_freq_hz; u32 max_pix_clk_freq_hz; };h]hstruct ccs_pll_branch_limits_bk { u16 min_sys_clk_div; u16 max_sys_clk_div; u32 min_sys_clk_freq_hz; u32 max_sys_clk_freq_hz; u16 min_pix_clk_div; u16 max_pix_clk_div; u32 min_pix_clk_freq_hz; u32 max_pix_clk_freq_hz; };}hjsbah}(h]h ]h"]h$]h&]hhuh1jhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjk)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubj?)}(hhh](jD)}(h1``min_sys_clk_div`` Minimum system clock divider h](jJ)}(h``min_sys_clk_div``h]jP)}(hj h]hmin_sys_clk_div}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(hMinimum system clock dividerh]hMinimum system clock divider}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhj ubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h1``max_sys_clk_div`` Maximum system clock divider h](jJ)}(h``max_sys_clk_div``h]jP)}(hjCh]hmax_sys_clk_div}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjAubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhj=ubjf)}(hhh]jk)}(hMaximum system clock dividerh]hMaximum system clock divider}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjXhKhjYubah}(h]h ]h"]h$]h&]uh1jehj=ubeh}(h]h ]h"]h$]h&]uh1jChjXhKhjubjD)}(h7``min_sys_clk_freq_hz`` Minimum system clock frequency h](jJ)}(h``min_sys_clk_freq_hz``h]jP)}(hj|h]hmin_sys_clk_freq_hz}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjzubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjvubjf)}(hhh]jk)}(hMinimum system clock frequencyh]hMinimum system clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjvubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h7``max_sys_clk_freq_hz`` Maximum system clock frequency h](jJ)}(h``max_sys_clk_freq_hz``h]jP)}(hjh]hmax_sys_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(hMaximum system clock frequencyh]hMaximum system clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h0``min_pix_clk_div`` Minimum pixel clock divider h](jJ)}(h``min_pix_clk_div``h]jP)}(hjh]hmin_pix_clk_div}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(hMinimum pixel clock dividerh]hMinimum pixel clock divider}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h0``max_pix_clk_div`` Maximum pixel clock divider h](jJ)}(h``max_pix_clk_div``h]jP)}(hj'h]hmax_pix_clk_div}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj%ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhj!ubjf)}(hhh]jk)}(hMaximum pixel clock dividerh]hMaximum pixel clock divider}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj<hKhj=ubah}(h]h ]h"]h$]h&]uh1jehj!ubeh}(h]h ]h"]h$]h&]uh1jChj<hKhjubjD)}(h6``min_pix_clk_freq_hz`` Minimum pixel clock frequency h](jJ)}(h``min_pix_clk_freq_hz``h]jP)}(hj`h]hmin_pix_clk_freq_hz}(hjbhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj^ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjZubjf)}(hhh]jk)}(hMinimum pixel clock frequencyh]hMinimum pixel clock frequency}(hjyhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjuhKhjvubah}(h]h ]h"]h$]h&]uh1jehjZubeh}(h]h ]h"]h$]h&]uh1jChjuhKhjubjD)}(h5``max_pix_clk_freq_hz`` Maximum pixel clock frequencyh](jJ)}(h``max_pix_clk_freq_hz``h]jP)}(hjh]hmax_pix_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(hMaximum pixel clock frequencyh]hMaximum pixel clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubeh}(h]h ]h"]h$]h&]uh1j>hjubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj&hhhNhNubjT)}(hhh]h}(h]h ]h"]h$]h&]entries](j`ccs_pll_limits (C struct)c.ccs_pll_limitshNtauh1jShj&hhhNhNubje)}(hhh](jj)}(hccs_pll_limitsh]jp)}(hstruct ccs_pll_limitsh](jv)}(hjyh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1juhjhhhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhKubj)}(hccs_pll_limitsh]j)}(hjh]hccs_pll_limits}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]hhuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]hhjuh1jojjhjhhhjhKubah}(h]jah ](jjeh"]h$]h&]jj)jhuh1jihjhKhjhhubj)}(hhh]jk)}(hCCS PLL limitsh]hCCS PLL limits}(hj5hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhj2hhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jstructeh"]h$]h&]jjjjMjjMjjjuh1jdhhhj&hNhNubj)}(hX3**Definition**:: struct ccs_pll_limits { u32 min_ext_clk_freq_hz; u32 max_ext_clk_freq_hz; struct ccs_pll_branch_limits_fr vt_fr; struct ccs_pll_branch_limits_bk vt_bk; struct ccs_pll_branch_limits_fr op_fr; struct ccs_pll_branch_limits_bk op_bk; u32 min_line_length_pck_bin; u32 min_line_length_pck; }; **Members** ``min_ext_clk_freq_hz`` Minimum external clock frequency ``max_ext_clk_freq_hz`` Maximum external clock frequency ``vt_fr`` Video timing front-end limits ``vt_bk`` Video timing back-end limits ``op_fr`` Operational timing front-end limits ``op_bk`` Operational timing back-end limits ``min_line_length_pck_bin`` Minimum line length in pixels, with binning ``min_line_length_pck`` Minimum line length in pixels without binningh](jk)}(h**Definition**::h](j)}(h**Definition**h]h Definition}(hjYhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjUubh:}(hjUhhhNhNubeh}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjQubj)}(hX>struct ccs_pll_limits { u32 min_ext_clk_freq_hz; u32 max_ext_clk_freq_hz; struct ccs_pll_branch_limits_fr vt_fr; struct ccs_pll_branch_limits_bk vt_bk; struct ccs_pll_branch_limits_fr op_fr; struct ccs_pll_branch_limits_bk op_bk; u32 min_line_length_pck_bin; u32 min_line_length_pck; };h]hX>struct ccs_pll_limits { u32 min_ext_clk_freq_hz; u32 max_ext_clk_freq_hz; struct ccs_pll_branch_limits_fr vt_fr; struct ccs_pll_branch_limits_bk vt_bk; struct ccs_pll_branch_limits_fr op_fr; struct ccs_pll_branch_limits_bk op_bk; u32 min_line_length_pck_bin; u32 min_line_length_pck; };}hjrsbah}(h]h ]h"]h$]h&]hhuh1jhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjQubjk)}(h **Members**h]j)}(hjh]hMembers}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjQubj?)}(hhh](jD)}(h9``min_ext_clk_freq_hz`` Minimum external clock frequency h](jJ)}(h``min_ext_clk_freq_hz``h]jP)}(hjh]hmin_ext_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h Minimum external clock frequencyh]h Minimum external clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h9``max_ext_clk_freq_hz`` Maximum external clock frequency h](jJ)}(h``max_ext_clk_freq_hz``h]jP)}(hjh]hmax_ext_clk_freq_hz}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h Maximum external clock frequencyh]h Maximum external clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h(``vt_fr`` Video timing front-end limits h](jJ)}(h ``vt_fr``h]jP)}(hjh]hvt_fr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(hVideo timing front-end limitsh]hVideo timing front-end limits}(hj-hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj)hKhj*ubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChj)hKhjubjD)}(h'``vt_bk`` Video timing back-end limits h](jJ)}(h ``vt_bk``h]jP)}(hjMh]hvt_bk}(hjOhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjKubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjGubjf)}(hhh]jk)}(hVideo timing back-end limitsh]hVideo timing back-end limits}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjbhKhjcubah}(h]h ]h"]h$]h&]uh1jehjGubeh}(h]h ]h"]h$]h&]uh1jChjbhKhjubjD)}(h.``op_fr`` Operational timing front-end limits h](jJ)}(h ``op_fr``h]jP)}(hjh]hop_fr}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h#Operational timing front-end limitsh]h#Operational timing front-end limits}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h-``op_bk`` Operational timing back-end limits h](jJ)}(h ``op_bk``h]jP)}(hjh]hop_bk}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h"Operational timing back-end limitsh]h"Operational timing back-end limits}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(hH``min_line_length_pck_bin`` Minimum line length in pixels, with binning h](jJ)}(h``min_line_length_pck_bin``h]jP)}(hjh]hmin_line_length_pck_bin}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h+Minimum line length in pixels, with binningh]h+Minimum line length in pixels, with binning}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChj hKhjubjD)}(hE``min_line_length_pck`` Minimum line length in pixels without binningh](jJ)}(h``min_line_length_pck``h]jP)}(hj1h]hmin_line_length_pck}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj/ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhj+ubjf)}(hhh]jk)}(h-Minimum line length in pixels without binningh]h-Minimum line length in pixels without binning}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjGubah}(h]h ]h"]h$]h&]uh1jehj+ubeh}(h]h ]h"]h$]h&]uh1jChjFhKhjubeh}(h]h ]h"]h$]h&]uh1j>hjQubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj&hhhNhNubjT)}(hhh]h}(h]h ]h"]h$]h&]entries](j`ccs_pll_calculate (C function)c.ccs_pll_calculatehNtauh1jShj&hhhNhNubje)}(hhh](jj)}(hdint ccs_pll_calculate (struct device *dev, const struct ccs_pll_limits *limits, struct ccs_pll *pll)h]jp)}(hcint ccs_pll_calculate(struct device *dev, const struct ccs_pll_limits *limits, struct ccs_pll *pll)h](hdesc_sig_keyword_type)}(hinth]hint}(hjhhhNhNubah}(h]h ]ktah"]h$]h&]uh1jhjhhhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjhhhjhKubj)}(hccs_pll_calculateh]j)}(hccs_pll_calculateh]hccs_pll_calculate}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ](jjeh"]h$]h&]hhuh1jhjhhhjhKubhdesc_parameterlist)}(hN(struct device *dev, const struct ccs_pll_limits *limits, struct ccs_pll *pll)h](hdesc_parameter)}(hstruct device *devh](jv)}(hjyh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1juhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hdeviceh]hdevice}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainjreftype identifier reftargetjmodnameN classnameN c:parent_keysphinx.domains.c LookupKey)}data]j ASTIdentifier)}jjsbc.ccs_pll_calculateasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubhdesc_sig_punctuation)}(h*h]h*}(hj%hhhNhNubah}(h]h ]pah"]h$]h&]uh1j#hjubj)}(hdevh]hdev}(hj4hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(h#const struct ccs_pll_limits *limitsh](jv)}(hconsth]hconst}(hjMhhhNhNubah}(h]h ]jah"]h$]h&]uh1juhjIubj)}(h h]h }(hj[hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubjv)}(hjyh]hstruct}(hjihhhNhNubah}(h]h ]jah"]h$]h&]uh1juhjIubj)}(h h]h }(hjvhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubh)}(hhh]j)}(hccs_pll_limitsh]hccs_pll_limits}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj )}j ]jc.ccs_pll_calculateasbuh1hhjIubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubj$)}(hj'h]h*}(hjhhhNhNubah}(h]h ]j0ah"]h$]h&]uh1j#hjIubj)}(hlimitsh]hlimits}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjIubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubj)}(hstruct ccs_pll *pllh](jv)}(hjyh]hstruct}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1juhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubh)}(hhh]j)}(hccs_pllh]hccs_pll}(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&] refdomainjreftypej reftargetjmodnameN classnameNjj )}j ]jc.ccs_pll_calculateasbuh1hhjubj)}(h h]h }(hjhhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubj$)}(hj'h]h*}(hj#hhhNhNubah}(h]h ]j0ah"]h$]h&]uh1j#hjubj)}(hpllh]hpll}(hj0hhhNhNubah}(h]h ]jah"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]noemphhhuh1jhjubeh}(h]h ]h"]h$]h&]hhuh1jhjhhhjhKubeh}(h]h ]h"]h$]h&]hhjuh1jojjhjhhhjhKubah}(h]j~ah ](jjeh"]h$]h&]jj)jhuh1jihjhKhjhhubj)}(hhh]jk)}(h9Calculate CCS PLL configuration based on input parametersh]h9Calculate CCS PLL configuration based on input parameters}(hjZhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjWhhubah}(h]h ]h"]h$]h&]uh1jhjhhhjhKubeh}(h]h ](jfunctioneh"]h$]h&]jjjjrjjrjjjuh1jdhhhj&hNhNubj)}(hXj**Parameters** ``struct device *dev`` Device pointer, used for printing messages ``const struct ccs_pll_limits *limits`` Limits specific to the sensor ``struct ccs_pll *pll`` Given PLL configuration **Description** Calculate the CCS PLL configuration based on the limits as well as given device specific, system specific or user configured input data.h](jk)}(h**Parameters**h]j)}(hj|h]h Parameters}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1jhjzubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjvubj?)}(hhh](jD)}(hB``struct device *dev`` Device pointer, used for printing messages h](jJ)}(h``struct device *dev``h]jP)}(hjh]hstruct device *dev}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(h*Device pointer, used for printing messagesh]h*Device pointer, used for printing messages}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(hF``const struct ccs_pll_limits *limits`` Limits specific to the sensor h](jJ)}(h'``const struct ccs_pll_limits *limits``h]jP)}(hjh]h#const struct ccs_pll_limits *limits}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhjubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(hLimits specific to the sensorh]hLimits specific to the sensor}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKhjubjD)}(h0``struct ccs_pll *pll`` Given PLL configuration h](jJ)}(h``struct ccs_pll *pll``h]jP)}(hj h]hstruct ccs_pll *pll}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jOhj ubah}(h]h ]h"]h$]h&]uh1jIhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjubjf)}(hhh]jk)}(hGiven PLL configurationh]hGiven PLL configuration}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj"hKhj#ubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChj"hKhjubeh}(h]h ]h"]h$]h&]uh1j>hjvubjk)}(h**Description**h]j)}(hjHh]h Description}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjFubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjvubjk)}(hCalculate the CCS PLL configuration based on the limits as well as given device specific, system specific or user configured input data.h]hCalculate the CCS PLL configuration based on the limits as well as given device specific, system specific or user configured input data.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhm/var/lib/git/docbuild/linux/Documentation/driver-api/media/drivers/ccs/ccs:166: ./drivers/media/i2c/ccs-pll.hhKhjvubeh}(h]h ] kernelindentah"]h$]h&]uh1jhj&hhhNhNubjk)}(h+**Copyright** |copy| 2020 Intel Corporationh](j)}(h **Copyright**h]h Copyright}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjtubh }(hjthhhNhNubh©}(hjthhhNhNubh 2020 Intel Corporation}(hjthhhNhNubeh}(h]h ]h"]h$]h&]uh1jjhhhKRhj&hhubeh}(h]ccs-pll-calculatorah ]h"]ccs pll calculatorah$]h&]uh1jUhhhhhhhKFubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(jZN 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_handlerjerror_encodingutf-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourceh _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}(hhhhhhj jjjj*jj9j-jHj<jWjKjfjZjujijjxjjjjjjjjjjjjjjjjj jjjj)jj8j,jGj;jVjJjejYjtjhjjwjjjjjjjjjjjjjjjjj jjj j(jj7j+jFj:jUjIjdjXjsjgjjvjjjjjjjjjjjjjjjjj jjj j'jj6j*jEj9jTjHjcjWjrjfjjujjjjjjjjjjjjjjjjjjjj j&jj5j)jDj8usubstitution_names}(amphߌaposhasthbrvbarj bsoljcentj*colonj9commajHcommatjWcopyjfcurrenjudarrjdegjdividejdollarjequalsjexcljfrac12jfrac14jfrac18jfrac34j frac38jfrac58j)frac78j8gtjGhalfjVhorbarjehyphenjtiexcljiquestjlaquojlarrjlcubjldquojlowbarjlparjlsqbjlsquoj ltjmicroj(middotj7nbspjFnotjUnumjdohmjsordfjordmjparajpercntjperiodjplusjplusmnjpoundjquestjquotj raquojrarrj'rcubj6rdquojEregjTrparjcrsqbjrrsquojsectjsemijshyjsoljsungjsup1jsup2jsup3jtimesjtradejuarrj&verbarj5yenjDurefnames}refids}jT]jIasnameids}(jjTjjjjjj ccs toolsjjjjj jju nametypes}(jjjjjTjjjuh}(jTjWjjWjjjjjjjjjjjj jjj&jbjkjp ju jK jP jjjNjSjjj~ju footnote_refs} citation_refs} autofootnotes]autofootnote_refs]symbol_footnotes]symbol_footnote_refs] footnotes] citations]autofootnote_startKsymbol_footnote_startK id_counter collectionsCounter}jKsRparse_messages]hsystem_message)}(hhh]jk)}(h,Duplicate implicit target name: "ccs tools".h]h0Duplicate implicit target name: “ccs tools”.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjuubah}(h]h ]h"]h$]h&]jalevelKtypeINFOsourcehlineKuh1jshjjhhhhhK,ubatransform_messages]jt)}(hhh]jk)}(hhh]h6Hyperlink target "media-ccs-driver" is not referenced.}hjsbah}(h]h ]h"]h$]h&]uh1jjhjubah}(h]h ]h"]h$]h&]levelKtypejsourcehlineK[uh1jsuba transformerN include_log]2Documentation/driver-api/media/drivers/ccs/ccs.rst(NNNNta decorationNhhub.