phy-qcom-qmp-usb.c 104 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (c) 2017, The Linux Foundation. All rights reserved.
  4. */
  5. #include <linux/clk.h>
  6. #include <linux/clk-provider.h>
  7. #include <linux/delay.h>
  8. #include <linux/err.h>
  9. #include <linux/io.h>
  10. #include <linux/iopoll.h>
  11. #include <linux/kernel.h>
  12. #include <linux/module.h>
  13. #include <linux/of.h>
  14. #include <linux/of_device.h>
  15. #include <linux/of_address.h>
  16. #include <linux/phy/phy.h>
  17. #include <linux/platform_device.h>
  18. #include <linux/regulator/consumer.h>
  19. #include <linux/reset.h>
  20. #include <linux/slab.h>
  21. #include <dt-bindings/phy/phy.h>
  22. #include "phy-qcom-qmp.h"
  23. /* QPHY_SW_RESET bit */
  24. #define SW_RESET BIT(0)
  25. /* QPHY_POWER_DOWN_CONTROL */
  26. #define SW_PWRDN BIT(0)
  27. /* QPHY_START_CONTROL bits */
  28. #define SERDES_START BIT(0)
  29. #define PCS_START BIT(1)
  30. /* QPHY_PCS_STATUS bit */
  31. #define PHYSTATUS BIT(6)
  32. /* QPHY_V3_DP_COM_RESET_OVRD_CTRL register bits */
  33. /* DP PHY soft reset */
  34. #define SW_DPPHY_RESET BIT(0)
  35. /* mux to select DP PHY reset control, 0:HW control, 1: software reset */
  36. #define SW_DPPHY_RESET_MUX BIT(1)
  37. /* USB3 PHY soft reset */
  38. #define SW_USB3PHY_RESET BIT(2)
  39. /* mux to select USB3 PHY reset control, 0:HW control, 1: software reset */
  40. #define SW_USB3PHY_RESET_MUX BIT(3)
  41. /* QPHY_V3_DP_COM_PHY_MODE_CTRL register bits */
  42. #define USB3_MODE BIT(0) /* enables USB3 mode */
  43. #define DP_MODE BIT(1) /* enables DP mode */
  44. /* QPHY_PCS_AUTONOMOUS_MODE_CTRL register bits */
  45. #define ARCVR_DTCT_EN BIT(0)
  46. #define ALFPS_DTCT_EN BIT(1)
  47. #define ARCVR_DTCT_EVENT_SEL BIT(4)
  48. /* QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR register bits */
  49. #define IRQ_CLEAR BIT(0)
  50. /* QPHY_PCS_LFPS_RXTERM_IRQ_STATUS register bits */
  51. #define RCVR_DETECT BIT(0)
  52. /* QPHY_V3_PCS_MISC_CLAMP_ENABLE register bits */
  53. #define CLAMP_EN BIT(0) /* enables i/o clamp_n */
  54. #define PHY_INIT_COMPLETE_TIMEOUT 10000
  55. struct qmp_phy_init_tbl {
  56. unsigned int offset;
  57. unsigned int val;
  58. /*
  59. * register part of layout ?
  60. * if yes, then offset gives index in the reg-layout
  61. */
  62. bool in_layout;
  63. /*
  64. * mask of lanes for which this register is written
  65. * for cases when second lane needs different values
  66. */
  67. u8 lane_mask;
  68. };
  69. #define QMP_PHY_INIT_CFG(o, v) \
  70. { \
  71. .offset = o, \
  72. .val = v, \
  73. .lane_mask = 0xff, \
  74. }
  75. #define QMP_PHY_INIT_CFG_L(o, v) \
  76. { \
  77. .offset = o, \
  78. .val = v, \
  79. .in_layout = true, \
  80. .lane_mask = 0xff, \
  81. }
  82. #define QMP_PHY_INIT_CFG_LANE(o, v, l) \
  83. { \
  84. .offset = o, \
  85. .val = v, \
  86. .lane_mask = l, \
  87. }
  88. /* set of registers with offsets different per-PHY */
  89. enum qphy_reg_layout {
  90. /* PCS registers */
  91. QPHY_SW_RESET,
  92. QPHY_START_CTRL,
  93. QPHY_PCS_STATUS,
  94. QPHY_PCS_AUTONOMOUS_MODE_CTRL,
  95. QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR,
  96. QPHY_PCS_LFPS_RXTERM_IRQ_STATUS,
  97. QPHY_PCS_POWER_DOWN_CONTROL,
  98. /* PCS_MISC registers */
  99. QPHY_PCS_MISC_TYPEC_CTRL,
  100. /* Keep last to ensure regs_layout arrays are properly initialized */
  101. QPHY_LAYOUT_SIZE
  102. };
  103. static const unsigned int usb3phy_regs_layout[QPHY_LAYOUT_SIZE] = {
  104. [QPHY_SW_RESET] = 0x00,
  105. [QPHY_START_CTRL] = 0x08,
  106. [QPHY_PCS_STATUS] = 0x17c,
  107. [QPHY_PCS_AUTONOMOUS_MODE_CTRL] = 0x0d4,
  108. [QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR] = 0x0d8,
  109. [QPHY_PCS_LFPS_RXTERM_IRQ_STATUS] = 0x178,
  110. [QPHY_PCS_POWER_DOWN_CONTROL] = 0x04,
  111. };
  112. static const unsigned int qmp_v3_usb3phy_regs_layout[QPHY_LAYOUT_SIZE] = {
  113. [QPHY_SW_RESET] = 0x00,
  114. [QPHY_START_CTRL] = 0x08,
  115. [QPHY_PCS_STATUS] = 0x174,
  116. [QPHY_PCS_AUTONOMOUS_MODE_CTRL] = 0x0d8,
  117. [QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR] = 0x0dc,
  118. [QPHY_PCS_LFPS_RXTERM_IRQ_STATUS] = 0x170,
  119. [QPHY_PCS_POWER_DOWN_CONTROL] = 0x04,
  120. };
  121. static const unsigned int qmp_v4_usb3phy_regs_layout[QPHY_LAYOUT_SIZE] = {
  122. [QPHY_SW_RESET] = 0x00,
  123. [QPHY_START_CTRL] = 0x44,
  124. [QPHY_PCS_STATUS] = 0x14,
  125. [QPHY_PCS_POWER_DOWN_CONTROL] = 0x40,
  126. /* In PCS_USB */
  127. [QPHY_PCS_AUTONOMOUS_MODE_CTRL] = 0x008,
  128. [QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR] = 0x014,
  129. };
  130. static const unsigned int qcm2290_usb3phy_regs_layout[QPHY_LAYOUT_SIZE] = {
  131. [QPHY_SW_RESET] = 0x00,
  132. [QPHY_PCS_POWER_DOWN_CONTROL] = 0x04,
  133. [QPHY_START_CTRL] = 0x08,
  134. [QPHY_PCS_AUTONOMOUS_MODE_CTRL] = 0xd8,
  135. [QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR] = 0xdc,
  136. [QPHY_PCS_STATUS] = 0x174,
  137. [QPHY_PCS_MISC_TYPEC_CTRL] = 0x00,
  138. };
  139. static const struct qmp_phy_init_tbl ipq8074_usb3_serdes_tbl[] = {
  140. QMP_PHY_INIT_CFG(QSERDES_COM_SYSCLK_EN_SEL, 0x1a),
  141. QMP_PHY_INIT_CFG(QSERDES_COM_BIAS_EN_CLKBUFLR_EN, 0x08),
  142. QMP_PHY_INIT_CFG(QSERDES_COM_CLK_SELECT, 0x30),
  143. QMP_PHY_INIT_CFG(QSERDES_COM_BG_TRIM, 0x0f),
  144. QMP_PHY_INIT_CFG(QSERDES_RX_UCDR_FASTLOCK_FO_GAIN, 0x0b),
  145. QMP_PHY_INIT_CFG(QSERDES_COM_SVS_MODE_CLK_SEL, 0x01),
  146. QMP_PHY_INIT_CFG(QSERDES_COM_HSCLK_SEL, 0x00),
  147. QMP_PHY_INIT_CFG(QSERDES_COM_CMN_CONFIG, 0x06),
  148. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_IVCO, 0x0f),
  149. QMP_PHY_INIT_CFG(QSERDES_COM_SYS_CLK_CTRL, 0x06),
  150. /* PLL and Loop filter settings */
  151. QMP_PHY_INIT_CFG(QSERDES_COM_DEC_START_MODE0, 0x82),
  152. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START1_MODE0, 0x55),
  153. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START2_MODE0, 0x55),
  154. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START3_MODE0, 0x03),
  155. QMP_PHY_INIT_CFG(QSERDES_COM_CP_CTRL_MODE0, 0x0b),
  156. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_RCTRL_MODE0, 0x16),
  157. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_CCTRL_MODE0, 0x28),
  158. QMP_PHY_INIT_CFG(QSERDES_COM_INTEGLOOP_GAIN0_MODE0, 0x80),
  159. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP1_MODE0, 0x15),
  160. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP2_MODE0, 0x34),
  161. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP3_MODE0, 0x00),
  162. QMP_PHY_INIT_CFG(QSERDES_COM_CORE_CLK_EN, 0x00),
  163. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP_CFG, 0x00),
  164. QMP_PHY_INIT_CFG(QSERDES_COM_VCO_TUNE_MAP, 0x00),
  165. QMP_PHY_INIT_CFG(QSERDES_COM_BG_TIMER, 0x0a),
  166. /* SSC settings */
  167. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_EN_CENTER, 0x01),
  168. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_PER1, 0x31),
  169. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_PER2, 0x01),
  170. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_ADJ_PER1, 0x00),
  171. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_ADJ_PER2, 0x00),
  172. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_STEP_SIZE1, 0xde),
  173. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_STEP_SIZE2, 0x07),
  174. };
  175. static const struct qmp_phy_init_tbl ipq8074_usb3_rx_tbl[] = {
  176. QMP_PHY_INIT_CFG(QSERDES_RX_UCDR_SO_GAIN, 0x06),
  177. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQU_ADAPTOR_CNTRL2, 0x02),
  178. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4c),
  179. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQU_ADAPTOR_CNTRL4, 0xb8),
  180. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x77),
  181. QMP_PHY_INIT_CFG(QSERDES_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  182. QMP_PHY_INIT_CFG(QSERDES_RX_SIGDET_CNTRL, 0x03),
  183. QMP_PHY_INIT_CFG(QSERDES_RX_SIGDET_DEGLITCH_CNTRL, 0x16),
  184. QMP_PHY_INIT_CFG(QSERDES_RX_SIGDET_ENABLES, 0x0),
  185. };
  186. static const struct qmp_phy_init_tbl ipq8074_usb3_pcs_tbl[] = {
  187. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V0, 0x15),
  188. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V0, 0x0e),
  189. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL2, 0x83),
  190. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL1, 0x02),
  191. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_L, 0x09),
  192. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_H_TOL, 0xa2),
  193. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_MAN_CODE, 0x85),
  194. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG1, 0xd1),
  195. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG2, 0x1f),
  196. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG3, 0x47),
  197. QMP_PHY_INIT_CFG(QPHY_V3_PCS_POWER_STATE_CONFIG2, 0x1b),
  198. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_WAIT_TIME, 0x75),
  199. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_RUN_TIME, 0x13),
  200. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LFPS_TX_ECSTART_EQTLOCK, 0x86),
  201. QMP_PHY_INIT_CFG(QPHY_V3_PCS_PWRUP_RESET_DLY_TIME_AUXCLK, 0x04),
  202. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TSYNC_RSYNC_TIME, 0x44),
  203. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  204. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  205. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_L, 0x40),
  206. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_H, 0x00),
  207. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RX_SIGDET_LVL, 0x88),
  208. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V0, 0x17),
  209. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V0, 0x0f),
  210. };
  211. static const struct qmp_phy_init_tbl msm8996_usb3_serdes_tbl[] = {
  212. QMP_PHY_INIT_CFG(QSERDES_COM_SYSCLK_EN_SEL, 0x14),
  213. QMP_PHY_INIT_CFG(QSERDES_COM_BIAS_EN_CLKBUFLR_EN, 0x08),
  214. QMP_PHY_INIT_CFG(QSERDES_COM_CLK_SELECT, 0x30),
  215. QMP_PHY_INIT_CFG(QSERDES_COM_CMN_CONFIG, 0x06),
  216. QMP_PHY_INIT_CFG(QSERDES_COM_SVS_MODE_CLK_SEL, 0x01),
  217. QMP_PHY_INIT_CFG(QSERDES_COM_HSCLK_SEL, 0x00),
  218. QMP_PHY_INIT_CFG(QSERDES_COM_BG_TRIM, 0x0f),
  219. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_IVCO, 0x0f),
  220. QMP_PHY_INIT_CFG(QSERDES_COM_SYS_CLK_CTRL, 0x04),
  221. /* PLL and Loop filter settings */
  222. QMP_PHY_INIT_CFG(QSERDES_COM_DEC_START_MODE0, 0x82),
  223. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START1_MODE0, 0x55),
  224. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START2_MODE0, 0x55),
  225. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START3_MODE0, 0x03),
  226. QMP_PHY_INIT_CFG(QSERDES_COM_CP_CTRL_MODE0, 0x0b),
  227. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_RCTRL_MODE0, 0x16),
  228. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_CCTRL_MODE0, 0x28),
  229. QMP_PHY_INIT_CFG(QSERDES_COM_INTEGLOOP_GAIN0_MODE0, 0x80),
  230. QMP_PHY_INIT_CFG(QSERDES_COM_VCO_TUNE_CTRL, 0x00),
  231. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP1_MODE0, 0x15),
  232. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP2_MODE0, 0x34),
  233. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP3_MODE0, 0x00),
  234. QMP_PHY_INIT_CFG(QSERDES_COM_CORE_CLK_EN, 0x00),
  235. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP_CFG, 0x00),
  236. QMP_PHY_INIT_CFG(QSERDES_COM_VCO_TUNE_MAP, 0x00),
  237. QMP_PHY_INIT_CFG(QSERDES_COM_BG_TIMER, 0x0a),
  238. /* SSC settings */
  239. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_EN_CENTER, 0x01),
  240. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_PER1, 0x31),
  241. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_PER2, 0x01),
  242. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_ADJ_PER1, 0x00),
  243. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_ADJ_PER2, 0x00),
  244. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_STEP_SIZE1, 0xde),
  245. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_STEP_SIZE2, 0x07),
  246. };
  247. static const struct qmp_phy_init_tbl msm8996_usb3_tx_tbl[] = {
  248. QMP_PHY_INIT_CFG(QSERDES_TX_HIGHZ_TRANSCEIVEREN_BIAS_DRVR_EN, 0x45),
  249. QMP_PHY_INIT_CFG(QSERDES_TX_RCV_DETECT_LVL_2, 0x12),
  250. QMP_PHY_INIT_CFG(QSERDES_TX_LANE_MODE, 0x06),
  251. };
  252. static const struct qmp_phy_init_tbl msm8996_usb3_rx_tbl[] = {
  253. QMP_PHY_INIT_CFG(QSERDES_RX_UCDR_FASTLOCK_FO_GAIN, 0x0b),
  254. QMP_PHY_INIT_CFG(QSERDES_RX_UCDR_SO_GAIN, 0x04),
  255. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQU_ADAPTOR_CNTRL2, 0x02),
  256. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4c),
  257. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQU_ADAPTOR_CNTRL4, 0xbb),
  258. QMP_PHY_INIT_CFG(QSERDES_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x77),
  259. QMP_PHY_INIT_CFG(QSERDES_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  260. QMP_PHY_INIT_CFG(QSERDES_RX_SIGDET_CNTRL, 0x03),
  261. QMP_PHY_INIT_CFG(QSERDES_RX_SIGDET_LVL, 0x18),
  262. QMP_PHY_INIT_CFG(QSERDES_RX_SIGDET_DEGLITCH_CNTRL, 0x16),
  263. };
  264. static const struct qmp_phy_init_tbl msm8996_usb3_pcs_tbl[] = {
  265. /* FLL settings */
  266. QMP_PHY_INIT_CFG(QPHY_V2_PCS_FLL_CNTRL2, 0x03),
  267. QMP_PHY_INIT_CFG(QPHY_V2_PCS_FLL_CNTRL1, 0x02),
  268. QMP_PHY_INIT_CFG(QPHY_V2_PCS_FLL_CNT_VAL_L, 0x09),
  269. QMP_PHY_INIT_CFG(QPHY_V2_PCS_FLL_CNT_VAL_H_TOL, 0x42),
  270. QMP_PHY_INIT_CFG(QPHY_V2_PCS_FLL_MAN_CODE, 0x85),
  271. /* Lock Det settings */
  272. QMP_PHY_INIT_CFG(QPHY_V2_PCS_LOCK_DETECT_CONFIG1, 0xd1),
  273. QMP_PHY_INIT_CFG(QPHY_V2_PCS_LOCK_DETECT_CONFIG2, 0x1f),
  274. QMP_PHY_INIT_CFG(QPHY_V2_PCS_LOCK_DETECT_CONFIG3, 0x47),
  275. QMP_PHY_INIT_CFG(QPHY_V2_PCS_POWER_STATE_CONFIG2, 0x08),
  276. };
  277. static const struct qmp_phy_init_tbl qmp_v3_usb3_serdes_tbl[] = {
  278. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_IVCO, 0x07),
  279. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYSCLK_EN_SEL, 0x14),
  280. QMP_PHY_INIT_CFG(QSERDES_V3_COM_BIAS_EN_CLKBUFLR_EN, 0x08),
  281. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CLK_SELECT, 0x30),
  282. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYS_CLK_CTRL, 0x02),
  283. QMP_PHY_INIT_CFG(QSERDES_V3_COM_RESETSM_CNTRL2, 0x08),
  284. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CMN_CONFIG, 0x16),
  285. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SVS_MODE_CLK_SEL, 0x01),
  286. QMP_PHY_INIT_CFG(QSERDES_V3_COM_HSCLK_SEL, 0x80),
  287. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DEC_START_MODE0, 0x82),
  288. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START1_MODE0, 0xab),
  289. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START2_MODE0, 0xea),
  290. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START3_MODE0, 0x02),
  291. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CP_CTRL_MODE0, 0x06),
  292. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_RCTRL_MODE0, 0x16),
  293. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_CCTRL_MODE0, 0x36),
  294. QMP_PHY_INIT_CFG(QSERDES_V3_COM_INTEGLOOP_GAIN1_MODE0, 0x00),
  295. QMP_PHY_INIT_CFG(QSERDES_V3_COM_INTEGLOOP_GAIN0_MODE0, 0x3f),
  296. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE2_MODE0, 0x01),
  297. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE1_MODE0, 0xc9),
  298. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CORECLK_DIV_MODE0, 0x0a),
  299. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP3_MODE0, 0x00),
  300. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP2_MODE0, 0x34),
  301. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP1_MODE0, 0x15),
  302. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP_EN, 0x04),
  303. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CORE_CLK_EN, 0x00),
  304. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP_CFG, 0x00),
  305. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE_MAP, 0x00),
  306. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYSCLK_BUF_ENABLE, 0x0a),
  307. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_EN_CENTER, 0x01),
  308. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_PER1, 0x31),
  309. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_PER2, 0x01),
  310. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_ADJ_PER1, 0x00),
  311. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_ADJ_PER2, 0x00),
  312. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_STEP_SIZE1, 0x85),
  313. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_STEP_SIZE2, 0x07),
  314. };
  315. static const struct qmp_phy_init_tbl qmp_v3_usb3_tx_tbl[] = {
  316. QMP_PHY_INIT_CFG(QSERDES_V3_TX_HIGHZ_DRVR_EN, 0x10),
  317. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RCV_DETECT_LVL_2, 0x12),
  318. QMP_PHY_INIT_CFG(QSERDES_V3_TX_LANE_MODE_1, 0x16),
  319. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RES_CODE_LANE_OFFSET_RX, 0x09),
  320. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RES_CODE_LANE_OFFSET_TX, 0x06),
  321. };
  322. static const struct qmp_phy_init_tbl qmp_v3_usb3_rx_tbl[] = {
  323. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_FO_GAIN, 0x0b),
  324. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  325. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4e),
  326. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL4, 0x18),
  327. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x77),
  328. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  329. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_CNTRL, 0x03),
  330. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_DEGLITCH_CNTRL, 0x16),
  331. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x75),
  332. };
  333. static const struct qmp_phy_init_tbl qmp_v3_usb3_pcs_tbl[] = {
  334. /* FLL settings */
  335. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL2, 0x83),
  336. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_L, 0x09),
  337. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_H_TOL, 0xa2),
  338. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_MAN_CODE, 0x40),
  339. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL1, 0x02),
  340. /* Lock Det settings */
  341. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG1, 0xd1),
  342. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG2, 0x1f),
  343. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG3, 0x47),
  344. QMP_PHY_INIT_CFG(QPHY_V3_PCS_POWER_STATE_CONFIG2, 0x1b),
  345. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RX_SIGDET_LVL, 0xba),
  346. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V0, 0x9f),
  347. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V1, 0x9f),
  348. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V2, 0xb7),
  349. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V3, 0x4e),
  350. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V4, 0x65),
  351. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_LS, 0x6b),
  352. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V0, 0x15),
  353. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V0, 0x0d),
  354. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V1, 0x15),
  355. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V1, 0x0d),
  356. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V2, 0x15),
  357. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V2, 0x0d),
  358. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V3, 0x15),
  359. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V3, 0x1d),
  360. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V4, 0x15),
  361. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V4, 0x0d),
  362. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_LS, 0x15),
  363. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_LS, 0x0d),
  364. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RATE_SLEW_CNTRL, 0x02),
  365. QMP_PHY_INIT_CFG(QPHY_V3_PCS_PWRUP_RESET_DLY_TIME_AUXCLK, 0x04),
  366. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TSYNC_RSYNC_TIME, 0x44),
  367. QMP_PHY_INIT_CFG(QPHY_V3_PCS_PWRUP_RESET_DLY_TIME_AUXCLK, 0x04),
  368. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  369. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  370. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_L, 0x40),
  371. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_H, 0x00),
  372. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_WAIT_TIME, 0x75),
  373. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LFPS_TX_ECSTART_EQTLOCK, 0x86),
  374. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_RUN_TIME, 0x13),
  375. };
  376. static const struct qmp_phy_init_tbl qmp_v3_usb3_uniphy_serdes_tbl[] = {
  377. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_IVCO, 0x07),
  378. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYSCLK_EN_SEL, 0x14),
  379. QMP_PHY_INIT_CFG(QSERDES_V3_COM_BIAS_EN_CLKBUFLR_EN, 0x04),
  380. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CLK_SELECT, 0x30),
  381. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYS_CLK_CTRL, 0x02),
  382. QMP_PHY_INIT_CFG(QSERDES_V3_COM_RESETSM_CNTRL2, 0x08),
  383. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CMN_CONFIG, 0x06),
  384. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SVS_MODE_CLK_SEL, 0x01),
  385. QMP_PHY_INIT_CFG(QSERDES_V3_COM_HSCLK_SEL, 0x80),
  386. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DEC_START_MODE0, 0x82),
  387. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START1_MODE0, 0xab),
  388. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START2_MODE0, 0xea),
  389. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START3_MODE0, 0x02),
  390. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CP_CTRL_MODE0, 0x06),
  391. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_RCTRL_MODE0, 0x16),
  392. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_CCTRL_MODE0, 0x36),
  393. QMP_PHY_INIT_CFG(QSERDES_V3_COM_INTEGLOOP_GAIN1_MODE0, 0x00),
  394. QMP_PHY_INIT_CFG(QSERDES_V3_COM_INTEGLOOP_GAIN0_MODE0, 0x3f),
  395. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE2_MODE0, 0x01),
  396. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE1_MODE0, 0xc9),
  397. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CORECLK_DIV_MODE0, 0x0a),
  398. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP3_MODE0, 0x00),
  399. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP2_MODE0, 0x34),
  400. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP1_MODE0, 0x15),
  401. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP_EN, 0x04),
  402. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CORE_CLK_EN, 0x00),
  403. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP_CFG, 0x00),
  404. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE_MAP, 0x00),
  405. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYSCLK_BUF_ENABLE, 0x0a),
  406. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_EN_CENTER, 0x01),
  407. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_PER1, 0x31),
  408. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_PER2, 0x01),
  409. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_ADJ_PER1, 0x00),
  410. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_ADJ_PER2, 0x00),
  411. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_STEP_SIZE1, 0x85),
  412. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_STEP_SIZE2, 0x07),
  413. };
  414. static const struct qmp_phy_init_tbl qmp_v3_usb3_uniphy_tx_tbl[] = {
  415. QMP_PHY_INIT_CFG(QSERDES_V3_TX_HIGHZ_DRVR_EN, 0x10),
  416. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RCV_DETECT_LVL_2, 0x12),
  417. QMP_PHY_INIT_CFG(QSERDES_V3_TX_LANE_MODE_1, 0xc6),
  418. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RES_CODE_LANE_OFFSET_RX, 0x06),
  419. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RES_CODE_LANE_OFFSET_TX, 0x06),
  420. };
  421. static const struct qmp_phy_init_tbl qmp_v3_usb3_uniphy_rx_tbl[] = {
  422. QMP_PHY_INIT_CFG(QSERDES_V3_RX_VGA_CAL_CNTRL2, 0x0c),
  423. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_MODE_00, 0x50),
  424. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_FO_GAIN, 0x0b),
  425. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0e),
  426. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4e),
  427. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL4, 0x18),
  428. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x77),
  429. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  430. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_CNTRL, 0x03),
  431. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_DEGLITCH_CNTRL, 0x1c),
  432. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x75),
  433. };
  434. static const struct qmp_phy_init_tbl qmp_v3_usb3_uniphy_pcs_tbl[] = {
  435. /* FLL settings */
  436. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL2, 0x83),
  437. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_L, 0x09),
  438. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_H_TOL, 0xa2),
  439. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_MAN_CODE, 0x40),
  440. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL1, 0x02),
  441. /* Lock Det settings */
  442. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG1, 0xd1),
  443. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG2, 0x1f),
  444. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG3, 0x47),
  445. QMP_PHY_INIT_CFG(QPHY_V3_PCS_POWER_STATE_CONFIG2, 0x1b),
  446. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RX_SIGDET_LVL, 0xba),
  447. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V0, 0x9f),
  448. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V1, 0x9f),
  449. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V2, 0xb5),
  450. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V3, 0x4c),
  451. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V4, 0x64),
  452. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_LS, 0x6a),
  453. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V0, 0x15),
  454. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V0, 0x0d),
  455. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V1, 0x15),
  456. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V1, 0x0d),
  457. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V2, 0x15),
  458. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V2, 0x0d),
  459. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V3, 0x15),
  460. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V3, 0x1d),
  461. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V4, 0x15),
  462. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V4, 0x0d),
  463. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_LS, 0x15),
  464. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_LS, 0x0d),
  465. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RATE_SLEW_CNTRL, 0x02),
  466. QMP_PHY_INIT_CFG(QPHY_V3_PCS_PWRUP_RESET_DLY_TIME_AUXCLK, 0x04),
  467. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TSYNC_RSYNC_TIME, 0x44),
  468. QMP_PHY_INIT_CFG(QPHY_V3_PCS_PWRUP_RESET_DLY_TIME_AUXCLK, 0x04),
  469. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  470. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  471. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_L, 0x40),
  472. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_H, 0x00),
  473. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_WAIT_TIME, 0x75),
  474. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LFPS_TX_ECSTART_EQTLOCK, 0x86),
  475. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_RUN_TIME, 0x13),
  476. QMP_PHY_INIT_CFG(QPHY_V3_PCS_REFGEN_REQ_CONFIG1, 0x21),
  477. QMP_PHY_INIT_CFG(QPHY_V3_PCS_REFGEN_REQ_CONFIG2, 0x60),
  478. };
  479. static const struct qmp_phy_init_tbl msm8998_usb3_serdes_tbl[] = {
  480. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CLK_SELECT, 0x30),
  481. QMP_PHY_INIT_CFG(QSERDES_V3_COM_BIAS_EN_CLKBUFLR_EN, 0x04),
  482. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYSCLK_EN_SEL, 0x14),
  483. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SYS_CLK_CTRL, 0x06),
  484. QMP_PHY_INIT_CFG(QSERDES_V3_COM_RESETSM_CNTRL2, 0x08),
  485. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CMN_CONFIG, 0x06),
  486. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SVS_MODE_CLK_SEL, 0x01),
  487. QMP_PHY_INIT_CFG(QSERDES_V3_COM_HSCLK_SEL, 0x80),
  488. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DEC_START_MODE0, 0x82),
  489. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START1_MODE0, 0xab),
  490. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START2_MODE0, 0xea),
  491. QMP_PHY_INIT_CFG(QSERDES_V3_COM_DIV_FRAC_START3_MODE0, 0x02),
  492. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CP_CTRL_MODE0, 0x06),
  493. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_RCTRL_MODE0, 0x16),
  494. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_CCTRL_MODE0, 0x36),
  495. QMP_PHY_INIT_CFG(QSERDES_V3_COM_INTEGLOOP_GAIN1_MODE0, 0x00),
  496. QMP_PHY_INIT_CFG(QSERDES_V3_COM_INTEGLOOP_GAIN0_MODE0, 0x3f),
  497. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE2_MODE0, 0x01),
  498. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE1_MODE0, 0xc9),
  499. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CORECLK_DIV_MODE0, 0x0a),
  500. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP3_MODE0, 0x00),
  501. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP2_MODE0, 0x34),
  502. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP1_MODE0, 0x15),
  503. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP_EN, 0x04),
  504. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CORE_CLK_EN, 0x00),
  505. QMP_PHY_INIT_CFG(QSERDES_V3_COM_LOCK_CMP_CFG, 0x00),
  506. QMP_PHY_INIT_CFG(QSERDES_V3_COM_VCO_TUNE_MAP, 0x00),
  507. QMP_PHY_INIT_CFG(QSERDES_V3_COM_BG_TIMER, 0x0a),
  508. QMP_PHY_INIT_CFG(QSERDES_V3_COM_PLL_IVCO, 0x07),
  509. QMP_PHY_INIT_CFG(QSERDES_V3_COM_INTEGLOOP_INITVAL, 0x80),
  510. QMP_PHY_INIT_CFG(QSERDES_V3_COM_CMN_MODE, 0x01),
  511. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_EN_CENTER, 0x01),
  512. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_PER1, 0x31),
  513. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_PER2, 0x01),
  514. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_ADJ_PER1, 0x00),
  515. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_ADJ_PER2, 0x00),
  516. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_STEP_SIZE1, 0x85),
  517. QMP_PHY_INIT_CFG(QSERDES_V3_COM_SSC_STEP_SIZE2, 0x07),
  518. };
  519. static const struct qmp_phy_init_tbl msm8998_usb3_tx_tbl[] = {
  520. QMP_PHY_INIT_CFG(QSERDES_V3_TX_HIGHZ_DRVR_EN, 0x10),
  521. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RCV_DETECT_LVL_2, 0x12),
  522. QMP_PHY_INIT_CFG(QSERDES_V3_TX_LANE_MODE_1, 0x16),
  523. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RES_CODE_LANE_OFFSET_TX, 0x00),
  524. };
  525. static const struct qmp_phy_init_tbl msm8998_usb3_rx_tbl[] = {
  526. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_FO_GAIN, 0x0b),
  527. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  528. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4e),
  529. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL4, 0x18),
  530. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x07),
  531. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  532. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_CNTRL, 0x43),
  533. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_DEGLITCH_CNTRL, 0x1c),
  534. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x75),
  535. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_COUNT_LOW, 0x00),
  536. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x00),
  537. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_PI_CONTROLS, 0x80),
  538. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FO_GAIN, 0x0a),
  539. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_SO_GAIN, 0x06),
  540. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_ENABLES, 0x00),
  541. QMP_PHY_INIT_CFG(QSERDES_V3_RX_VGA_CAL_CNTRL2, 0x03),
  542. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_MODE_00, 0x05),
  543. };
  544. static const struct qmp_phy_init_tbl msm8998_usb3_pcs_tbl[] = {
  545. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL2, 0x83),
  546. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_L, 0x09),
  547. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_H_TOL, 0xa2),
  548. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_MAN_CODE, 0x40),
  549. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL1, 0x02),
  550. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG1, 0xd1),
  551. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG2, 0x1f),
  552. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG3, 0x47),
  553. QMP_PHY_INIT_CFG(QPHY_V3_PCS_POWER_STATE_CONFIG2, 0x1b),
  554. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V0, 0x9f),
  555. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V1, 0x9f),
  556. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V2, 0xb7),
  557. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V3, 0x4e),
  558. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V4, 0x65),
  559. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_LS, 0x6b),
  560. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V0, 0x15),
  561. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V0, 0x0d),
  562. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V1, 0x15),
  563. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V1, 0x0d),
  564. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V2, 0x15),
  565. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V2, 0x0d),
  566. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V3, 0x15),
  567. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V3, 0x0d),
  568. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V4, 0x15),
  569. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V4, 0x0d),
  570. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_LS, 0x15),
  571. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_LS, 0x0d),
  572. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RATE_SLEW_CNTRL, 0x02),
  573. QMP_PHY_INIT_CFG(QPHY_V3_PCS_PWRUP_RESET_DLY_TIME_AUXCLK, 0x04),
  574. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TSYNC_RSYNC_TIME, 0x44),
  575. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  576. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  577. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_L, 0x40),
  578. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_H, 0x00),
  579. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RX_SIGDET_LVL, 0x8a),
  580. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_WAIT_TIME, 0x75),
  581. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LFPS_TX_ECSTART_EQTLOCK, 0x86),
  582. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_RUN_TIME, 0x13),
  583. };
  584. static const struct qmp_phy_init_tbl sm8150_usb3_serdes_tbl[] = {
  585. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_EN_CENTER, 0x01),
  586. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_PER1, 0x31),
  587. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_PER2, 0x01),
  588. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE1_MODE0, 0xde),
  589. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE2_MODE0, 0x07),
  590. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE1_MODE1, 0xde),
  591. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE2_MODE1, 0x07),
  592. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SYSCLK_BUF_ENABLE, 0x0a),
  593. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CMN_IPTRIM, 0x20),
  594. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CP_CTRL_MODE0, 0x06),
  595. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CP_CTRL_MODE1, 0x06),
  596. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_RCTRL_MODE0, 0x16),
  597. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_RCTRL_MODE1, 0x16),
  598. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_CCTRL_MODE0, 0x36),
  599. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_CCTRL_MODE1, 0x36),
  600. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SYSCLK_EN_SEL, 0x1a),
  601. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP_EN, 0x04),
  602. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP1_MODE0, 0x14),
  603. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP2_MODE0, 0x34),
  604. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP1_MODE1, 0x34),
  605. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP2_MODE1, 0x82),
  606. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DEC_START_MODE0, 0x82),
  607. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DEC_START_MODE1, 0x82),
  608. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START1_MODE0, 0xab),
  609. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START2_MODE0, 0xea),
  610. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START3_MODE0, 0x02),
  611. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE_MAP, 0x02),
  612. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START1_MODE1, 0xab),
  613. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START2_MODE1, 0xea),
  614. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START3_MODE1, 0x02),
  615. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE1_MODE0, 0x24),
  616. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE1_MODE1, 0x24),
  617. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE2_MODE1, 0x02),
  618. QMP_PHY_INIT_CFG(QSERDES_V4_COM_HSCLK_SEL, 0x01),
  619. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CORECLK_DIV_MODE1, 0x08),
  620. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE1_MODE0, 0xca),
  621. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE2_MODE0, 0x1e),
  622. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE1_MODE1, 0xca),
  623. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE2_MODE1, 0x1e),
  624. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_HSCLK_SEL, 0x11),
  625. };
  626. static const struct qmp_phy_init_tbl sm8150_usb3_tx_tbl[] = {
  627. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_TX, 0x00),
  628. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_RX, 0x00),
  629. QMP_PHY_INIT_CFG(QSERDES_V4_TX_LANE_MODE_1, 0xd5),
  630. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RCV_DETECT_LVL_2, 0x12),
  631. QMP_PHY_INIT_CFG(QSERDES_V4_TX_PI_QEC_CTRL, 0x20),
  632. };
  633. static const struct qmp_phy_init_tbl sm8150_usb3_rx_tbl[] = {
  634. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_GAIN, 0x05),
  635. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  636. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x7f),
  637. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  638. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  639. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_PI_CONTROLS, 0x99),
  640. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH1, 0x04),
  641. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH2, 0x08),
  642. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN1, 0x05),
  643. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN2, 0x05),
  644. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL1, 0x54),
  645. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL2, 0x0e),
  646. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  647. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4a),
  648. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  649. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_LOW, 0xc0),
  650. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_HIGH, 0x00),
  651. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x77),
  652. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_CNTRL, 0x04),
  653. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  654. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_LOW, 0xbf),
  655. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH, 0xbf),
  656. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH2, 0x3f),
  657. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH3, 0x7f),
  658. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH4, 0x94),
  659. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_LOW, 0xdc),
  660. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH, 0xdc),
  661. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH2, 0x5c),
  662. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH3, 0x0b),
  663. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH4, 0xb3),
  664. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_EN_TIMER, 0x04),
  665. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  666. QMP_PHY_INIT_CFG(QSERDES_V4_RX_AUX_DATA_TCOARSE_TFINE, 0xa0),
  667. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DCC_CTRL1, 0x0c),
  668. QMP_PHY_INIT_CFG(QSERDES_V4_RX_GM_CAL, 0x1f),
  669. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VTH_CODE, 0x10),
  670. };
  671. static const struct qmp_phy_init_tbl sm8150_usb3_pcs_tbl[] = {
  672. /* Lock Det settings */
  673. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG1, 0xd0),
  674. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG2, 0x07),
  675. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG6, 0x13),
  676. QMP_PHY_INIT_CFG(QPHY_V4_PCS_REFGEN_REQ_CONFIG1, 0x21),
  677. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RX_SIGDET_LVL, 0xaa),
  678. QMP_PHY_INIT_CFG(QPHY_V4_PCS_CDR_RESET_TIME, 0x0a),
  679. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG1, 0x88),
  680. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG2, 0x13),
  681. QMP_PHY_INIT_CFG(QPHY_V4_PCS_PCS_TX_RX_CONFIG, 0x0c),
  682. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG1, 0x4b),
  683. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG5, 0x10),
  684. };
  685. static const struct qmp_phy_init_tbl sm8150_usb3_pcs_usb_tbl[] = {
  686. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
  687. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
  688. };
  689. static const struct qmp_phy_init_tbl sm8150_usb3_uniphy_serdes_tbl[] = {
  690. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SYSCLK_EN_SEL, 0x1a),
  691. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_HSCLK_SEL, 0x11),
  692. QMP_PHY_INIT_CFG(QSERDES_V4_COM_HSCLK_SEL, 0x01),
  693. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DEC_START_MODE0, 0x82),
  694. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START1_MODE0, 0xab),
  695. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START2_MODE0, 0xea),
  696. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START3_MODE0, 0x02),
  697. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE1_MODE0, 0xca),
  698. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE2_MODE0, 0x1e),
  699. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CP_CTRL_MODE0, 0x06),
  700. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_RCTRL_MODE0, 0x16),
  701. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_CCTRL_MODE0, 0x36),
  702. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE1_MODE0, 0x24),
  703. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP2_MODE0, 0x34),
  704. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP1_MODE0, 0x14),
  705. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP_EN, 0x04),
  706. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SYSCLK_BUF_ENABLE, 0x0a),
  707. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE2_MODE1, 0x02),
  708. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE1_MODE1, 0x24),
  709. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CORECLK_DIV_MODE1, 0x08),
  710. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DEC_START_MODE1, 0x82),
  711. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START1_MODE1, 0xab),
  712. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START2_MODE1, 0xea),
  713. QMP_PHY_INIT_CFG(QSERDES_V4_COM_DIV_FRAC_START3_MODE1, 0x02),
  714. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP2_MODE1, 0x82),
  715. QMP_PHY_INIT_CFG(QSERDES_V4_COM_LOCK_CMP1_MODE1, 0x34),
  716. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CP_CTRL_MODE1, 0x06),
  717. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_RCTRL_MODE1, 0x16),
  718. QMP_PHY_INIT_CFG(QSERDES_V4_COM_PLL_CCTRL_MODE1, 0x36),
  719. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE1_MODE1, 0xca),
  720. QMP_PHY_INIT_CFG(QSERDES_V4_COM_BIN_VCOCAL_CMP_CODE2_MODE1, 0x1e),
  721. QMP_PHY_INIT_CFG(QSERDES_V4_COM_CMN_IPTRIM, 0x20),
  722. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_EN_CENTER, 0x01),
  723. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_PER1, 0x31),
  724. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_PER2, 0x01),
  725. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE1_MODE1, 0xde),
  726. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE2_MODE1, 0x07),
  727. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE1_MODE0, 0xde),
  728. QMP_PHY_INIT_CFG(QSERDES_V4_COM_SSC_STEP_SIZE2_MODE0, 0x07),
  729. QMP_PHY_INIT_CFG(QSERDES_V4_COM_VCO_TUNE_MAP, 0x02),
  730. };
  731. static const struct qmp_phy_init_tbl sm8150_usb3_uniphy_tx_tbl[] = {
  732. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RCV_DETECT_LVL_2, 0x12),
  733. QMP_PHY_INIT_CFG(QSERDES_V4_TX_LANE_MODE_1, 0x95),
  734. QMP_PHY_INIT_CFG(QSERDES_V4_TX_PI_QEC_CTRL, 0x40),
  735. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_OFFSET_TX, 0x05),
  736. };
  737. static const struct qmp_phy_init_tbl sm8150_usb3_uniphy_rx_tbl[] = {
  738. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH4, 0xb8),
  739. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH3, 0x7f),
  740. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH2, 0x37),
  741. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH, 0x2f),
  742. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_LOW, 0xef),
  743. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH4, 0xb3),
  744. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH3, 0x0b),
  745. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH2, 0x5c),
  746. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH, 0xdc),
  747. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_LOW, 0xdc),
  748. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_PI_CONTROLS, 0x99),
  749. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH1, 0x04),
  750. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH2, 0x08),
  751. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN1, 0x05),
  752. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN2, 0x05),
  753. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  754. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  755. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  756. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x7f),
  757. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FO_GAIN, 0x08),
  758. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL1, 0x54),
  759. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL2, 0x0c),
  760. QMP_PHY_INIT_CFG(QSERDES_V4_RX_GM_CAL, 0x1f),
  761. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  762. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4a),
  763. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  764. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_EN_TIMER, 0x04),
  765. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x47),
  766. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  767. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_CNTRL, 0x04),
  768. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  769. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_HIGH, 0x00),
  770. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_LOW, 0xc0),
  771. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_CTLE_POST_CAL_OFFSET, 0x20),
  772. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_GAIN, 0x04),
  773. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DCC_CTRL1, 0x0c),
  774. };
  775. static const struct qmp_phy_init_tbl sm8150_usb3_uniphy_pcs_tbl[] = {
  776. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG1, 0xd0),
  777. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG2, 0x07),
  778. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG3, 0x20),
  779. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG6, 0x13),
  780. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  781. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  782. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RX_SIGDET_LVL, 0xaa),
  783. QMP_PHY_INIT_CFG(QPHY_V4_PCS_CDR_RESET_TIME, 0x0f),
  784. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG1, 0x88),
  785. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG2, 0x13),
  786. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG1, 0x4b),
  787. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG5, 0x10),
  788. QMP_PHY_INIT_CFG(QPHY_V4_PCS_REFGEN_REQ_CONFIG1, 0x21),
  789. QMP_PHY_INIT_CFG(QPHY_V4_PCS_PCS_TX_RX_CONFIG, 0x0c),
  790. };
  791. static const struct qmp_phy_init_tbl sm8150_usb3_uniphy_pcs_usb_tbl[] = {
  792. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
  793. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
  794. };
  795. static const struct qmp_phy_init_tbl sm8250_usb3_tx_tbl[] = {
  796. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_TX, 0x60),
  797. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_RX, 0x60),
  798. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_OFFSET_TX, 0x11),
  799. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_OFFSET_RX, 0x02),
  800. QMP_PHY_INIT_CFG(QSERDES_V4_TX_LANE_MODE_1, 0xd5),
  801. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RCV_DETECT_LVL_2, 0x12),
  802. QMP_PHY_INIT_CFG_LANE(QSERDES_V4_TX_PI_QEC_CTRL, 0x40, 1),
  803. QMP_PHY_INIT_CFG_LANE(QSERDES_V4_TX_PI_QEC_CTRL, 0x54, 2),
  804. };
  805. static const struct qmp_phy_init_tbl sm8250_usb3_rx_tbl[] = {
  806. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_GAIN, 0x06),
  807. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  808. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x7f),
  809. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  810. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  811. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_PI_CONTROLS, 0x99),
  812. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH1, 0x04),
  813. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH2, 0x08),
  814. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN1, 0x05),
  815. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN2, 0x05),
  816. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL1, 0x54),
  817. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL2, 0x0c),
  818. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  819. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4a),
  820. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  821. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_LOW, 0xc0),
  822. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_HIGH, 0x00),
  823. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x77),
  824. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_CNTRL, 0x04),
  825. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  826. QMP_PHY_INIT_CFG_LANE(QSERDES_V4_RX_RX_MODE_00_LOW, 0xff, 1),
  827. QMP_PHY_INIT_CFG_LANE(QSERDES_V4_RX_RX_MODE_00_LOW, 0x7f, 2),
  828. QMP_PHY_INIT_CFG_LANE(QSERDES_V4_RX_RX_MODE_00_HIGH, 0x7f, 1),
  829. QMP_PHY_INIT_CFG_LANE(QSERDES_V4_RX_RX_MODE_00_HIGH, 0xff, 2),
  830. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH2, 0x7f),
  831. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH3, 0x7f),
  832. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH4, 0x97),
  833. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_LOW, 0xdc),
  834. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH, 0xdc),
  835. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH2, 0x5c),
  836. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH3, 0x7b),
  837. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH4, 0xb4),
  838. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_EN_TIMER, 0x04),
  839. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  840. QMP_PHY_INIT_CFG(QSERDES_V4_RX_AUX_DATA_TCOARSE_TFINE, 0xa0),
  841. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DCC_CTRL1, 0x0c),
  842. QMP_PHY_INIT_CFG(QSERDES_V4_RX_GM_CAL, 0x1f),
  843. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VTH_CODE, 0x10),
  844. };
  845. static const struct qmp_phy_init_tbl sm8250_usb3_pcs_tbl[] = {
  846. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG1, 0xd0),
  847. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG2, 0x07),
  848. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG3, 0x20),
  849. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG6, 0x13),
  850. QMP_PHY_INIT_CFG(QPHY_V4_PCS_REFGEN_REQ_CONFIG1, 0x21),
  851. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RX_SIGDET_LVL, 0xa9),
  852. QMP_PHY_INIT_CFG(QPHY_V4_PCS_CDR_RESET_TIME, 0x0a),
  853. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG1, 0x88),
  854. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG2, 0x13),
  855. QMP_PHY_INIT_CFG(QPHY_V4_PCS_PCS_TX_RX_CONFIG, 0x0c),
  856. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG1, 0x4b),
  857. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG5, 0x10),
  858. };
  859. static const struct qmp_phy_init_tbl sm8250_usb3_pcs_usb_tbl[] = {
  860. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
  861. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
  862. };
  863. static const struct qmp_phy_init_tbl sm8250_usb3_uniphy_tx_tbl[] = {
  864. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RCV_DETECT_LVL_2, 0x12),
  865. QMP_PHY_INIT_CFG(QSERDES_V4_TX_LANE_MODE_1, 0xd5),
  866. QMP_PHY_INIT_CFG(QSERDES_V4_TX_LANE_MODE_2, 0x82),
  867. QMP_PHY_INIT_CFG(QSERDES_V4_TX_PI_QEC_CTRL, 0x40),
  868. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_OFFSET_TX, 0x11),
  869. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_OFFSET_RX, 0x02),
  870. };
  871. static const struct qmp_phy_init_tbl sm8250_usb3_uniphy_rx_tbl[] = {
  872. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH4, 0xb8),
  873. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH3, 0xff),
  874. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH2, 0xbf),
  875. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH, 0x7f),
  876. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_LOW, 0x7f),
  877. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH4, 0xb4),
  878. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH3, 0x7b),
  879. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH2, 0x5c),
  880. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH, 0xdc),
  881. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_LOW, 0xdc),
  882. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_PI_CONTROLS, 0x99),
  883. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH1, 0x04),
  884. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH2, 0x08),
  885. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN1, 0x05),
  886. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN2, 0x05),
  887. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  888. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  889. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  890. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x7f),
  891. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FO_GAIN, 0x0a),
  892. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL1, 0x54),
  893. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL2, 0x0c),
  894. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  895. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4a),
  896. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  897. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_EN_TIMER, 0x04),
  898. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x47),
  899. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  900. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_CNTRL, 0x04),
  901. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  902. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_HIGH, 0x00),
  903. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_LOW, 0xc0),
  904. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  905. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_GAIN, 0x06),
  906. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DCC_CTRL1, 0x0c),
  907. QMP_PHY_INIT_CFG(QSERDES_V4_RX_GM_CAL, 0x1f),
  908. };
  909. static const struct qmp_phy_init_tbl sm8250_usb3_uniphy_pcs_tbl[] = {
  910. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG1, 0xd0),
  911. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG2, 0x07),
  912. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG3, 0x20),
  913. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG6, 0x13),
  914. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  915. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  916. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RX_SIGDET_LVL, 0xa9),
  917. QMP_PHY_INIT_CFG(QPHY_V4_PCS_PCS_TX_RX_CONFIG, 0x0c),
  918. QMP_PHY_INIT_CFG(QPHY_V4_PCS_CDR_RESET_TIME, 0x0a),
  919. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG1, 0x88),
  920. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG2, 0x13),
  921. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG1, 0x4b),
  922. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG5, 0x10),
  923. QMP_PHY_INIT_CFG(QPHY_V4_PCS_REFGEN_REQ_CONFIG1, 0x21),
  924. };
  925. static const struct qmp_phy_init_tbl sm8250_usb3_uniphy_pcs_usb_tbl[] = {
  926. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
  927. QMP_PHY_INIT_CFG(QPHY_V4_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
  928. };
  929. static const struct qmp_phy_init_tbl sdx55_usb3_uniphy_tx_tbl[] = {
  930. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RCV_DETECT_LVL_2, 0x12),
  931. QMP_PHY_INIT_CFG(QSERDES_V4_TX_LANE_MODE_1, 0xd5),
  932. QMP_PHY_INIT_CFG(QSERDES_V4_TX_LANE_MODE_2, 0x80),
  933. QMP_PHY_INIT_CFG(QSERDES_V4_TX_PI_QEC_CTRL, 0x20),
  934. QMP_PHY_INIT_CFG(QSERDES_V4_TX_RES_CODE_LANE_OFFSET_TX, 0x08),
  935. };
  936. static const struct qmp_phy_init_tbl sdx55_usb3_uniphy_rx_tbl[] = {
  937. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH4, 0x26),
  938. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH3, 0x7f),
  939. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH2, 0xbf),
  940. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_HIGH, 0x7f),
  941. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_00_LOW, 0x7f),
  942. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH4, 0xb4),
  943. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH3, 0x7b),
  944. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH2, 0x5c),
  945. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_HIGH, 0xdc),
  946. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_MODE_01_LOW, 0xdc),
  947. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_PI_CONTROLS, 0x99),
  948. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH1, 0x048),
  949. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_THRESH2, 0x08),
  950. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN1, 0x00),
  951. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SB2_GAIN2, 0x04),
  952. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  953. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  954. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  955. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x7f),
  956. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_FO_GAIN, 0x09),
  957. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL1, 0x54),
  958. QMP_PHY_INIT_CFG(QSERDES_V4_RX_VGA_CAL_CNTRL2, 0x0c),
  959. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  960. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4a),
  961. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  962. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_EN_TIMER, 0x04),
  963. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x47),
  964. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  965. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_CNTRL, 0x04),
  966. QMP_PHY_INIT_CFG(QSERDES_V4_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  967. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_HIGH, 0x00),
  968. QMP_PHY_INIT_CFG(QSERDES_V4_RX_RX_IDAC_TSETTLE_LOW, 0xc0),
  969. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  970. QMP_PHY_INIT_CFG(QSERDES_V4_RX_UCDR_SO_GAIN, 0x05),
  971. QMP_PHY_INIT_CFG(QSERDES_V4_RX_DCC_CTRL1, 0x0c),
  972. QMP_PHY_INIT_CFG(QSERDES_V4_RX_GM_CAL, 0x1f),
  973. };
  974. static const struct qmp_phy_init_tbl sdx65_usb3_uniphy_tx_tbl[] = {
  975. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_1, 0xa5),
  976. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_2, 0x82),
  977. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_3, 0x3f),
  978. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_4, 0x3f),
  979. QMP_PHY_INIT_CFG(QSERDES_V5_TX_PI_QEC_CTRL, 0x21),
  980. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_TX, 0x1f),
  981. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_RX, 0x0b),
  982. };
  983. static const struct qmp_phy_init_tbl sdx65_usb3_uniphy_rx_tbl[] = {
  984. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH4, 0xdb),
  985. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH3, 0xbd),
  986. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH2, 0xff),
  987. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH, 0x7f),
  988. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_LOW, 0xff),
  989. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH4, 0xa9),
  990. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH3, 0x7b),
  991. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH2, 0xe4),
  992. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH, 0x24),
  993. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_LOW, 0x64),
  994. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_PI_CONTROLS, 0x99),
  995. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH1, 0x08),
  996. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH2, 0x08),
  997. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN1, 0x00),
  998. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN2, 0x04),
  999. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  1000. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  1001. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  1002. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FO_GAIN, 0x0a),
  1003. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL1, 0x54),
  1004. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL2, 0x0f),
  1005. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  1006. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  1007. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x47),
  1008. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  1009. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_CNTRL, 0x04),
  1010. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  1011. QMP_PHY_INIT_CFG(QSERDES_V5_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  1012. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SO_GAIN, 0x05),
  1013. QMP_PHY_INIT_CFG(QSERDES_V5_RX_GM_CAL, 0x00),
  1014. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_ENABLES, 0x00),
  1015. };
  1016. static const struct qmp_phy_init_tbl sm8350_usb3_tx_tbl[] = {
  1017. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_TX, 0x00),
  1018. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_RX, 0x00),
  1019. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_TX, 0x16),
  1020. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_RX, 0x0e),
  1021. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_1, 0x35),
  1022. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_3, 0x3f),
  1023. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_4, 0x7f),
  1024. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_5, 0x3f),
  1025. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RCV_DETECT_LVL_2, 0x12),
  1026. QMP_PHY_INIT_CFG(QSERDES_V5_TX_PI_QEC_CTRL, 0x21),
  1027. };
  1028. static const struct qmp_phy_init_tbl sm8350_usb3_rx_tbl[] = {
  1029. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FO_GAIN, 0x0a),
  1030. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SO_GAIN, 0x05),
  1031. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  1032. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x7f),
  1033. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  1034. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  1035. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_PI_CONTROLS, 0x99),
  1036. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH1, 0x08),
  1037. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH2, 0x08),
  1038. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN1, 0x00),
  1039. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN2, 0x04),
  1040. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL1, 0x54),
  1041. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL2, 0x0f),
  1042. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  1043. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4a),
  1044. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  1045. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_IDAC_TSETTLE_LOW, 0xc0),
  1046. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_IDAC_TSETTLE_HIGH, 0x00),
  1047. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x47),
  1048. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_CNTRL, 0x04),
  1049. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  1050. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_LOW, 0xbb),
  1051. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH, 0x7b),
  1052. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH2, 0xbb),
  1053. QMP_PHY_INIT_CFG_LANE(QSERDES_V5_RX_RX_MODE_00_HIGH3, 0x3d, 1),
  1054. QMP_PHY_INIT_CFG_LANE(QSERDES_V5_RX_RX_MODE_00_HIGH3, 0x3c, 2),
  1055. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH4, 0xdb),
  1056. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_LOW, 0x64),
  1057. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH, 0x24),
  1058. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH2, 0xd2),
  1059. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH3, 0x13),
  1060. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH4, 0xa9),
  1061. QMP_PHY_INIT_CFG(QSERDES_V5_RX_DFE_EN_TIMER, 0x04),
  1062. QMP_PHY_INIT_CFG(QSERDES_V5_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  1063. QMP_PHY_INIT_CFG(QSERDES_V5_RX_AUX_DATA_TCOARSE_TFINE, 0xa0),
  1064. QMP_PHY_INIT_CFG(QSERDES_V5_RX_DCC_CTRL1, 0x0c),
  1065. QMP_PHY_INIT_CFG(QSERDES_V5_RX_GM_CAL, 0x00),
  1066. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VTH_CODE, 0x10),
  1067. };
  1068. static const struct qmp_phy_init_tbl sm8350_usb3_pcs_tbl[] = {
  1069. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  1070. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  1071. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG1, 0xd0),
  1072. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG2, 0x07),
  1073. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG3, 0x20),
  1074. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG6, 0x13),
  1075. QMP_PHY_INIT_CFG(QPHY_V4_PCS_REFGEN_REQ_CONFIG1, 0x21),
  1076. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RX_SIGDET_LVL, 0xaa),
  1077. QMP_PHY_INIT_CFG(QPHY_V4_PCS_CDR_RESET_TIME, 0x0a),
  1078. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG1, 0x88),
  1079. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG2, 0x13),
  1080. QMP_PHY_INIT_CFG(QPHY_V4_PCS_PCS_TX_RX_CONFIG, 0x0c),
  1081. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG1, 0x4b),
  1082. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG5, 0x10),
  1083. };
  1084. static const struct qmp_phy_init_tbl sm8350_usb3_pcs_usb_tbl[] = {
  1085. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_RCVR_DTCT_DLY_U3_L, 0x40),
  1086. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_RCVR_DTCT_DLY_U3_H, 0x00),
  1087. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
  1088. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
  1089. };
  1090. static const struct qmp_phy_init_tbl sm8350_usb3_uniphy_tx_tbl[] = {
  1091. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_1, 0xa5),
  1092. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_2, 0x82),
  1093. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_3, 0x3f),
  1094. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_4, 0x3f),
  1095. QMP_PHY_INIT_CFG(QSERDES_V5_TX_PI_QEC_CTRL, 0x21),
  1096. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_TX, 0x10),
  1097. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_RX, 0x0e),
  1098. };
  1099. static const struct qmp_phy_init_tbl sm8350_usb3_uniphy_rx_tbl[] = {
  1100. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH4, 0xdc),
  1101. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH3, 0xbd),
  1102. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH2, 0xff),
  1103. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH, 0x7f),
  1104. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_LOW, 0xff),
  1105. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH4, 0xa9),
  1106. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH3, 0x7b),
  1107. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH2, 0xe4),
  1108. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH, 0x24),
  1109. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_LOW, 0x64),
  1110. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_PI_CONTROLS, 0x99),
  1111. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH1, 0x08),
  1112. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH2, 0x08),
  1113. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN1, 0x00),
  1114. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN2, 0x04),
  1115. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  1116. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  1117. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  1118. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FO_GAIN, 0x0a),
  1119. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL1, 0x54),
  1120. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL2, 0x0f),
  1121. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  1122. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  1123. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x47),
  1124. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  1125. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_CNTRL, 0x04),
  1126. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  1127. QMP_PHY_INIT_CFG(QSERDES_V5_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  1128. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SO_GAIN, 0x05),
  1129. QMP_PHY_INIT_CFG(QSERDES_V5_RX_GM_CAL, 0x00),
  1130. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_ENABLES, 0x00),
  1131. };
  1132. static const struct qmp_phy_init_tbl sm8350_usb3_uniphy_pcs_tbl[] = {
  1133. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG1, 0xd0),
  1134. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG2, 0x07),
  1135. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG3, 0x20),
  1136. QMP_PHY_INIT_CFG(QPHY_V4_PCS_LOCK_DETECT_CONFIG6, 0x13),
  1137. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  1138. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  1139. QMP_PHY_INIT_CFG(QPHY_V4_PCS_RX_SIGDET_LVL, 0xaa),
  1140. QMP_PHY_INIT_CFG(QPHY_V4_PCS_PCS_TX_RX_CONFIG, 0x0c),
  1141. QMP_PHY_INIT_CFG(QPHY_V4_PCS_CDR_RESET_TIME, 0x0a),
  1142. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG1, 0x88),
  1143. QMP_PHY_INIT_CFG(QPHY_V4_PCS_ALIGN_DETECT_CONFIG2, 0x13),
  1144. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG1, 0x4b),
  1145. QMP_PHY_INIT_CFG(QPHY_V4_PCS_EQ_CONFIG5, 0x10),
  1146. QMP_PHY_INIT_CFG(QPHY_V4_PCS_REFGEN_REQ_CONFIG1, 0x21),
  1147. };
  1148. static const struct qmp_phy_init_tbl sm8350_usb3_uniphy_pcs_usb_tbl[] = {
  1149. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
  1150. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
  1151. };
  1152. static const struct qmp_phy_init_tbl qcm2290_usb3_serdes_tbl[] = {
  1153. QMP_PHY_INIT_CFG(QSERDES_COM_SYSCLK_EN_SEL, 0x14),
  1154. QMP_PHY_INIT_CFG(QSERDES_COM_BIAS_EN_CLKBUFLR_EN, 0x08),
  1155. QMP_PHY_INIT_CFG(QSERDES_COM_CLK_SELECT, 0x30),
  1156. QMP_PHY_INIT_CFG(QSERDES_COM_SYS_CLK_CTRL, 0x06),
  1157. QMP_PHY_INIT_CFG(QSERDES_COM_RESETSM_CNTRL, 0x00),
  1158. QMP_PHY_INIT_CFG(QSERDES_COM_RESETSM_CNTRL2, 0x08),
  1159. QMP_PHY_INIT_CFG(QSERDES_COM_BG_TRIM, 0x0f),
  1160. QMP_PHY_INIT_CFG(QSERDES_COM_SVS_MODE_CLK_SEL, 0x01),
  1161. QMP_PHY_INIT_CFG(QSERDES_COM_HSCLK_SEL, 0x00),
  1162. QMP_PHY_INIT_CFG(QSERDES_COM_DEC_START_MODE0, 0x82),
  1163. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START1_MODE0, 0x55),
  1164. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START2_MODE0, 0x55),
  1165. QMP_PHY_INIT_CFG(QSERDES_COM_DIV_FRAC_START3_MODE0, 0x03),
  1166. QMP_PHY_INIT_CFG(QSERDES_COM_CP_CTRL_MODE0, 0x0b),
  1167. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_RCTRL_MODE0, 0x16),
  1168. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_CCTRL_MODE0, 0x28),
  1169. QMP_PHY_INIT_CFG(QSERDES_COM_INTEGLOOP_GAIN0_MODE0, 0x80),
  1170. QMP_PHY_INIT_CFG(QSERDES_COM_INTEGLOOP_GAIN1_MODE0, 0x00),
  1171. QMP_PHY_INIT_CFG(QSERDES_COM_CORECLK_DIV, 0x0a),
  1172. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP1_MODE0, 0x15),
  1173. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP2_MODE0, 0x34),
  1174. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP3_MODE0, 0x00),
  1175. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP_EN, 0x00),
  1176. QMP_PHY_INIT_CFG(QSERDES_COM_CORE_CLK_EN, 0x00),
  1177. QMP_PHY_INIT_CFG(QSERDES_COM_LOCK_CMP_CFG, 0x00),
  1178. QMP_PHY_INIT_CFG(QSERDES_COM_VCO_TUNE_MAP, 0x00),
  1179. QMP_PHY_INIT_CFG(QSERDES_COM_BG_TIMER, 0x0a),
  1180. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_EN_CENTER, 0x01),
  1181. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_PER1, 0x31),
  1182. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_PER2, 0x01),
  1183. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_ADJ_PER1, 0x00),
  1184. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_ADJ_PER2, 0x00),
  1185. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_STEP_SIZE1, 0xde),
  1186. QMP_PHY_INIT_CFG(QSERDES_COM_SSC_STEP_SIZE2, 0x07),
  1187. QMP_PHY_INIT_CFG(QSERDES_COM_PLL_IVCO, 0x0f),
  1188. QMP_PHY_INIT_CFG(QSERDES_COM_CMN_CONFIG, 0x06),
  1189. QMP_PHY_INIT_CFG(QSERDES_COM_INTEGLOOP_INITVAL, 0x80),
  1190. QMP_PHY_INIT_CFG(QSERDES_COM_BIAS_EN_CTRL_BY_PSM, 0x01),
  1191. };
  1192. static const struct qmp_phy_init_tbl qcm2290_usb3_tx_tbl[] = {
  1193. QMP_PHY_INIT_CFG(QSERDES_V3_TX_HIGHZ_DRVR_EN, 0x10),
  1194. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RCV_DETECT_LVL_2, 0x12),
  1195. QMP_PHY_INIT_CFG(QSERDES_V3_TX_LANE_MODE_1, 0xc6),
  1196. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RES_CODE_LANE_OFFSET_TX, 0x00),
  1197. QMP_PHY_INIT_CFG(QSERDES_V3_TX_RES_CODE_LANE_OFFSET_RX, 0x00),
  1198. };
  1199. static const struct qmp_phy_init_tbl qcm2290_usb3_rx_tbl[] = {
  1200. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_FO_GAIN, 0x0b),
  1201. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_PI_CONTROLS, 0x00),
  1202. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_COUNT_LOW, 0x00),
  1203. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x00),
  1204. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_FO_GAIN, 0x0a),
  1205. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_SO_GAIN, 0x06),
  1206. QMP_PHY_INIT_CFG(QSERDES_V3_RX_UCDR_SO_SATURATION_AND_ENABLE, 0x75),
  1207. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL2, 0x02),
  1208. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL3, 0x4e),
  1209. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQU_ADAPTOR_CNTRL4, 0x18),
  1210. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x77),
  1211. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  1212. QMP_PHY_INIT_CFG(QSERDES_V3_RX_VGA_CAL_CNTRL2, 0x0a),
  1213. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_CNTRL, 0x03),
  1214. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_DEGLITCH_CNTRL, 0x16),
  1215. QMP_PHY_INIT_CFG(QSERDES_V3_RX_SIGDET_ENABLES, 0x00),
  1216. QMP_PHY_INIT_CFG(QSERDES_V3_RX_RX_MODE_00, 0x00),
  1217. };
  1218. static const struct qmp_phy_init_tbl qcm2290_usb3_pcs_tbl[] = {
  1219. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXMGN_V0, 0x9f),
  1220. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M6DB_V0, 0x17),
  1221. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TXDEEMPH_M3P5DB_V0, 0x0f),
  1222. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL2, 0x83),
  1223. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNTRL1, 0x02),
  1224. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_L, 0x09),
  1225. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_CNT_VAL_H_TOL, 0xa2),
  1226. QMP_PHY_INIT_CFG(QPHY_V3_PCS_FLL_MAN_CODE, 0x85),
  1227. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG1, 0xd1),
  1228. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG2, 0x1f),
  1229. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LOCK_DETECT_CONFIG3, 0x47),
  1230. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_WAIT_TIME, 0x75),
  1231. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RXEQTRAINING_RUN_TIME, 0x13),
  1232. QMP_PHY_INIT_CFG(QPHY_V3_PCS_LFPS_TX_ECSTART_EQTLOCK, 0x86),
  1233. QMP_PHY_INIT_CFG(QPHY_V3_PCS_PWRUP_RESET_DLY_TIME_AUXCLK, 0x04),
  1234. QMP_PHY_INIT_CFG(QPHY_V3_PCS_TSYNC_RSYNC_TIME, 0x44),
  1235. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  1236. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  1237. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_L, 0x40),
  1238. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RCVR_DTCT_DLY_U3_H, 0x00),
  1239. QMP_PHY_INIT_CFG(QPHY_V3_PCS_RX_SIGDET_LVL, 0x88),
  1240. };
  1241. static const struct qmp_phy_init_tbl sc8280xp_usb3_uniphy_serdes_tbl[] = {
  1242. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SYSCLK_EN_SEL, 0x1a),
  1243. QMP_PHY_INIT_CFG(QSERDES_V5_COM_BIN_VCOCAL_HSCLK_SEL, 0x11),
  1244. QMP_PHY_INIT_CFG(QSERDES_V5_COM_HSCLK_SEL, 0x01),
  1245. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DEC_START_MODE0, 0x82),
  1246. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START1_MODE0, 0xab),
  1247. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START2_MODE0, 0xea),
  1248. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START3_MODE0, 0x02),
  1249. QMP_PHY_INIT_CFG(QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE1_MODE0, 0xca),
  1250. QMP_PHY_INIT_CFG(QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE2_MODE0, 0x1e),
  1251. QMP_PHY_INIT_CFG(QSERDES_V5_COM_CP_CTRL_MODE0, 0x06),
  1252. QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_RCTRL_MODE0, 0x16),
  1253. QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_CCTRL_MODE0, 0x36),
  1254. QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE1_MODE0, 0x24),
  1255. QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP2_MODE0, 0x34),
  1256. QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP1_MODE0, 0x14),
  1257. QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP_EN, 0x04),
  1258. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SYSCLK_BUF_ENABLE, 0x0a),
  1259. QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE2_MODE1, 0x02),
  1260. QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE1_MODE1, 0x24),
  1261. QMP_PHY_INIT_CFG(QSERDES_V5_COM_CORECLK_DIV_MODE1, 0x08),
  1262. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DEC_START_MODE1, 0x82),
  1263. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START1_MODE1, 0xab),
  1264. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START2_MODE1, 0xea),
  1265. QMP_PHY_INIT_CFG(QSERDES_V5_COM_DIV_FRAC_START3_MODE1, 0x02),
  1266. QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP2_MODE1, 0x82),
  1267. QMP_PHY_INIT_CFG(QSERDES_V5_COM_LOCK_CMP1_MODE1, 0x34),
  1268. QMP_PHY_INIT_CFG(QSERDES_V5_COM_CP_CTRL_MODE1, 0x06),
  1269. QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_RCTRL_MODE1, 0x16),
  1270. QMP_PHY_INIT_CFG(QSERDES_V5_COM_PLL_CCTRL_MODE1, 0x36),
  1271. QMP_PHY_INIT_CFG(QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE1_MODE1, 0xca),
  1272. QMP_PHY_INIT_CFG(QSERDES_V5_COM_BIN_VCOCAL_CMP_CODE2_MODE1, 0x1e),
  1273. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_EN_CENTER, 0x01),
  1274. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_PER1, 0x31),
  1275. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_PER2, 0x01),
  1276. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE1_MODE1, 0xde),
  1277. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE2_MODE1, 0x07),
  1278. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE1_MODE0, 0xde),
  1279. QMP_PHY_INIT_CFG(QSERDES_V5_COM_SSC_STEP_SIZE2_MODE0, 0x07),
  1280. QMP_PHY_INIT_CFG(QSERDES_V5_COM_VCO_TUNE_MAP, 0x02),
  1281. };
  1282. static const struct qmp_phy_init_tbl sc8280xp_usb3_uniphy_tx_tbl[] = {
  1283. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_1, 0xa5),
  1284. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_2, 0x82),
  1285. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_3, 0x3f),
  1286. QMP_PHY_INIT_CFG(QSERDES_V5_TX_LANE_MODE_4, 0x3f),
  1287. QMP_PHY_INIT_CFG(QSERDES_V5_TX_PI_QEC_CTRL, 0x21),
  1288. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_TX, 0x10),
  1289. QMP_PHY_INIT_CFG(QSERDES_V5_TX_RES_CODE_LANE_OFFSET_RX, 0x0e),
  1290. };
  1291. static const struct qmp_phy_init_tbl sc8280xp_usb3_uniphy_rx_tbl[] = {
  1292. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH4, 0xdc),
  1293. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH3, 0xbd),
  1294. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH2, 0xff),
  1295. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_HIGH, 0x7f),
  1296. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_00_LOW, 0xff),
  1297. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH4, 0xa9),
  1298. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH3, 0x7b),
  1299. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH2, 0xe4),
  1300. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_HIGH, 0x24),
  1301. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_MODE_01_LOW, 0x64),
  1302. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_PI_CONTROLS, 0x99),
  1303. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH1, 0x08),
  1304. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_THRESH2, 0x08),
  1305. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN1, 0x00),
  1306. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SB2_GAIN2, 0x04),
  1307. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_FO_GAIN, 0x2f),
  1308. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_LOW, 0xff),
  1309. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_FASTLOCK_COUNT_HIGH, 0x0f),
  1310. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SO_GAIN, 0x0a),
  1311. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL1, 0x54),
  1312. QMP_PHY_INIT_CFG(QSERDES_V5_RX_VGA_CAL_CNTRL2, 0x0f),
  1313. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL2, 0x0f),
  1314. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQU_ADAPTOR_CNTRL4, 0x0a),
  1315. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_EQ_OFFSET_ADAPTOR_CNTRL1, 0x47),
  1316. QMP_PHY_INIT_CFG(QSERDES_V5_RX_RX_OFFSET_ADAPTOR_CNTRL2, 0x80),
  1317. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_CNTRL, 0x04),
  1318. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_DEGLITCH_CNTRL, 0x0e),
  1319. QMP_PHY_INIT_CFG(QSERDES_V5_RX_DFE_CTLE_POST_CAL_OFFSET, 0x38),
  1320. QMP_PHY_INIT_CFG(QSERDES_V5_RX_UCDR_SO_GAIN, 0x05),
  1321. QMP_PHY_INIT_CFG(QSERDES_V5_RX_GM_CAL, 0x00),
  1322. QMP_PHY_INIT_CFG(QSERDES_V5_RX_SIGDET_ENABLES, 0x00),
  1323. };
  1324. static const struct qmp_phy_init_tbl sc8280xp_usb3_uniphy_pcs_tbl[] = {
  1325. QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG1, 0xd0),
  1326. QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG2, 0x07),
  1327. QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG3, 0x20),
  1328. QMP_PHY_INIT_CFG(QPHY_V5_PCS_LOCK_DETECT_CONFIG6, 0x13),
  1329. QMP_PHY_INIT_CFG(QPHY_V5_PCS_RCVR_DTCT_DLY_P1U2_L, 0xe7),
  1330. QMP_PHY_INIT_CFG(QPHY_V5_PCS_RCVR_DTCT_DLY_P1U2_H, 0x03),
  1331. QMP_PHY_INIT_CFG(QPHY_V5_PCS_RX_SIGDET_LVL, 0xaa),
  1332. QMP_PHY_INIT_CFG(QPHY_V5_PCS_PCS_TX_RX_CONFIG, 0x0c),
  1333. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_RXEQTRAINING_DFE_TIME_S2, 0x07),
  1334. QMP_PHY_INIT_CFG(QPHY_V5_PCS_USB3_LFPS_DET_HIGH_COUNT_VAL, 0xf8),
  1335. QMP_PHY_INIT_CFG(QPHY_V5_PCS_CDR_RESET_TIME, 0x0a),
  1336. QMP_PHY_INIT_CFG(QPHY_V5_PCS_ALIGN_DETECT_CONFIG1, 0x88),
  1337. QMP_PHY_INIT_CFG(QPHY_V5_PCS_ALIGN_DETECT_CONFIG2, 0x13),
  1338. QMP_PHY_INIT_CFG(QPHY_V5_PCS_EQ_CONFIG1, 0x4b),
  1339. QMP_PHY_INIT_CFG(QPHY_V5_PCS_EQ_CONFIG5, 0x10),
  1340. QMP_PHY_INIT_CFG(QPHY_V5_PCS_REFGEN_REQ_CONFIG1, 0x21),
  1341. };
  1342. /* struct qmp_phy_cfg - per-PHY initialization config */
  1343. struct qmp_phy_cfg {
  1344. int lanes;
  1345. /* Init sequence for PHY blocks - serdes, tx, rx, pcs */
  1346. const struct qmp_phy_init_tbl *serdes_tbl;
  1347. int serdes_tbl_num;
  1348. const struct qmp_phy_init_tbl *tx_tbl;
  1349. int tx_tbl_num;
  1350. const struct qmp_phy_init_tbl *rx_tbl;
  1351. int rx_tbl_num;
  1352. const struct qmp_phy_init_tbl *pcs_tbl;
  1353. int pcs_tbl_num;
  1354. const struct qmp_phy_init_tbl *pcs_usb_tbl;
  1355. int pcs_usb_tbl_num;
  1356. /* clock ids to be requested */
  1357. const char * const *clk_list;
  1358. int num_clks;
  1359. /* resets to be requested */
  1360. const char * const *reset_list;
  1361. int num_resets;
  1362. /* regulators to be requested */
  1363. const char * const *vreg_list;
  1364. int num_vregs;
  1365. /* array of registers with different offsets */
  1366. const unsigned int *regs;
  1367. /* true, if PHY needs delay after POWER_DOWN */
  1368. bool has_pwrdn_delay;
  1369. /* true, if PHY has a separate DP_COM control block */
  1370. bool has_phy_dp_com_ctrl;
  1371. /* Offset from PCS to PCS_USB region */
  1372. unsigned int pcs_usb_offset;
  1373. };
  1374. /**
  1375. * struct qmp_phy - per-lane phy descriptor
  1376. *
  1377. * @phy: generic phy
  1378. * @cfg: phy specific configuration
  1379. * @serdes: iomapped memory space for phy's serdes (i.e. PLL)
  1380. * @tx: iomapped memory space for lane's tx
  1381. * @rx: iomapped memory space for lane's rx
  1382. * @pcs: iomapped memory space for lane's pcs
  1383. * @tx2: iomapped memory space for second lane's tx (in dual lane PHYs)
  1384. * @rx2: iomapped memory space for second lane's rx (in dual lane PHYs)
  1385. * @pcs_misc: iomapped memory space for lane's pcs_misc
  1386. * @pcs_usb: iomapped memory space for lane's pcs_usb
  1387. * @pipe_clk: pipe clock
  1388. * @qmp: QMP phy to which this lane belongs
  1389. * @mode: current PHY mode
  1390. */
  1391. struct qmp_phy {
  1392. struct phy *phy;
  1393. const struct qmp_phy_cfg *cfg;
  1394. void __iomem *serdes;
  1395. void __iomem *tx;
  1396. void __iomem *rx;
  1397. void __iomem *pcs;
  1398. void __iomem *tx2;
  1399. void __iomem *rx2;
  1400. void __iomem *pcs_misc;
  1401. void __iomem *pcs_usb;
  1402. struct clk *pipe_clk;
  1403. struct qcom_qmp *qmp;
  1404. enum phy_mode mode;
  1405. };
  1406. /**
  1407. * struct qcom_qmp - structure holding QMP phy block attributes
  1408. *
  1409. * @dev: device
  1410. * @dp_com: iomapped memory space for phy's dp_com control block
  1411. *
  1412. * @clks: array of clocks required by phy
  1413. * @resets: array of resets required by phy
  1414. * @vregs: regulator supplies bulk data
  1415. *
  1416. * @phys: array of per-lane phy descriptors
  1417. */
  1418. struct qcom_qmp {
  1419. struct device *dev;
  1420. void __iomem *dp_com;
  1421. struct clk_bulk_data *clks;
  1422. struct reset_control_bulk_data *resets;
  1423. struct regulator_bulk_data *vregs;
  1424. struct qmp_phy **phys;
  1425. };
  1426. static inline void qphy_setbits(void __iomem *base, u32 offset, u32 val)
  1427. {
  1428. u32 reg;
  1429. reg = readl(base + offset);
  1430. reg |= val;
  1431. writel(reg, base + offset);
  1432. /* ensure that above write is through */
  1433. readl(base + offset);
  1434. }
  1435. static inline void qphy_clrbits(void __iomem *base, u32 offset, u32 val)
  1436. {
  1437. u32 reg;
  1438. reg = readl(base + offset);
  1439. reg &= ~val;
  1440. writel(reg, base + offset);
  1441. /* ensure that above write is through */
  1442. readl(base + offset);
  1443. }
  1444. /* list of clocks required by phy */
  1445. static const char * const msm8996_phy_clk_l[] = {
  1446. "aux", "cfg_ahb", "ref",
  1447. };
  1448. static const char * const qmp_v3_phy_clk_l[] = {
  1449. "aux", "cfg_ahb", "ref", "com_aux",
  1450. };
  1451. static const char * const qmp_v4_phy_clk_l[] = {
  1452. "aux", "ref_clk_src", "ref", "com_aux",
  1453. };
  1454. /* the primary usb3 phy on sm8250 doesn't have a ref clock */
  1455. static const char * const qmp_v4_sm8250_usbphy_clk_l[] = {
  1456. "aux", "ref_clk_src", "com_aux"
  1457. };
  1458. /* usb3 phy on sdx55 doesn't have com_aux clock */
  1459. static const char * const qmp_v4_sdx55_usbphy_clk_l[] = {
  1460. "aux", "cfg_ahb", "ref"
  1461. };
  1462. static const char * const qcm2290_usb3phy_clk_l[] = {
  1463. "cfg_ahb", "ref", "com_aux",
  1464. };
  1465. /* list of resets */
  1466. static const char * const msm8996_usb3phy_reset_l[] = {
  1467. "phy", "common",
  1468. };
  1469. static const char * const sc7180_usb3phy_reset_l[] = {
  1470. "phy",
  1471. };
  1472. static const char * const qcm2290_usb3phy_reset_l[] = {
  1473. "phy_phy", "phy",
  1474. };
  1475. /* list of regulators */
  1476. static const char * const qmp_phy_vreg_l[] = {
  1477. "vdda-phy", "vdda-pll",
  1478. };
  1479. static const struct qmp_phy_cfg ipq8074_usb3phy_cfg = {
  1480. .lanes = 1,
  1481. .serdes_tbl = ipq8074_usb3_serdes_tbl,
  1482. .serdes_tbl_num = ARRAY_SIZE(ipq8074_usb3_serdes_tbl),
  1483. .tx_tbl = msm8996_usb3_tx_tbl,
  1484. .tx_tbl_num = ARRAY_SIZE(msm8996_usb3_tx_tbl),
  1485. .rx_tbl = ipq8074_usb3_rx_tbl,
  1486. .rx_tbl_num = ARRAY_SIZE(ipq8074_usb3_rx_tbl),
  1487. .pcs_tbl = ipq8074_usb3_pcs_tbl,
  1488. .pcs_tbl_num = ARRAY_SIZE(ipq8074_usb3_pcs_tbl),
  1489. .clk_list = msm8996_phy_clk_l,
  1490. .num_clks = ARRAY_SIZE(msm8996_phy_clk_l),
  1491. .reset_list = msm8996_usb3phy_reset_l,
  1492. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1493. .vreg_list = qmp_phy_vreg_l,
  1494. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1495. .regs = qmp_v3_usb3phy_regs_layout,
  1496. };
  1497. static const struct qmp_phy_cfg msm8996_usb3phy_cfg = {
  1498. .lanes = 1,
  1499. .serdes_tbl = msm8996_usb3_serdes_tbl,
  1500. .serdes_tbl_num = ARRAY_SIZE(msm8996_usb3_serdes_tbl),
  1501. .tx_tbl = msm8996_usb3_tx_tbl,
  1502. .tx_tbl_num = ARRAY_SIZE(msm8996_usb3_tx_tbl),
  1503. .rx_tbl = msm8996_usb3_rx_tbl,
  1504. .rx_tbl_num = ARRAY_SIZE(msm8996_usb3_rx_tbl),
  1505. .pcs_tbl = msm8996_usb3_pcs_tbl,
  1506. .pcs_tbl_num = ARRAY_SIZE(msm8996_usb3_pcs_tbl),
  1507. .clk_list = msm8996_phy_clk_l,
  1508. .num_clks = ARRAY_SIZE(msm8996_phy_clk_l),
  1509. .reset_list = msm8996_usb3phy_reset_l,
  1510. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1511. .vreg_list = qmp_phy_vreg_l,
  1512. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1513. .regs = usb3phy_regs_layout,
  1514. };
  1515. static const struct qmp_phy_cfg qmp_v3_usb3phy_cfg = {
  1516. .lanes = 2,
  1517. .serdes_tbl = qmp_v3_usb3_serdes_tbl,
  1518. .serdes_tbl_num = ARRAY_SIZE(qmp_v3_usb3_serdes_tbl),
  1519. .tx_tbl = qmp_v3_usb3_tx_tbl,
  1520. .tx_tbl_num = ARRAY_SIZE(qmp_v3_usb3_tx_tbl),
  1521. .rx_tbl = qmp_v3_usb3_rx_tbl,
  1522. .rx_tbl_num = ARRAY_SIZE(qmp_v3_usb3_rx_tbl),
  1523. .pcs_tbl = qmp_v3_usb3_pcs_tbl,
  1524. .pcs_tbl_num = ARRAY_SIZE(qmp_v3_usb3_pcs_tbl),
  1525. .clk_list = qmp_v3_phy_clk_l,
  1526. .num_clks = ARRAY_SIZE(qmp_v3_phy_clk_l),
  1527. .reset_list = msm8996_usb3phy_reset_l,
  1528. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1529. .vreg_list = qmp_phy_vreg_l,
  1530. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1531. .regs = qmp_v3_usb3phy_regs_layout,
  1532. .has_pwrdn_delay = true,
  1533. .has_phy_dp_com_ctrl = true,
  1534. };
  1535. static const struct qmp_phy_cfg sc7180_usb3phy_cfg = {
  1536. .lanes = 2,
  1537. .serdes_tbl = qmp_v3_usb3_serdes_tbl,
  1538. .serdes_tbl_num = ARRAY_SIZE(qmp_v3_usb3_serdes_tbl),
  1539. .tx_tbl = qmp_v3_usb3_tx_tbl,
  1540. .tx_tbl_num = ARRAY_SIZE(qmp_v3_usb3_tx_tbl),
  1541. .rx_tbl = qmp_v3_usb3_rx_tbl,
  1542. .rx_tbl_num = ARRAY_SIZE(qmp_v3_usb3_rx_tbl),
  1543. .pcs_tbl = qmp_v3_usb3_pcs_tbl,
  1544. .pcs_tbl_num = ARRAY_SIZE(qmp_v3_usb3_pcs_tbl),
  1545. .clk_list = qmp_v3_phy_clk_l,
  1546. .num_clks = ARRAY_SIZE(qmp_v3_phy_clk_l),
  1547. .reset_list = sc7180_usb3phy_reset_l,
  1548. .num_resets = ARRAY_SIZE(sc7180_usb3phy_reset_l),
  1549. .vreg_list = qmp_phy_vreg_l,
  1550. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1551. .regs = qmp_v3_usb3phy_regs_layout,
  1552. .has_pwrdn_delay = true,
  1553. .has_phy_dp_com_ctrl = true,
  1554. };
  1555. static const struct qmp_phy_cfg sc8280xp_usb3_uniphy_cfg = {
  1556. .lanes = 1,
  1557. .serdes_tbl = sc8280xp_usb3_uniphy_serdes_tbl,
  1558. .serdes_tbl_num = ARRAY_SIZE(sc8280xp_usb3_uniphy_serdes_tbl),
  1559. .tx_tbl = sc8280xp_usb3_uniphy_tx_tbl,
  1560. .tx_tbl_num = ARRAY_SIZE(sc8280xp_usb3_uniphy_tx_tbl),
  1561. .rx_tbl = sc8280xp_usb3_uniphy_rx_tbl,
  1562. .rx_tbl_num = ARRAY_SIZE(sc8280xp_usb3_uniphy_rx_tbl),
  1563. .pcs_tbl = sc8280xp_usb3_uniphy_pcs_tbl,
  1564. .pcs_tbl_num = ARRAY_SIZE(sc8280xp_usb3_uniphy_pcs_tbl),
  1565. .clk_list = qmp_v4_phy_clk_l,
  1566. .num_clks = ARRAY_SIZE(qmp_v4_phy_clk_l),
  1567. .reset_list = msm8996_usb3phy_reset_l,
  1568. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1569. .vreg_list = qmp_phy_vreg_l,
  1570. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1571. .regs = qmp_v4_usb3phy_regs_layout,
  1572. .pcs_usb_offset = 0x1000,
  1573. };
  1574. static const struct qmp_phy_cfg qmp_v3_usb3_uniphy_cfg = {
  1575. .lanes = 1,
  1576. .serdes_tbl = qmp_v3_usb3_uniphy_serdes_tbl,
  1577. .serdes_tbl_num = ARRAY_SIZE(qmp_v3_usb3_uniphy_serdes_tbl),
  1578. .tx_tbl = qmp_v3_usb3_uniphy_tx_tbl,
  1579. .tx_tbl_num = ARRAY_SIZE(qmp_v3_usb3_uniphy_tx_tbl),
  1580. .rx_tbl = qmp_v3_usb3_uniphy_rx_tbl,
  1581. .rx_tbl_num = ARRAY_SIZE(qmp_v3_usb3_uniphy_rx_tbl),
  1582. .pcs_tbl = qmp_v3_usb3_uniphy_pcs_tbl,
  1583. .pcs_tbl_num = ARRAY_SIZE(qmp_v3_usb3_uniphy_pcs_tbl),
  1584. .clk_list = qmp_v3_phy_clk_l,
  1585. .num_clks = ARRAY_SIZE(qmp_v3_phy_clk_l),
  1586. .reset_list = msm8996_usb3phy_reset_l,
  1587. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1588. .vreg_list = qmp_phy_vreg_l,
  1589. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1590. .regs = qmp_v3_usb3phy_regs_layout,
  1591. .has_pwrdn_delay = true,
  1592. };
  1593. static const struct qmp_phy_cfg msm8998_usb3phy_cfg = {
  1594. .lanes = 2,
  1595. .serdes_tbl = msm8998_usb3_serdes_tbl,
  1596. .serdes_tbl_num = ARRAY_SIZE(msm8998_usb3_serdes_tbl),
  1597. .tx_tbl = msm8998_usb3_tx_tbl,
  1598. .tx_tbl_num = ARRAY_SIZE(msm8998_usb3_tx_tbl),
  1599. .rx_tbl = msm8998_usb3_rx_tbl,
  1600. .rx_tbl_num = ARRAY_SIZE(msm8998_usb3_rx_tbl),
  1601. .pcs_tbl = msm8998_usb3_pcs_tbl,
  1602. .pcs_tbl_num = ARRAY_SIZE(msm8998_usb3_pcs_tbl),
  1603. .clk_list = msm8996_phy_clk_l,
  1604. .num_clks = ARRAY_SIZE(msm8996_phy_clk_l),
  1605. .reset_list = msm8996_usb3phy_reset_l,
  1606. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1607. .vreg_list = qmp_phy_vreg_l,
  1608. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1609. .regs = qmp_v3_usb3phy_regs_layout,
  1610. };
  1611. static const struct qmp_phy_cfg sm8150_usb3phy_cfg = {
  1612. .lanes = 2,
  1613. .serdes_tbl = sm8150_usb3_serdes_tbl,
  1614. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_serdes_tbl),
  1615. .tx_tbl = sm8150_usb3_tx_tbl,
  1616. .tx_tbl_num = ARRAY_SIZE(sm8150_usb3_tx_tbl),
  1617. .rx_tbl = sm8150_usb3_rx_tbl,
  1618. .rx_tbl_num = ARRAY_SIZE(sm8150_usb3_rx_tbl),
  1619. .pcs_tbl = sm8150_usb3_pcs_tbl,
  1620. .pcs_tbl_num = ARRAY_SIZE(sm8150_usb3_pcs_tbl),
  1621. .pcs_usb_tbl = sm8150_usb3_pcs_usb_tbl,
  1622. .pcs_usb_tbl_num = ARRAY_SIZE(sm8150_usb3_pcs_usb_tbl),
  1623. .clk_list = qmp_v4_phy_clk_l,
  1624. .num_clks = ARRAY_SIZE(qmp_v4_phy_clk_l),
  1625. .reset_list = msm8996_usb3phy_reset_l,
  1626. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1627. .vreg_list = qmp_phy_vreg_l,
  1628. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1629. .regs = qmp_v4_usb3phy_regs_layout,
  1630. .pcs_usb_offset = 0x300,
  1631. .has_pwrdn_delay = true,
  1632. .has_phy_dp_com_ctrl = true,
  1633. };
  1634. static const struct qmp_phy_cfg sm8150_usb3_uniphy_cfg = {
  1635. .lanes = 1,
  1636. .serdes_tbl = sm8150_usb3_uniphy_serdes_tbl,
  1637. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_serdes_tbl),
  1638. .tx_tbl = sm8150_usb3_uniphy_tx_tbl,
  1639. .tx_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_tx_tbl),
  1640. .rx_tbl = sm8150_usb3_uniphy_rx_tbl,
  1641. .rx_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_rx_tbl),
  1642. .pcs_tbl = sm8150_usb3_uniphy_pcs_tbl,
  1643. .pcs_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_pcs_tbl),
  1644. .pcs_usb_tbl = sm8150_usb3_uniphy_pcs_usb_tbl,
  1645. .pcs_usb_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_pcs_usb_tbl),
  1646. .clk_list = qmp_v4_phy_clk_l,
  1647. .num_clks = ARRAY_SIZE(qmp_v4_phy_clk_l),
  1648. .reset_list = msm8996_usb3phy_reset_l,
  1649. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1650. .vreg_list = qmp_phy_vreg_l,
  1651. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1652. .regs = qmp_v4_usb3phy_regs_layout,
  1653. .pcs_usb_offset = 0x600,
  1654. .has_pwrdn_delay = true,
  1655. };
  1656. static const struct qmp_phy_cfg sm8250_usb3phy_cfg = {
  1657. .lanes = 2,
  1658. .serdes_tbl = sm8150_usb3_serdes_tbl,
  1659. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_serdes_tbl),
  1660. .tx_tbl = sm8250_usb3_tx_tbl,
  1661. .tx_tbl_num = ARRAY_SIZE(sm8250_usb3_tx_tbl),
  1662. .rx_tbl = sm8250_usb3_rx_tbl,
  1663. .rx_tbl_num = ARRAY_SIZE(sm8250_usb3_rx_tbl),
  1664. .pcs_tbl = sm8250_usb3_pcs_tbl,
  1665. .pcs_tbl_num = ARRAY_SIZE(sm8250_usb3_pcs_tbl),
  1666. .pcs_usb_tbl = sm8250_usb3_pcs_usb_tbl,
  1667. .pcs_usb_tbl_num = ARRAY_SIZE(sm8250_usb3_pcs_usb_tbl),
  1668. .clk_list = qmp_v4_sm8250_usbphy_clk_l,
  1669. .num_clks = ARRAY_SIZE(qmp_v4_sm8250_usbphy_clk_l),
  1670. .reset_list = msm8996_usb3phy_reset_l,
  1671. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1672. .vreg_list = qmp_phy_vreg_l,
  1673. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1674. .regs = qmp_v4_usb3phy_regs_layout,
  1675. .pcs_usb_offset = 0x300,
  1676. .has_pwrdn_delay = true,
  1677. .has_phy_dp_com_ctrl = true,
  1678. };
  1679. static const struct qmp_phy_cfg sm8250_usb3_uniphy_cfg = {
  1680. .lanes = 1,
  1681. .serdes_tbl = sm8150_usb3_uniphy_serdes_tbl,
  1682. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_serdes_tbl),
  1683. .tx_tbl = sm8250_usb3_uniphy_tx_tbl,
  1684. .tx_tbl_num = ARRAY_SIZE(sm8250_usb3_uniphy_tx_tbl),
  1685. .rx_tbl = sm8250_usb3_uniphy_rx_tbl,
  1686. .rx_tbl_num = ARRAY_SIZE(sm8250_usb3_uniphy_rx_tbl),
  1687. .pcs_tbl = sm8250_usb3_uniphy_pcs_tbl,
  1688. .pcs_tbl_num = ARRAY_SIZE(sm8250_usb3_uniphy_pcs_tbl),
  1689. .pcs_usb_tbl = sm8250_usb3_uniphy_pcs_usb_tbl,
  1690. .pcs_usb_tbl_num = ARRAY_SIZE(sm8250_usb3_uniphy_pcs_usb_tbl),
  1691. .clk_list = qmp_v4_phy_clk_l,
  1692. .num_clks = ARRAY_SIZE(qmp_v4_phy_clk_l),
  1693. .reset_list = msm8996_usb3phy_reset_l,
  1694. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1695. .vreg_list = qmp_phy_vreg_l,
  1696. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1697. .regs = qmp_v4_usb3phy_regs_layout,
  1698. .pcs_usb_offset = 0x600,
  1699. .has_pwrdn_delay = true,
  1700. };
  1701. static const struct qmp_phy_cfg sdx55_usb3_uniphy_cfg = {
  1702. .lanes = 1,
  1703. .serdes_tbl = sm8150_usb3_uniphy_serdes_tbl,
  1704. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_serdes_tbl),
  1705. .tx_tbl = sdx55_usb3_uniphy_tx_tbl,
  1706. .tx_tbl_num = ARRAY_SIZE(sdx55_usb3_uniphy_tx_tbl),
  1707. .rx_tbl = sdx55_usb3_uniphy_rx_tbl,
  1708. .rx_tbl_num = ARRAY_SIZE(sdx55_usb3_uniphy_rx_tbl),
  1709. .pcs_tbl = sm8250_usb3_uniphy_pcs_tbl,
  1710. .pcs_tbl_num = ARRAY_SIZE(sm8250_usb3_uniphy_pcs_tbl),
  1711. .pcs_usb_tbl = sm8250_usb3_uniphy_pcs_usb_tbl,
  1712. .pcs_usb_tbl_num = ARRAY_SIZE(sm8250_usb3_uniphy_pcs_usb_tbl),
  1713. .clk_list = qmp_v4_sdx55_usbphy_clk_l,
  1714. .num_clks = ARRAY_SIZE(qmp_v4_sdx55_usbphy_clk_l),
  1715. .reset_list = msm8996_usb3phy_reset_l,
  1716. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1717. .vreg_list = qmp_phy_vreg_l,
  1718. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1719. .regs = qmp_v4_usb3phy_regs_layout,
  1720. .pcs_usb_offset = 0x600,
  1721. .has_pwrdn_delay = true,
  1722. };
  1723. static const struct qmp_phy_cfg sdx65_usb3_uniphy_cfg = {
  1724. .lanes = 1,
  1725. .serdes_tbl = sm8150_usb3_uniphy_serdes_tbl,
  1726. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_serdes_tbl),
  1727. .tx_tbl = sdx65_usb3_uniphy_tx_tbl,
  1728. .tx_tbl_num = ARRAY_SIZE(sdx65_usb3_uniphy_tx_tbl),
  1729. .rx_tbl = sdx65_usb3_uniphy_rx_tbl,
  1730. .rx_tbl_num = ARRAY_SIZE(sdx65_usb3_uniphy_rx_tbl),
  1731. .pcs_tbl = sm8350_usb3_uniphy_pcs_tbl,
  1732. .pcs_tbl_num = ARRAY_SIZE(sm8350_usb3_uniphy_pcs_tbl),
  1733. .pcs_usb_tbl = sm8350_usb3_uniphy_pcs_usb_tbl,
  1734. .pcs_usb_tbl_num = ARRAY_SIZE(sm8350_usb3_uniphy_pcs_usb_tbl),
  1735. .clk_list = qmp_v4_sdx55_usbphy_clk_l,
  1736. .num_clks = ARRAY_SIZE(qmp_v4_sdx55_usbphy_clk_l),
  1737. .reset_list = msm8996_usb3phy_reset_l,
  1738. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1739. .vreg_list = qmp_phy_vreg_l,
  1740. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1741. .regs = qmp_v4_usb3phy_regs_layout,
  1742. .pcs_usb_offset = 0x1000,
  1743. .has_pwrdn_delay = true,
  1744. };
  1745. static const struct qmp_phy_cfg sm8350_usb3phy_cfg = {
  1746. .lanes = 2,
  1747. .serdes_tbl = sm8150_usb3_serdes_tbl,
  1748. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_serdes_tbl),
  1749. .tx_tbl = sm8350_usb3_tx_tbl,
  1750. .tx_tbl_num = ARRAY_SIZE(sm8350_usb3_tx_tbl),
  1751. .rx_tbl = sm8350_usb3_rx_tbl,
  1752. .rx_tbl_num = ARRAY_SIZE(sm8350_usb3_rx_tbl),
  1753. .pcs_tbl = sm8350_usb3_pcs_tbl,
  1754. .pcs_tbl_num = ARRAY_SIZE(sm8350_usb3_pcs_tbl),
  1755. .pcs_usb_tbl = sm8350_usb3_pcs_usb_tbl,
  1756. .pcs_usb_tbl_num = ARRAY_SIZE(sm8350_usb3_pcs_usb_tbl),
  1757. .clk_list = qmp_v4_sm8250_usbphy_clk_l,
  1758. .num_clks = ARRAY_SIZE(qmp_v4_sm8250_usbphy_clk_l),
  1759. .reset_list = msm8996_usb3phy_reset_l,
  1760. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1761. .vreg_list = qmp_phy_vreg_l,
  1762. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1763. .regs = qmp_v4_usb3phy_regs_layout,
  1764. .pcs_usb_offset = 0x300,
  1765. .has_pwrdn_delay = true,
  1766. .has_phy_dp_com_ctrl = true,
  1767. };
  1768. static const struct qmp_phy_cfg sm8350_usb3_uniphy_cfg = {
  1769. .lanes = 1,
  1770. .serdes_tbl = sm8150_usb3_uniphy_serdes_tbl,
  1771. .serdes_tbl_num = ARRAY_SIZE(sm8150_usb3_uniphy_serdes_tbl),
  1772. .tx_tbl = sm8350_usb3_uniphy_tx_tbl,
  1773. .tx_tbl_num = ARRAY_SIZE(sm8350_usb3_uniphy_tx_tbl),
  1774. .rx_tbl = sm8350_usb3_uniphy_rx_tbl,
  1775. .rx_tbl_num = ARRAY_SIZE(sm8350_usb3_uniphy_rx_tbl),
  1776. .pcs_tbl = sm8350_usb3_uniphy_pcs_tbl,
  1777. .pcs_tbl_num = ARRAY_SIZE(sm8350_usb3_uniphy_pcs_tbl),
  1778. .pcs_usb_tbl = sm8350_usb3_uniphy_pcs_usb_tbl,
  1779. .pcs_usb_tbl_num = ARRAY_SIZE(sm8350_usb3_uniphy_pcs_usb_tbl),
  1780. .clk_list = qmp_v4_phy_clk_l,
  1781. .num_clks = ARRAY_SIZE(qmp_v4_phy_clk_l),
  1782. .reset_list = msm8996_usb3phy_reset_l,
  1783. .num_resets = ARRAY_SIZE(msm8996_usb3phy_reset_l),
  1784. .vreg_list = qmp_phy_vreg_l,
  1785. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1786. .regs = qmp_v4_usb3phy_regs_layout,
  1787. .pcs_usb_offset = 0x1000,
  1788. .has_pwrdn_delay = true,
  1789. };
  1790. static const struct qmp_phy_cfg qcm2290_usb3phy_cfg = {
  1791. .lanes = 2,
  1792. .serdes_tbl = qcm2290_usb3_serdes_tbl,
  1793. .serdes_tbl_num = ARRAY_SIZE(qcm2290_usb3_serdes_tbl),
  1794. .tx_tbl = qcm2290_usb3_tx_tbl,
  1795. .tx_tbl_num = ARRAY_SIZE(qcm2290_usb3_tx_tbl),
  1796. .rx_tbl = qcm2290_usb3_rx_tbl,
  1797. .rx_tbl_num = ARRAY_SIZE(qcm2290_usb3_rx_tbl),
  1798. .pcs_tbl = qcm2290_usb3_pcs_tbl,
  1799. .pcs_tbl_num = ARRAY_SIZE(qcm2290_usb3_pcs_tbl),
  1800. .clk_list = qcm2290_usb3phy_clk_l,
  1801. .num_clks = ARRAY_SIZE(qcm2290_usb3phy_clk_l),
  1802. .reset_list = qcm2290_usb3phy_reset_l,
  1803. .num_resets = ARRAY_SIZE(qcm2290_usb3phy_reset_l),
  1804. .vreg_list = qmp_phy_vreg_l,
  1805. .num_vregs = ARRAY_SIZE(qmp_phy_vreg_l),
  1806. .regs = qcm2290_usb3phy_regs_layout,
  1807. };
  1808. static void qmp_usb_configure_lane(void __iomem *base,
  1809. const unsigned int *regs,
  1810. const struct qmp_phy_init_tbl tbl[],
  1811. int num,
  1812. u8 lane_mask)
  1813. {
  1814. int i;
  1815. const struct qmp_phy_init_tbl *t = tbl;
  1816. if (!t)
  1817. return;
  1818. for (i = 0; i < num; i++, t++) {
  1819. if (!(t->lane_mask & lane_mask))
  1820. continue;
  1821. if (t->in_layout)
  1822. writel(t->val, base + regs[t->offset]);
  1823. else
  1824. writel(t->val, base + t->offset);
  1825. }
  1826. }
  1827. static void qmp_usb_configure(void __iomem *base,
  1828. const unsigned int *regs,
  1829. const struct qmp_phy_init_tbl tbl[],
  1830. int num)
  1831. {
  1832. qmp_usb_configure_lane(base, regs, tbl, num, 0xff);
  1833. }
  1834. static int qmp_usb_serdes_init(struct qmp_phy *qphy)
  1835. {
  1836. const struct qmp_phy_cfg *cfg = qphy->cfg;
  1837. void __iomem *serdes = qphy->serdes;
  1838. const struct qmp_phy_init_tbl *serdes_tbl = cfg->serdes_tbl;
  1839. int serdes_tbl_num = cfg->serdes_tbl_num;
  1840. qmp_usb_configure(serdes, cfg->regs, serdes_tbl, serdes_tbl_num);
  1841. return 0;
  1842. }
  1843. static int qmp_usb_init(struct phy *phy)
  1844. {
  1845. struct qmp_phy *qphy = phy_get_drvdata(phy);
  1846. struct qcom_qmp *qmp = qphy->qmp;
  1847. const struct qmp_phy_cfg *cfg = qphy->cfg;
  1848. void __iomem *pcs = qphy->pcs;
  1849. void __iomem *dp_com = qmp->dp_com;
  1850. int ret;
  1851. /* turn on regulator supplies */
  1852. ret = regulator_bulk_enable(cfg->num_vregs, qmp->vregs);
  1853. if (ret) {
  1854. dev_err(qmp->dev, "failed to enable regulators, err=%d\n", ret);
  1855. return ret;
  1856. }
  1857. ret = reset_control_bulk_assert(cfg->num_resets, qmp->resets);
  1858. if (ret) {
  1859. dev_err(qmp->dev, "reset assert failed\n");
  1860. goto err_disable_regulators;
  1861. }
  1862. ret = reset_control_bulk_deassert(cfg->num_resets, qmp->resets);
  1863. if (ret) {
  1864. dev_err(qmp->dev, "reset deassert failed\n");
  1865. goto err_disable_regulators;
  1866. }
  1867. ret = clk_bulk_prepare_enable(cfg->num_clks, qmp->clks);
  1868. if (ret)
  1869. goto err_assert_reset;
  1870. if (cfg->has_phy_dp_com_ctrl) {
  1871. qphy_setbits(dp_com, QPHY_V3_DP_COM_POWER_DOWN_CTRL,
  1872. SW_PWRDN);
  1873. /* override hardware control for reset of qmp phy */
  1874. qphy_setbits(dp_com, QPHY_V3_DP_COM_RESET_OVRD_CTRL,
  1875. SW_DPPHY_RESET_MUX | SW_DPPHY_RESET |
  1876. SW_USB3PHY_RESET_MUX | SW_USB3PHY_RESET);
  1877. /* Default type-c orientation, i.e CC1 */
  1878. qphy_setbits(dp_com, QPHY_V3_DP_COM_TYPEC_CTRL, 0x02);
  1879. qphy_setbits(dp_com, QPHY_V3_DP_COM_PHY_MODE_CTRL,
  1880. USB3_MODE | DP_MODE);
  1881. /* bring both QMP USB and QMP DP PHYs PCS block out of reset */
  1882. qphy_clrbits(dp_com, QPHY_V3_DP_COM_RESET_OVRD_CTRL,
  1883. SW_DPPHY_RESET_MUX | SW_DPPHY_RESET |
  1884. SW_USB3PHY_RESET_MUX | SW_USB3PHY_RESET);
  1885. qphy_clrbits(dp_com, QPHY_V3_DP_COM_SWI_CTRL, 0x03);
  1886. qphy_clrbits(dp_com, QPHY_V3_DP_COM_SW_RESET, SW_RESET);
  1887. }
  1888. qphy_setbits(pcs, cfg->regs[QPHY_PCS_POWER_DOWN_CONTROL], SW_PWRDN);
  1889. return 0;
  1890. err_assert_reset:
  1891. reset_control_bulk_assert(cfg->num_resets, qmp->resets);
  1892. err_disable_regulators:
  1893. regulator_bulk_disable(cfg->num_vregs, qmp->vregs);
  1894. return ret;
  1895. }
  1896. static int qmp_usb_exit(struct phy *phy)
  1897. {
  1898. struct qmp_phy *qphy = phy_get_drvdata(phy);
  1899. struct qcom_qmp *qmp = qphy->qmp;
  1900. const struct qmp_phy_cfg *cfg = qphy->cfg;
  1901. reset_control_bulk_assert(cfg->num_resets, qmp->resets);
  1902. clk_bulk_disable_unprepare(cfg->num_clks, qmp->clks);
  1903. regulator_bulk_disable(cfg->num_vregs, qmp->vregs);
  1904. return 0;
  1905. }
  1906. static int qmp_usb_power_on(struct phy *phy)
  1907. {
  1908. struct qmp_phy *qphy = phy_get_drvdata(phy);
  1909. struct qcom_qmp *qmp = qphy->qmp;
  1910. const struct qmp_phy_cfg *cfg = qphy->cfg;
  1911. void __iomem *tx = qphy->tx;
  1912. void __iomem *rx = qphy->rx;
  1913. void __iomem *pcs = qphy->pcs;
  1914. void __iomem *status;
  1915. unsigned int val;
  1916. int ret;
  1917. qmp_usb_serdes_init(qphy);
  1918. ret = clk_prepare_enable(qphy->pipe_clk);
  1919. if (ret) {
  1920. dev_err(qmp->dev, "pipe_clk enable failed err=%d\n", ret);
  1921. return ret;
  1922. }
  1923. /* Tx, Rx, and PCS configurations */
  1924. qmp_usb_configure_lane(tx, cfg->regs, cfg->tx_tbl, cfg->tx_tbl_num, 1);
  1925. if (cfg->lanes >= 2) {
  1926. qmp_usb_configure_lane(qphy->tx2, cfg->regs,
  1927. cfg->tx_tbl, cfg->tx_tbl_num, 2);
  1928. }
  1929. qmp_usb_configure_lane(rx, cfg->regs, cfg->rx_tbl, cfg->rx_tbl_num, 1);
  1930. if (cfg->lanes >= 2) {
  1931. qmp_usb_configure_lane(qphy->rx2, cfg->regs,
  1932. cfg->rx_tbl, cfg->rx_tbl_num, 2);
  1933. }
  1934. /* Configure link rate, swing, etc. */
  1935. qmp_usb_configure(pcs, cfg->regs, cfg->pcs_tbl, cfg->pcs_tbl_num);
  1936. if (cfg->has_pwrdn_delay)
  1937. usleep_range(10, 20);
  1938. /* Pull PHY out of reset state */
  1939. qphy_clrbits(pcs, cfg->regs[QPHY_SW_RESET], SW_RESET);
  1940. /* start SerDes and Phy-Coding-Sublayer */
  1941. qphy_setbits(pcs, cfg->regs[QPHY_START_CTRL], SERDES_START | PCS_START);
  1942. status = pcs + cfg->regs[QPHY_PCS_STATUS];
  1943. ret = readl_poll_timeout(status, val, !(val & PHYSTATUS), 10,
  1944. PHY_INIT_COMPLETE_TIMEOUT);
  1945. if (ret) {
  1946. dev_err(qmp->dev, "phy initialization timed-out\n");
  1947. goto err_disable_pipe_clk;
  1948. }
  1949. return 0;
  1950. err_disable_pipe_clk:
  1951. clk_disable_unprepare(qphy->pipe_clk);
  1952. return ret;
  1953. }
  1954. static int qmp_usb_power_off(struct phy *phy)
  1955. {
  1956. struct qmp_phy *qphy = phy_get_drvdata(phy);
  1957. const struct qmp_phy_cfg *cfg = qphy->cfg;
  1958. clk_disable_unprepare(qphy->pipe_clk);
  1959. /* PHY reset */
  1960. qphy_setbits(qphy->pcs, cfg->regs[QPHY_SW_RESET], SW_RESET);
  1961. /* stop SerDes and Phy-Coding-Sublayer */
  1962. qphy_clrbits(qphy->pcs, cfg->regs[QPHY_START_CTRL],
  1963. SERDES_START | PCS_START);
  1964. /* Put PHY into POWER DOWN state: active low */
  1965. qphy_clrbits(qphy->pcs, cfg->regs[QPHY_PCS_POWER_DOWN_CONTROL],
  1966. SW_PWRDN);
  1967. return 0;
  1968. }
  1969. static int qmp_usb_enable(struct phy *phy)
  1970. {
  1971. int ret;
  1972. ret = qmp_usb_init(phy);
  1973. if (ret)
  1974. return ret;
  1975. ret = qmp_usb_power_on(phy);
  1976. if (ret)
  1977. qmp_usb_exit(phy);
  1978. return ret;
  1979. }
  1980. static int qmp_usb_disable(struct phy *phy)
  1981. {
  1982. int ret;
  1983. ret = qmp_usb_power_off(phy);
  1984. if (ret)
  1985. return ret;
  1986. return qmp_usb_exit(phy);
  1987. }
  1988. static int qmp_usb_set_mode(struct phy *phy, enum phy_mode mode, int submode)
  1989. {
  1990. struct qmp_phy *qphy = phy_get_drvdata(phy);
  1991. qphy->mode = mode;
  1992. return 0;
  1993. }
  1994. static void qmp_usb_enable_autonomous_mode(struct qmp_phy *qphy)
  1995. {
  1996. const struct qmp_phy_cfg *cfg = qphy->cfg;
  1997. void __iomem *pcs_usb = qphy->pcs_usb ?: qphy->pcs;
  1998. void __iomem *pcs_misc = qphy->pcs_misc;
  1999. u32 intr_mask;
  2000. if (qphy->mode == PHY_MODE_USB_HOST_SS ||
  2001. qphy->mode == PHY_MODE_USB_DEVICE_SS)
  2002. intr_mask = ARCVR_DTCT_EN | ALFPS_DTCT_EN;
  2003. else
  2004. intr_mask = ARCVR_DTCT_EN | ARCVR_DTCT_EVENT_SEL;
  2005. /* Clear any pending interrupts status */
  2006. qphy_setbits(pcs_usb, cfg->regs[QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR], IRQ_CLEAR);
  2007. /* Writing 1 followed by 0 clears the interrupt */
  2008. qphy_clrbits(pcs_usb, cfg->regs[QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR], IRQ_CLEAR);
  2009. qphy_clrbits(pcs_usb, cfg->regs[QPHY_PCS_AUTONOMOUS_MODE_CTRL],
  2010. ARCVR_DTCT_EN | ALFPS_DTCT_EN | ARCVR_DTCT_EVENT_SEL);
  2011. /* Enable required PHY autonomous mode interrupts */
  2012. qphy_setbits(pcs_usb, cfg->regs[QPHY_PCS_AUTONOMOUS_MODE_CTRL], intr_mask);
  2013. /* Enable i/o clamp_n for autonomous mode */
  2014. if (pcs_misc)
  2015. qphy_clrbits(pcs_misc, QPHY_V3_PCS_MISC_CLAMP_ENABLE, CLAMP_EN);
  2016. }
  2017. static void qmp_usb_disable_autonomous_mode(struct qmp_phy *qphy)
  2018. {
  2019. const struct qmp_phy_cfg *cfg = qphy->cfg;
  2020. void __iomem *pcs_usb = qphy->pcs_usb ?: qphy->pcs;
  2021. void __iomem *pcs_misc = qphy->pcs_misc;
  2022. /* Disable i/o clamp_n on resume for normal mode */
  2023. if (pcs_misc)
  2024. qphy_setbits(pcs_misc, QPHY_V3_PCS_MISC_CLAMP_ENABLE, CLAMP_EN);
  2025. qphy_clrbits(pcs_usb, cfg->regs[QPHY_PCS_AUTONOMOUS_MODE_CTRL],
  2026. ARCVR_DTCT_EN | ARCVR_DTCT_EVENT_SEL | ALFPS_DTCT_EN);
  2027. qphy_setbits(pcs_usb, cfg->regs[QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR], IRQ_CLEAR);
  2028. /* Writing 1 followed by 0 clears the interrupt */
  2029. qphy_clrbits(pcs_usb, cfg->regs[QPHY_PCS_LFPS_RXTERM_IRQ_CLEAR], IRQ_CLEAR);
  2030. }
  2031. static int __maybe_unused qmp_usb_runtime_suspend(struct device *dev)
  2032. {
  2033. struct qcom_qmp *qmp = dev_get_drvdata(dev);
  2034. struct qmp_phy *qphy = qmp->phys[0];
  2035. const struct qmp_phy_cfg *cfg = qphy->cfg;
  2036. dev_vdbg(dev, "Suspending QMP phy, mode:%d\n", qphy->mode);
  2037. if (!qphy->phy->init_count) {
  2038. dev_vdbg(dev, "PHY not initialized, bailing out\n");
  2039. return 0;
  2040. }
  2041. qmp_usb_enable_autonomous_mode(qphy);
  2042. clk_disable_unprepare(qphy->pipe_clk);
  2043. clk_bulk_disable_unprepare(cfg->num_clks, qmp->clks);
  2044. return 0;
  2045. }
  2046. static int __maybe_unused qmp_usb_runtime_resume(struct device *dev)
  2047. {
  2048. struct qcom_qmp *qmp = dev_get_drvdata(dev);
  2049. struct qmp_phy *qphy = qmp->phys[0];
  2050. const struct qmp_phy_cfg *cfg = qphy->cfg;
  2051. int ret = 0;
  2052. dev_vdbg(dev, "Resuming QMP phy, mode:%d\n", qphy->mode);
  2053. if (!qphy->phy->init_count) {
  2054. dev_vdbg(dev, "PHY not initialized, bailing out\n");
  2055. return 0;
  2056. }
  2057. ret = clk_bulk_prepare_enable(cfg->num_clks, qmp->clks);
  2058. if (ret)
  2059. return ret;
  2060. ret = clk_prepare_enable(qphy->pipe_clk);
  2061. if (ret) {
  2062. dev_err(dev, "pipe_clk enable failed, err=%d\n", ret);
  2063. clk_bulk_disable_unprepare(cfg->num_clks, qmp->clks);
  2064. return ret;
  2065. }
  2066. qmp_usb_disable_autonomous_mode(qphy);
  2067. return 0;
  2068. }
  2069. static int qmp_usb_vreg_init(struct device *dev, const struct qmp_phy_cfg *cfg)
  2070. {
  2071. struct qcom_qmp *qmp = dev_get_drvdata(dev);
  2072. int num = cfg->num_vregs;
  2073. int i;
  2074. qmp->vregs = devm_kcalloc(dev, num, sizeof(*qmp->vregs), GFP_KERNEL);
  2075. if (!qmp->vregs)
  2076. return -ENOMEM;
  2077. for (i = 0; i < num; i++)
  2078. qmp->vregs[i].supply = cfg->vreg_list[i];
  2079. return devm_regulator_bulk_get(dev, num, qmp->vregs);
  2080. }
  2081. static int qmp_usb_reset_init(struct device *dev, const struct qmp_phy_cfg *cfg)
  2082. {
  2083. struct qcom_qmp *qmp = dev_get_drvdata(dev);
  2084. int i;
  2085. int ret;
  2086. qmp->resets = devm_kcalloc(dev, cfg->num_resets,
  2087. sizeof(*qmp->resets), GFP_KERNEL);
  2088. if (!qmp->resets)
  2089. return -ENOMEM;
  2090. for (i = 0; i < cfg->num_resets; i++)
  2091. qmp->resets[i].id = cfg->reset_list[i];
  2092. ret = devm_reset_control_bulk_get_exclusive(dev, cfg->num_resets, qmp->resets);
  2093. if (ret)
  2094. return dev_err_probe(dev, ret, "failed to get resets\n");
  2095. return 0;
  2096. }
  2097. static int qmp_usb_clk_init(struct device *dev, const struct qmp_phy_cfg *cfg)
  2098. {
  2099. struct qcom_qmp *qmp = dev_get_drvdata(dev);
  2100. int num = cfg->num_clks;
  2101. int i;
  2102. qmp->clks = devm_kcalloc(dev, num, sizeof(*qmp->clks), GFP_KERNEL);
  2103. if (!qmp->clks)
  2104. return -ENOMEM;
  2105. for (i = 0; i < num; i++)
  2106. qmp->clks[i].id = cfg->clk_list[i];
  2107. return devm_clk_bulk_get(dev, num, qmp->clks);
  2108. }
  2109. static void phy_clk_release_provider(void *res)
  2110. {
  2111. of_clk_del_provider(res);
  2112. }
  2113. /*
  2114. * Register a fixed rate pipe clock.
  2115. *
  2116. * The <s>_pipe_clksrc generated by PHY goes to the GCC that gate
  2117. * controls it. The <s>_pipe_clk coming out of the GCC is requested
  2118. * by the PHY driver for its operations.
  2119. * We register the <s>_pipe_clksrc here. The gcc driver takes care
  2120. * of assigning this <s>_pipe_clksrc as parent to <s>_pipe_clk.
  2121. * Below picture shows this relationship.
  2122. *
  2123. * +---------------+
  2124. * | PHY block |<<---------------------------------------+
  2125. * | | |
  2126. * | +-------+ | +-----+ |
  2127. * I/P---^-->| PLL |---^--->pipe_clksrc--->| GCC |--->pipe_clk---+
  2128. * clk | +-------+ | +-----+
  2129. * +---------------+
  2130. */
  2131. static int phy_pipe_clk_register(struct qcom_qmp *qmp, struct device_node *np)
  2132. {
  2133. struct clk_fixed_rate *fixed;
  2134. struct clk_init_data init = { };
  2135. int ret;
  2136. ret = of_property_read_string(np, "clock-output-names", &init.name);
  2137. if (ret) {
  2138. dev_err(qmp->dev, "%pOFn: No clock-output-names\n", np);
  2139. return ret;
  2140. }
  2141. fixed = devm_kzalloc(qmp->dev, sizeof(*fixed), GFP_KERNEL);
  2142. if (!fixed)
  2143. return -ENOMEM;
  2144. init.ops = &clk_fixed_rate_ops;
  2145. /* controllers using QMP phys use 125MHz pipe clock interface */
  2146. fixed->fixed_rate = 125000000;
  2147. fixed->hw.init = &init;
  2148. ret = devm_clk_hw_register(qmp->dev, &fixed->hw);
  2149. if (ret)
  2150. return ret;
  2151. ret = of_clk_add_hw_provider(np, of_clk_hw_simple_get, &fixed->hw);
  2152. if (ret)
  2153. return ret;
  2154. /*
  2155. * Roll a devm action because the clock provider is the child node, but
  2156. * the child node is not actually a device.
  2157. */
  2158. return devm_add_action_or_reset(qmp->dev, phy_clk_release_provider, np);
  2159. }
  2160. static const struct phy_ops qmp_usb_ops = {
  2161. .init = qmp_usb_enable,
  2162. .exit = qmp_usb_disable,
  2163. .set_mode = qmp_usb_set_mode,
  2164. .owner = THIS_MODULE,
  2165. };
  2166. static void __iomem *qmp_usb_iomap(struct device *dev, struct device_node *np,
  2167. int index, bool exclusive)
  2168. {
  2169. struct resource res;
  2170. if (!exclusive) {
  2171. if (of_address_to_resource(np, index, &res))
  2172. return IOMEM_ERR_PTR(-EINVAL);
  2173. return devm_ioremap(dev, res.start, resource_size(&res));
  2174. }
  2175. return devm_of_iomap(dev, np, index, NULL);
  2176. }
  2177. static
  2178. int qmp_usb_create(struct device *dev, struct device_node *np, int id,
  2179. void __iomem *serdes, const struct qmp_phy_cfg *cfg)
  2180. {
  2181. struct qcom_qmp *qmp = dev_get_drvdata(dev);
  2182. struct phy *generic_phy;
  2183. struct qmp_phy *qphy;
  2184. bool exclusive = true;
  2185. int ret;
  2186. /*
  2187. * FIXME: These bindings should be fixed to not rely on overlapping
  2188. * mappings for PCS.
  2189. */
  2190. if (of_device_is_compatible(dev->of_node, "qcom,sdx65-qmp-usb3-uni-phy"))
  2191. exclusive = false;
  2192. if (of_device_is_compatible(dev->of_node, "qcom,sm8350-qmp-usb3-uni-phy"))
  2193. exclusive = false;
  2194. qphy = devm_kzalloc(dev, sizeof(*qphy), GFP_KERNEL);
  2195. if (!qphy)
  2196. return -ENOMEM;
  2197. qphy->cfg = cfg;
  2198. qphy->serdes = serdes;
  2199. /*
  2200. * Get memory resources for each phy lane:
  2201. * Resources are indexed as: tx -> 0; rx -> 1; pcs -> 2.
  2202. * For dual lane PHYs: tx2 -> 3, rx2 -> 4, pcs_misc (optional) -> 5
  2203. * For single lane PHYs: pcs_misc (optional) -> 3.
  2204. */
  2205. qphy->tx = devm_of_iomap(dev, np, 0, NULL);
  2206. if (IS_ERR(qphy->tx))
  2207. return PTR_ERR(qphy->tx);
  2208. qphy->rx = devm_of_iomap(dev, np, 1, NULL);
  2209. if (IS_ERR(qphy->rx))
  2210. return PTR_ERR(qphy->rx);
  2211. qphy->pcs = qmp_usb_iomap(dev, np, 2, exclusive);
  2212. if (IS_ERR(qphy->pcs))
  2213. return PTR_ERR(qphy->pcs);
  2214. if (cfg->pcs_usb_offset)
  2215. qphy->pcs_usb = qphy->pcs + cfg->pcs_usb_offset;
  2216. if (cfg->lanes >= 2) {
  2217. qphy->tx2 = devm_of_iomap(dev, np, 3, NULL);
  2218. if (IS_ERR(qphy->tx2))
  2219. return PTR_ERR(qphy->tx2);
  2220. qphy->rx2 = devm_of_iomap(dev, np, 4, NULL);
  2221. if (IS_ERR(qphy->rx2))
  2222. return PTR_ERR(qphy->rx2);
  2223. qphy->pcs_misc = devm_of_iomap(dev, np, 5, NULL);
  2224. } else {
  2225. qphy->pcs_misc = devm_of_iomap(dev, np, 3, NULL);
  2226. }
  2227. if (IS_ERR(qphy->pcs_misc)) {
  2228. dev_vdbg(dev, "PHY pcs_misc-reg not used\n");
  2229. qphy->pcs_misc = NULL;
  2230. }
  2231. qphy->pipe_clk = devm_get_clk_from_child(dev, np, NULL);
  2232. if (IS_ERR(qphy->pipe_clk)) {
  2233. return dev_err_probe(dev, PTR_ERR(qphy->pipe_clk),
  2234. "failed to get lane%d pipe clock\n", id);
  2235. }
  2236. generic_phy = devm_phy_create(dev, np, &qmp_usb_ops);
  2237. if (IS_ERR(generic_phy)) {
  2238. ret = PTR_ERR(generic_phy);
  2239. dev_err(dev, "failed to create qphy %d\n", ret);
  2240. return ret;
  2241. }
  2242. qphy->phy = generic_phy;
  2243. qphy->qmp = qmp;
  2244. qmp->phys[id] = qphy;
  2245. phy_set_drvdata(generic_phy, qphy);
  2246. return 0;
  2247. }
  2248. static const struct of_device_id qmp_usb_of_match_table[] = {
  2249. {
  2250. .compatible = "qcom,ipq8074-qmp-usb3-phy",
  2251. .data = &ipq8074_usb3phy_cfg,
  2252. }, {
  2253. .compatible = "qcom,msm8996-qmp-usb3-phy",
  2254. .data = &msm8996_usb3phy_cfg,
  2255. }, {
  2256. .compatible = "qcom,ipq6018-qmp-usb3-phy",
  2257. .data = &ipq8074_usb3phy_cfg,
  2258. }, {
  2259. .compatible = "qcom,sc7180-qmp-usb3-phy",
  2260. .data = &sc7180_usb3phy_cfg,
  2261. }, {
  2262. .compatible = "qcom,sc8180x-qmp-usb3-phy",
  2263. .data = &sm8150_usb3phy_cfg,
  2264. }, {
  2265. .compatible = "qcom,sc8280xp-qmp-usb3-uni-phy",
  2266. .data = &sc8280xp_usb3_uniphy_cfg,
  2267. }, {
  2268. .compatible = "qcom,sdm845-qmp-usb3-phy",
  2269. .data = &qmp_v3_usb3phy_cfg,
  2270. }, {
  2271. .compatible = "qcom,sdm845-qmp-usb3-uni-phy",
  2272. .data = &qmp_v3_usb3_uniphy_cfg,
  2273. }, {
  2274. .compatible = "qcom,msm8998-qmp-usb3-phy",
  2275. .data = &msm8998_usb3phy_cfg,
  2276. }, {
  2277. .compatible = "qcom,sm8150-qmp-usb3-phy",
  2278. .data = &sm8150_usb3phy_cfg,
  2279. }, {
  2280. .compatible = "qcom,sm8150-qmp-usb3-uni-phy",
  2281. .data = &sm8150_usb3_uniphy_cfg,
  2282. }, {
  2283. .compatible = "qcom,sm8250-qmp-usb3-phy",
  2284. .data = &sm8250_usb3phy_cfg,
  2285. }, {
  2286. .compatible = "qcom,sm8250-qmp-usb3-uni-phy",
  2287. .data = &sm8250_usb3_uniphy_cfg,
  2288. }, {
  2289. .compatible = "qcom,sdx55-qmp-usb3-uni-phy",
  2290. .data = &sdx55_usb3_uniphy_cfg,
  2291. }, {
  2292. .compatible = "qcom,sdx65-qmp-usb3-uni-phy",
  2293. .data = &sdx65_usb3_uniphy_cfg,
  2294. }, {
  2295. .compatible = "qcom,sm8350-qmp-usb3-phy",
  2296. .data = &sm8350_usb3phy_cfg,
  2297. }, {
  2298. .compatible = "qcom,sm8350-qmp-usb3-uni-phy",
  2299. .data = &sm8350_usb3_uniphy_cfg,
  2300. }, {
  2301. .compatible = "qcom,sm8450-qmp-usb3-phy",
  2302. .data = &sm8350_usb3phy_cfg,
  2303. }, {
  2304. .compatible = "qcom,qcm2290-qmp-usb3-phy",
  2305. .data = &qcm2290_usb3phy_cfg,
  2306. },
  2307. { },
  2308. };
  2309. MODULE_DEVICE_TABLE(of, qmp_usb_of_match_table);
  2310. static const struct dev_pm_ops qmp_usb_pm_ops = {
  2311. SET_RUNTIME_PM_OPS(qmp_usb_runtime_suspend,
  2312. qmp_usb_runtime_resume, NULL)
  2313. };
  2314. static int qmp_usb_probe(struct platform_device *pdev)
  2315. {
  2316. struct qcom_qmp *qmp;
  2317. struct device *dev = &pdev->dev;
  2318. struct device_node *child;
  2319. struct phy_provider *phy_provider;
  2320. void __iomem *serdes;
  2321. const struct qmp_phy_cfg *cfg = NULL;
  2322. int num, id;
  2323. int ret;
  2324. qmp = devm_kzalloc(dev, sizeof(*qmp), GFP_KERNEL);
  2325. if (!qmp)
  2326. return -ENOMEM;
  2327. qmp->dev = dev;
  2328. dev_set_drvdata(dev, qmp);
  2329. /* Get the specific init parameters of QMP phy */
  2330. cfg = of_device_get_match_data(dev);
  2331. if (!cfg)
  2332. return -EINVAL;
  2333. /* per PHY serdes; usually located at base address */
  2334. serdes = devm_platform_ioremap_resource(pdev, 0);
  2335. if (IS_ERR(serdes))
  2336. return PTR_ERR(serdes);
  2337. /* per PHY dp_com; if PHY has dp_com control block */
  2338. if (cfg->has_phy_dp_com_ctrl) {
  2339. qmp->dp_com = devm_platform_ioremap_resource(pdev, 1);
  2340. if (IS_ERR(qmp->dp_com))
  2341. return PTR_ERR(qmp->dp_com);
  2342. }
  2343. ret = qmp_usb_clk_init(dev, cfg);
  2344. if (ret)
  2345. return ret;
  2346. ret = qmp_usb_reset_init(dev, cfg);
  2347. if (ret)
  2348. return ret;
  2349. ret = qmp_usb_vreg_init(dev, cfg);
  2350. if (ret)
  2351. return dev_err_probe(dev, ret,
  2352. "failed to get regulator supplies\n");
  2353. num = of_get_available_child_count(dev->of_node);
  2354. /* do we have a rogue child node ? */
  2355. if (num > 1)
  2356. return -EINVAL;
  2357. qmp->phys = devm_kcalloc(dev, num, sizeof(*qmp->phys), GFP_KERNEL);
  2358. if (!qmp->phys)
  2359. return -ENOMEM;
  2360. pm_runtime_set_active(dev);
  2361. ret = devm_pm_runtime_enable(dev);
  2362. if (ret)
  2363. return ret;
  2364. /*
  2365. * Prevent runtime pm from being ON by default. Users can enable
  2366. * it using power/control in sysfs.
  2367. */
  2368. pm_runtime_forbid(dev);
  2369. id = 0;
  2370. for_each_available_child_of_node(dev->of_node, child) {
  2371. /* Create per-lane phy */
  2372. ret = qmp_usb_create(dev, child, id, serdes, cfg);
  2373. if (ret) {
  2374. dev_err(dev, "failed to create lane%d phy, %d\n",
  2375. id, ret);
  2376. goto err_node_put;
  2377. }
  2378. /*
  2379. * Register the pipe clock provided by phy.
  2380. * See function description to see details of this pipe clock.
  2381. */
  2382. ret = phy_pipe_clk_register(qmp, child);
  2383. if (ret) {
  2384. dev_err(qmp->dev,
  2385. "failed to register pipe clock source\n");
  2386. goto err_node_put;
  2387. }
  2388. id++;
  2389. }
  2390. phy_provider = devm_of_phy_provider_register(dev, of_phy_simple_xlate);
  2391. return PTR_ERR_OR_ZERO(phy_provider);
  2392. err_node_put:
  2393. of_node_put(child);
  2394. return ret;
  2395. }
  2396. static struct platform_driver qmp_usb_driver = {
  2397. .probe = qmp_usb_probe,
  2398. .driver = {
  2399. .name = "qcom-qmp-usb-phy",
  2400. .pm = &qmp_usb_pm_ops,
  2401. .of_match_table = qmp_usb_of_match_table,
  2402. },
  2403. };
  2404. module_platform_driver(qmp_usb_driver);
  2405. MODULE_AUTHOR("Vivek Gautam <[email protected]>");
  2406. MODULE_DESCRIPTION("Qualcomm QMP USB PHY driver");
  2407. MODULE_LICENSE("GPL v2");