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.hhK2hjubhdefinition_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.hhK,hjubjf)}(hhh]jk)}(hPLL input clock frequencyh]hPLL input clock frequency}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhK,hjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhK,hj@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.hhK,hjubjf)}(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.hhK-hj ubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChj hK,hj@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.hhK0hj&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.hhK6hj 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.hhK:hj 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.hhKhj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hK=hj# 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.hhKAhj&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.hhK7hj&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.hhK``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.hhKLhj 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 hKLhj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKLhj 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.hhKMhj: ubjf)}(hhh]jk)}(h#Number of operational lanes (input)h]h#Number of operational lanes (input)}(hjY hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjU hKMhjV ubah}(h]h ]h"]h$]h&]uh1jehj: ubeh}(h]h ]h"]h$]h&]uh1jChjU hKMhj 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.hhKNhjs 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 hKNhj ubah}(h]h ]h"]h$]h&]uh1jehjs ubeh}(h]h ]h"]h$]h&]uh1jChj hKNhj 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.hhKOhj ubjf)}(hhh]jk)}(hCSI-2 related parametersh]hCSI-2 related parameters}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj hKOhj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKOhj 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.hhKPhj 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 hKPhj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKPhj 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.hhKRhj ubjf)}(hhh]jk)}(h!Horizontal binning factor (input)h]h!Horizontal binning factor (input)}(hj= hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhj9 hKRhj: ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj9 hKRhj 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.hhKQhjW ubjf)}(hhh]jk)}(hVertical binning factor (input)h]hVertical binning factor (input)}(hjv hhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjr hKQhjs ubah}(h]h ]h"]h$]h&]uh1jehjW ubeh}(h]h ]h"]h$]h&]uh1jChjr hKQhj 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.hhKShj 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 hKShj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKShj 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.hhKThj 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 hKThj ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj hKThj 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.hhKUhjubjf)}(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&]uh1jjhjhKUhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKUhj 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.hhKVhj;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&]uh1jjhjVhKVhjWubah}(h]h ]h"]h$]h&]uh1jehj;ubeh}(h]h ]h"]h$]h&]uh1jChjVhKVhj 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.hhKWhjtubjf)}(hhh]jk)}(hCCS_PLL_FLAG_* (input)h]hCCS_PLL_FLAG_* (input)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKWhjubah}(h]h ]h"]h$]h&]uh1jehjtubeh}(h]h ]h"]h$]h&]uh1jChjhKWhj 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.hhKXhjubjf)}(hhh]jk)}(hChosen link frequency (input)h]hChosen link frequency (input)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhKXhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKXhj 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.hhKZhjubjf)}(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.hhKYhjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhKZhj 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.hhK[hj 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;hK[hj<ubah}(h]h ]h"]h$]h&]uh1jehj ubeh}(h]h ]h"]h$]h&]uh1jChj;hK[hj 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.hhK\hjYubjf)}(hhh]jk)}(h,Video timing back-end configuration (output)h]h,Video timing back-end configuration (output)}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjthK\hjuubah}(h]h ]h"]h$]h&]uh1jehjYubeh}(h]h ]h"]h$]h&]uh1jChjthK\hj 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.hhK]hjubjf)}(hhh]jk)}(h3Operational timing front-end configuration (output)h]h3Operational timing front-end configuration (output)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhK]hjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhK]hj 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.hhK^hjubjf)}(hhh]jk)}(h2Operational timing back-end configuration (output)h]h2Operational timing back-end configuration (output)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jjhjhK^hjubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhK^hj 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.hhK_hjubjf)}(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&]uh1jjhjhK_hj ubah}(h]h ]h"]h$]h&]uh1jehjubeh}(h]h ]h"]h$]h&]uh1jChjhK_hj 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.hhK`hj=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&]uh1jjhjXhK`hjYubah}(h]h ]h"]h$]h&]uh1jehj=ubeh}(h]h ]h"]h$]h&]uh1jChjXhK`hj 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.hhKdhj&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.