hdmi.c 56 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) 2012 Avionic Design GmbH
  4. * Copyright (C) 2012 NVIDIA CORPORATION. All rights reserved.
  5. */
  6. #include <linux/clk.h>
  7. #include <linux/debugfs.h>
  8. #include <linux/delay.h>
  9. #include <linux/hdmi.h>
  10. #include <linux/math64.h>
  11. #include <linux/module.h>
  12. #include <linux/of.h>
  13. #include <linux/platform_device.h>
  14. #include <linux/pm_opp.h>
  15. #include <linux/pm_runtime.h>
  16. #include <linux/regulator/consumer.h>
  17. #include <linux/reset.h>
  18. #include <soc/tegra/common.h>
  19. #include <sound/hdmi-codec.h>
  20. #include <drm/drm_bridge_connector.h>
  21. #include <drm/drm_atomic_helper.h>
  22. #include <drm/drm_crtc.h>
  23. #include <drm/drm_debugfs.h>
  24. #include <drm/drm_edid.h>
  25. #include <drm/drm_eld.h>
  26. #include <drm/drm_file.h>
  27. #include <drm/drm_fourcc.h>
  28. #include <drm/drm_print.h>
  29. #include <drm/drm_probe_helper.h>
  30. #include <drm/drm_simple_kms_helper.h>
  31. #include "hda.h"
  32. #include "hdmi.h"
  33. #include "drm.h"
  34. #include "dc.h"
  35. #include "trace.h"
  36. #define HDMI_ELD_BUFFER_SIZE 96
  37. struct tmds_config {
  38. unsigned int pclk;
  39. u32 pll0;
  40. u32 pll1;
  41. u32 pe_current;
  42. u32 drive_current;
  43. u32 peak_current;
  44. };
  45. struct tegra_hdmi_config {
  46. const struct tmds_config *tmds;
  47. unsigned int num_tmds;
  48. unsigned long fuse_override_offset;
  49. u32 fuse_override_value;
  50. bool has_sor_io_peak_current;
  51. bool has_hda;
  52. bool has_hbr;
  53. };
  54. struct tegra_hdmi {
  55. struct host1x_client client;
  56. struct tegra_output output;
  57. struct device *dev;
  58. struct regulator *hdmi;
  59. struct regulator *pll;
  60. struct regulator *vdd;
  61. void __iomem *regs;
  62. unsigned int irq;
  63. struct clk *clk_parent;
  64. struct clk *clk;
  65. struct reset_control *rst;
  66. const struct tegra_hdmi_config *config;
  67. unsigned int audio_source;
  68. struct tegra_hda_format format;
  69. unsigned int pixel_clock;
  70. bool stereo;
  71. bool dvi;
  72. struct drm_info_list *debugfs_files;
  73. struct platform_device *audio_pdev;
  74. struct mutex audio_lock;
  75. };
  76. static inline struct tegra_hdmi *
  77. host1x_client_to_hdmi(struct host1x_client *client)
  78. {
  79. return container_of(client, struct tegra_hdmi, client);
  80. }
  81. static inline struct tegra_hdmi *to_hdmi(struct tegra_output *output)
  82. {
  83. return container_of(output, struct tegra_hdmi, output);
  84. }
  85. #define HDMI_AUDIOCLK_FREQ 216000000
  86. #define HDMI_REKEY_DEFAULT 56
  87. enum {
  88. AUTO = 0,
  89. SPDIF,
  90. HDA,
  91. };
  92. static inline u32 tegra_hdmi_readl(struct tegra_hdmi *hdmi,
  93. unsigned int offset)
  94. {
  95. u32 value = readl(hdmi->regs + (offset << 2));
  96. trace_hdmi_readl(hdmi->dev, offset, value);
  97. return value;
  98. }
  99. static inline void tegra_hdmi_writel(struct tegra_hdmi *hdmi, u32 value,
  100. unsigned int offset)
  101. {
  102. trace_hdmi_writel(hdmi->dev, offset, value);
  103. writel(value, hdmi->regs + (offset << 2));
  104. }
  105. struct tegra_hdmi_audio_config {
  106. unsigned int n;
  107. unsigned int cts;
  108. unsigned int aval;
  109. };
  110. static const struct tmds_config tegra20_tmds_config[] = {
  111. { /* slow pixel clock modes */
  112. .pclk = 27000000,
  113. .pll0 = SOR_PLL_BG_V17_S(3) | SOR_PLL_ICHPMP(1) |
  114. SOR_PLL_RESISTORSEL | SOR_PLL_VCOCAP(0) |
  115. SOR_PLL_TX_REG_LOAD(3),
  116. .pll1 = SOR_PLL_TMDS_TERM_ENABLE,
  117. .pe_current = PE_CURRENT0(PE_CURRENT_0_0_mA) |
  118. PE_CURRENT1(PE_CURRENT_0_0_mA) |
  119. PE_CURRENT2(PE_CURRENT_0_0_mA) |
  120. PE_CURRENT3(PE_CURRENT_0_0_mA),
  121. .drive_current = DRIVE_CURRENT_LANE0(DRIVE_CURRENT_7_125_mA) |
  122. DRIVE_CURRENT_LANE1(DRIVE_CURRENT_7_125_mA) |
  123. DRIVE_CURRENT_LANE2(DRIVE_CURRENT_7_125_mA) |
  124. DRIVE_CURRENT_LANE3(DRIVE_CURRENT_7_125_mA),
  125. },
  126. { /* high pixel clock modes */
  127. .pclk = UINT_MAX,
  128. .pll0 = SOR_PLL_BG_V17_S(3) | SOR_PLL_ICHPMP(1) |
  129. SOR_PLL_RESISTORSEL | SOR_PLL_VCOCAP(1) |
  130. SOR_PLL_TX_REG_LOAD(3),
  131. .pll1 = SOR_PLL_TMDS_TERM_ENABLE | SOR_PLL_PE_EN,
  132. .pe_current = PE_CURRENT0(PE_CURRENT_6_0_mA) |
  133. PE_CURRENT1(PE_CURRENT_6_0_mA) |
  134. PE_CURRENT2(PE_CURRENT_6_0_mA) |
  135. PE_CURRENT3(PE_CURRENT_6_0_mA),
  136. .drive_current = DRIVE_CURRENT_LANE0(DRIVE_CURRENT_7_125_mA) |
  137. DRIVE_CURRENT_LANE1(DRIVE_CURRENT_7_125_mA) |
  138. DRIVE_CURRENT_LANE2(DRIVE_CURRENT_7_125_mA) |
  139. DRIVE_CURRENT_LANE3(DRIVE_CURRENT_7_125_mA),
  140. },
  141. };
  142. static const struct tmds_config tegra30_tmds_config[] = {
  143. { /* 480p modes */
  144. .pclk = 27000000,
  145. .pll0 = SOR_PLL_BG_V17_S(3) | SOR_PLL_ICHPMP(1) |
  146. SOR_PLL_RESISTORSEL | SOR_PLL_VCOCAP(0) |
  147. SOR_PLL_TX_REG_LOAD(0),
  148. .pll1 = SOR_PLL_TMDS_TERM_ENABLE,
  149. .pe_current = PE_CURRENT0(PE_CURRENT_0_0_mA) |
  150. PE_CURRENT1(PE_CURRENT_0_0_mA) |
  151. PE_CURRENT2(PE_CURRENT_0_0_mA) |
  152. PE_CURRENT3(PE_CURRENT_0_0_mA),
  153. .drive_current = DRIVE_CURRENT_LANE0(DRIVE_CURRENT_5_250_mA) |
  154. DRIVE_CURRENT_LANE1(DRIVE_CURRENT_5_250_mA) |
  155. DRIVE_CURRENT_LANE2(DRIVE_CURRENT_5_250_mA) |
  156. DRIVE_CURRENT_LANE3(DRIVE_CURRENT_5_250_mA),
  157. }, { /* 720p modes */
  158. .pclk = 74250000,
  159. .pll0 = SOR_PLL_BG_V17_S(3) | SOR_PLL_ICHPMP(1) |
  160. SOR_PLL_RESISTORSEL | SOR_PLL_VCOCAP(1) |
  161. SOR_PLL_TX_REG_LOAD(0),
  162. .pll1 = SOR_PLL_TMDS_TERM_ENABLE | SOR_PLL_PE_EN,
  163. .pe_current = PE_CURRENT0(PE_CURRENT_5_0_mA) |
  164. PE_CURRENT1(PE_CURRENT_5_0_mA) |
  165. PE_CURRENT2(PE_CURRENT_5_0_mA) |
  166. PE_CURRENT3(PE_CURRENT_5_0_mA),
  167. .drive_current = DRIVE_CURRENT_LANE0(DRIVE_CURRENT_5_250_mA) |
  168. DRIVE_CURRENT_LANE1(DRIVE_CURRENT_5_250_mA) |
  169. DRIVE_CURRENT_LANE2(DRIVE_CURRENT_5_250_mA) |
  170. DRIVE_CURRENT_LANE3(DRIVE_CURRENT_5_250_mA),
  171. }, { /* 1080p modes */
  172. .pclk = UINT_MAX,
  173. .pll0 = SOR_PLL_BG_V17_S(3) | SOR_PLL_ICHPMP(1) |
  174. SOR_PLL_RESISTORSEL | SOR_PLL_VCOCAP(3) |
  175. SOR_PLL_TX_REG_LOAD(0),
  176. .pll1 = SOR_PLL_TMDS_TERM_ENABLE | SOR_PLL_PE_EN,
  177. .pe_current = PE_CURRENT0(PE_CURRENT_5_0_mA) |
  178. PE_CURRENT1(PE_CURRENT_5_0_mA) |
  179. PE_CURRENT2(PE_CURRENT_5_0_mA) |
  180. PE_CURRENT3(PE_CURRENT_5_0_mA),
  181. .drive_current = DRIVE_CURRENT_LANE0(DRIVE_CURRENT_5_250_mA) |
  182. DRIVE_CURRENT_LANE1(DRIVE_CURRENT_5_250_mA) |
  183. DRIVE_CURRENT_LANE2(DRIVE_CURRENT_5_250_mA) |
  184. DRIVE_CURRENT_LANE3(DRIVE_CURRENT_5_250_mA),
  185. },
  186. };
  187. static const struct tmds_config tegra114_tmds_config[] = {
  188. { /* 480p/576p / 25.2MHz/27MHz modes */
  189. .pclk = 27000000,
  190. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  191. SOR_PLL_VCOCAP(0) | SOR_PLL_RESISTORSEL,
  192. .pll1 = SOR_PLL_LOADADJ(3) | SOR_PLL_TMDS_TERMADJ(0),
  193. .pe_current = PE_CURRENT0(PE_CURRENT_0_mA_T114) |
  194. PE_CURRENT1(PE_CURRENT_0_mA_T114) |
  195. PE_CURRENT2(PE_CURRENT_0_mA_T114) |
  196. PE_CURRENT3(PE_CURRENT_0_mA_T114),
  197. .drive_current =
  198. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_10_400_mA_T114) |
  199. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_10_400_mA_T114) |
  200. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_10_400_mA_T114) |
  201. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_10_400_mA_T114),
  202. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_0_000_mA) |
  203. PEAK_CURRENT_LANE1(PEAK_CURRENT_0_000_mA) |
  204. PEAK_CURRENT_LANE2(PEAK_CURRENT_0_000_mA) |
  205. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_000_mA),
  206. }, { /* 720p / 74.25MHz modes */
  207. .pclk = 74250000,
  208. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  209. SOR_PLL_VCOCAP(1) | SOR_PLL_RESISTORSEL,
  210. .pll1 = SOR_PLL_PE_EN | SOR_PLL_LOADADJ(3) |
  211. SOR_PLL_TMDS_TERMADJ(0),
  212. .pe_current = PE_CURRENT0(PE_CURRENT_15_mA_T114) |
  213. PE_CURRENT1(PE_CURRENT_15_mA_T114) |
  214. PE_CURRENT2(PE_CURRENT_15_mA_T114) |
  215. PE_CURRENT3(PE_CURRENT_15_mA_T114),
  216. .drive_current =
  217. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_10_400_mA_T114) |
  218. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_10_400_mA_T114) |
  219. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_10_400_mA_T114) |
  220. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_10_400_mA_T114),
  221. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_0_000_mA) |
  222. PEAK_CURRENT_LANE1(PEAK_CURRENT_0_000_mA) |
  223. PEAK_CURRENT_LANE2(PEAK_CURRENT_0_000_mA) |
  224. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_000_mA),
  225. }, { /* 1080p / 148.5MHz modes */
  226. .pclk = 148500000,
  227. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  228. SOR_PLL_VCOCAP(3) | SOR_PLL_RESISTORSEL,
  229. .pll1 = SOR_PLL_PE_EN | SOR_PLL_LOADADJ(3) |
  230. SOR_PLL_TMDS_TERMADJ(0),
  231. .pe_current = PE_CURRENT0(PE_CURRENT_10_mA_T114) |
  232. PE_CURRENT1(PE_CURRENT_10_mA_T114) |
  233. PE_CURRENT2(PE_CURRENT_10_mA_T114) |
  234. PE_CURRENT3(PE_CURRENT_10_mA_T114),
  235. .drive_current =
  236. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_12_400_mA_T114) |
  237. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_12_400_mA_T114) |
  238. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_12_400_mA_T114) |
  239. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_12_400_mA_T114),
  240. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_0_000_mA) |
  241. PEAK_CURRENT_LANE1(PEAK_CURRENT_0_000_mA) |
  242. PEAK_CURRENT_LANE2(PEAK_CURRENT_0_000_mA) |
  243. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_000_mA),
  244. }, { /* 225/297MHz modes */
  245. .pclk = UINT_MAX,
  246. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  247. SOR_PLL_VCOCAP(0xf) | SOR_PLL_RESISTORSEL,
  248. .pll1 = SOR_PLL_LOADADJ(3) | SOR_PLL_TMDS_TERMADJ(7)
  249. | SOR_PLL_TMDS_TERM_ENABLE,
  250. .pe_current = PE_CURRENT0(PE_CURRENT_0_mA_T114) |
  251. PE_CURRENT1(PE_CURRENT_0_mA_T114) |
  252. PE_CURRENT2(PE_CURRENT_0_mA_T114) |
  253. PE_CURRENT3(PE_CURRENT_0_mA_T114),
  254. .drive_current =
  255. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_25_200_mA_T114) |
  256. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_25_200_mA_T114) |
  257. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_25_200_mA_T114) |
  258. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_19_200_mA_T114),
  259. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_3_000_mA) |
  260. PEAK_CURRENT_LANE1(PEAK_CURRENT_3_000_mA) |
  261. PEAK_CURRENT_LANE2(PEAK_CURRENT_3_000_mA) |
  262. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_800_mA),
  263. },
  264. };
  265. static const struct tmds_config tegra124_tmds_config[] = {
  266. { /* 480p/576p / 25.2MHz/27MHz modes */
  267. .pclk = 27000000,
  268. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  269. SOR_PLL_VCOCAP(0) | SOR_PLL_RESISTORSEL,
  270. .pll1 = SOR_PLL_LOADADJ(3) | SOR_PLL_TMDS_TERMADJ(0),
  271. .pe_current = PE_CURRENT0(PE_CURRENT_0_mA_T114) |
  272. PE_CURRENT1(PE_CURRENT_0_mA_T114) |
  273. PE_CURRENT2(PE_CURRENT_0_mA_T114) |
  274. PE_CURRENT3(PE_CURRENT_0_mA_T114),
  275. .drive_current =
  276. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_10_400_mA_T114) |
  277. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_10_400_mA_T114) |
  278. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_10_400_mA_T114) |
  279. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_10_400_mA_T114),
  280. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_0_000_mA) |
  281. PEAK_CURRENT_LANE1(PEAK_CURRENT_0_000_mA) |
  282. PEAK_CURRENT_LANE2(PEAK_CURRENT_0_000_mA) |
  283. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_000_mA),
  284. }, { /* 720p / 74.25MHz modes */
  285. .pclk = 74250000,
  286. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  287. SOR_PLL_VCOCAP(1) | SOR_PLL_RESISTORSEL,
  288. .pll1 = SOR_PLL_PE_EN | SOR_PLL_LOADADJ(3) |
  289. SOR_PLL_TMDS_TERMADJ(0),
  290. .pe_current = PE_CURRENT0(PE_CURRENT_15_mA_T114) |
  291. PE_CURRENT1(PE_CURRENT_15_mA_T114) |
  292. PE_CURRENT2(PE_CURRENT_15_mA_T114) |
  293. PE_CURRENT3(PE_CURRENT_15_mA_T114),
  294. .drive_current =
  295. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_10_400_mA_T114) |
  296. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_10_400_mA_T114) |
  297. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_10_400_mA_T114) |
  298. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_10_400_mA_T114),
  299. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_0_000_mA) |
  300. PEAK_CURRENT_LANE1(PEAK_CURRENT_0_000_mA) |
  301. PEAK_CURRENT_LANE2(PEAK_CURRENT_0_000_mA) |
  302. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_000_mA),
  303. }, { /* 1080p / 148.5MHz modes */
  304. .pclk = 148500000,
  305. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  306. SOR_PLL_VCOCAP(3) | SOR_PLL_RESISTORSEL,
  307. .pll1 = SOR_PLL_PE_EN | SOR_PLL_LOADADJ(3) |
  308. SOR_PLL_TMDS_TERMADJ(0),
  309. .pe_current = PE_CURRENT0(PE_CURRENT_10_mA_T114) |
  310. PE_CURRENT1(PE_CURRENT_10_mA_T114) |
  311. PE_CURRENT2(PE_CURRENT_10_mA_T114) |
  312. PE_CURRENT3(PE_CURRENT_10_mA_T114),
  313. .drive_current =
  314. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_12_400_mA_T114) |
  315. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_12_400_mA_T114) |
  316. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_12_400_mA_T114) |
  317. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_12_400_mA_T114),
  318. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_0_000_mA) |
  319. PEAK_CURRENT_LANE1(PEAK_CURRENT_0_000_mA) |
  320. PEAK_CURRENT_LANE2(PEAK_CURRENT_0_000_mA) |
  321. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_000_mA),
  322. }, { /* 225/297MHz modes */
  323. .pclk = UINT_MAX,
  324. .pll0 = SOR_PLL_ICHPMP(1) | SOR_PLL_BG_V17_S(3) |
  325. SOR_PLL_VCOCAP(0xf) | SOR_PLL_RESISTORSEL,
  326. .pll1 = SOR_PLL_LOADADJ(3) | SOR_PLL_TMDS_TERMADJ(7)
  327. | SOR_PLL_TMDS_TERM_ENABLE,
  328. .pe_current = PE_CURRENT0(PE_CURRENT_0_mA_T114) |
  329. PE_CURRENT1(PE_CURRENT_0_mA_T114) |
  330. PE_CURRENT2(PE_CURRENT_0_mA_T114) |
  331. PE_CURRENT3(PE_CURRENT_0_mA_T114),
  332. .drive_current =
  333. DRIVE_CURRENT_LANE0_T114(DRIVE_CURRENT_25_200_mA_T114) |
  334. DRIVE_CURRENT_LANE1_T114(DRIVE_CURRENT_25_200_mA_T114) |
  335. DRIVE_CURRENT_LANE2_T114(DRIVE_CURRENT_25_200_mA_T114) |
  336. DRIVE_CURRENT_LANE3_T114(DRIVE_CURRENT_19_200_mA_T114),
  337. .peak_current = PEAK_CURRENT_LANE0(PEAK_CURRENT_3_000_mA) |
  338. PEAK_CURRENT_LANE1(PEAK_CURRENT_3_000_mA) |
  339. PEAK_CURRENT_LANE2(PEAK_CURRENT_3_000_mA) |
  340. PEAK_CURRENT_LANE3(PEAK_CURRENT_0_800_mA),
  341. },
  342. };
  343. static void tegra_hdmi_audio_lock(struct tegra_hdmi *hdmi)
  344. {
  345. mutex_lock(&hdmi->audio_lock);
  346. disable_irq(hdmi->irq);
  347. }
  348. static void tegra_hdmi_audio_unlock(struct tegra_hdmi *hdmi)
  349. {
  350. enable_irq(hdmi->irq);
  351. mutex_unlock(&hdmi->audio_lock);
  352. }
  353. static int
  354. tegra_hdmi_get_audio_config(unsigned int audio_freq, unsigned int pix_clock,
  355. struct tegra_hdmi_audio_config *config)
  356. {
  357. const unsigned int afreq = 128 * audio_freq;
  358. const unsigned int min_n = afreq / 1500;
  359. const unsigned int max_n = afreq / 300;
  360. const unsigned int ideal_n = afreq / 1000;
  361. int64_t min_err = (uint64_t)-1 >> 1;
  362. unsigned int min_delta = -1;
  363. int n;
  364. memset(config, 0, sizeof(*config));
  365. config->n = -1;
  366. for (n = min_n; n <= max_n; n++) {
  367. uint64_t cts_f, aval_f;
  368. unsigned int delta;
  369. int64_t cts, err;
  370. /* compute aval in 48.16 fixed point */
  371. aval_f = ((int64_t)24000000 << 16) * n;
  372. do_div(aval_f, afreq);
  373. /* It should round without any rest */
  374. if (aval_f & 0xFFFF)
  375. continue;
  376. /* Compute cts in 48.16 fixed point */
  377. cts_f = ((int64_t)pix_clock << 16) * n;
  378. do_div(cts_f, afreq);
  379. /* Round it to the nearest integer */
  380. cts = (cts_f & ~0xFFFF) + ((cts_f & BIT(15)) << 1);
  381. delta = abs(n - ideal_n);
  382. /* Compute the absolute error */
  383. err = abs((int64_t)cts_f - cts);
  384. if (err < min_err || (err == min_err && delta < min_delta)) {
  385. config->n = n;
  386. config->cts = cts >> 16;
  387. config->aval = aval_f >> 16;
  388. min_delta = delta;
  389. min_err = err;
  390. }
  391. }
  392. return config->n != -1 ? 0 : -EINVAL;
  393. }
  394. static void tegra_hdmi_setup_audio_fs_tables(struct tegra_hdmi *hdmi)
  395. {
  396. static const unsigned int freqs[] = {
  397. 32000, 44100, 48000, 88200, 96000, 176400, 192000
  398. };
  399. unsigned int i;
  400. for (i = 0; i < ARRAY_SIZE(freqs); i++) {
  401. unsigned int f = freqs[i];
  402. unsigned int eight_half;
  403. unsigned int delta;
  404. u32 value;
  405. if (f > 96000)
  406. delta = 2;
  407. else if (f > 48000)
  408. delta = 6;
  409. else
  410. delta = 9;
  411. eight_half = (8 * HDMI_AUDIOCLK_FREQ) / (f * 128);
  412. value = AUDIO_FS_LOW(eight_half - delta) |
  413. AUDIO_FS_HIGH(eight_half + delta);
  414. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_AUDIO_FS(i));
  415. }
  416. }
  417. static void tegra_hdmi_write_aval(struct tegra_hdmi *hdmi, u32 value)
  418. {
  419. static const struct {
  420. unsigned int sample_rate;
  421. unsigned int offset;
  422. } regs[] = {
  423. { 32000, HDMI_NV_PDISP_SOR_AUDIO_AVAL_0320 },
  424. { 44100, HDMI_NV_PDISP_SOR_AUDIO_AVAL_0441 },
  425. { 48000, HDMI_NV_PDISP_SOR_AUDIO_AVAL_0480 },
  426. { 88200, HDMI_NV_PDISP_SOR_AUDIO_AVAL_0882 },
  427. { 96000, HDMI_NV_PDISP_SOR_AUDIO_AVAL_0960 },
  428. { 176400, HDMI_NV_PDISP_SOR_AUDIO_AVAL_1764 },
  429. { 192000, HDMI_NV_PDISP_SOR_AUDIO_AVAL_1920 },
  430. };
  431. unsigned int i;
  432. for (i = 0; i < ARRAY_SIZE(regs); i++) {
  433. if (regs[i].sample_rate == hdmi->format.sample_rate) {
  434. tegra_hdmi_writel(hdmi, value, regs[i].offset);
  435. break;
  436. }
  437. }
  438. }
  439. static int tegra_hdmi_setup_audio(struct tegra_hdmi *hdmi)
  440. {
  441. struct tegra_hdmi_audio_config config;
  442. u32 source, value;
  443. int err;
  444. switch (hdmi->audio_source) {
  445. case HDA:
  446. if (hdmi->config->has_hda)
  447. source = SOR_AUDIO_CNTRL0_SOURCE_SELECT_HDAL;
  448. else
  449. return -EINVAL;
  450. break;
  451. case SPDIF:
  452. if (hdmi->config->has_hda)
  453. source = SOR_AUDIO_CNTRL0_SOURCE_SELECT_SPDIF;
  454. else
  455. source = AUDIO_CNTRL0_SOURCE_SELECT_SPDIF;
  456. break;
  457. default:
  458. if (hdmi->config->has_hda)
  459. source = SOR_AUDIO_CNTRL0_SOURCE_SELECT_AUTO;
  460. else
  461. source = AUDIO_CNTRL0_SOURCE_SELECT_AUTO;
  462. break;
  463. }
  464. /*
  465. * Tegra30 and later use a slightly modified version of the register
  466. * layout to accomodate for changes related to supporting HDA as the
  467. * audio input source for HDMI. The source select field has moved to
  468. * the SOR_AUDIO_CNTRL0 register, but the error tolerance and frames
  469. * per block fields remain in the AUDIO_CNTRL0 register.
  470. */
  471. if (hdmi->config->has_hda) {
  472. /*
  473. * Inject null samples into the audio FIFO for every frame in
  474. * which the codec did not receive any samples. This applies
  475. * to stereo LPCM only.
  476. *
  477. * XXX: This seems to be a remnant of MCP days when this was
  478. * used to work around issues with monitors not being able to
  479. * play back system startup sounds early. It is possibly not
  480. * needed on Linux at all.
  481. */
  482. if (hdmi->format.channels == 2)
  483. value = SOR_AUDIO_CNTRL0_INJECT_NULLSMPL;
  484. else
  485. value = 0;
  486. value |= source;
  487. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_AUDIO_CNTRL0);
  488. }
  489. /*
  490. * On Tegra20, HDA is not a supported audio source and the source
  491. * select field is part of the AUDIO_CNTRL0 register.
  492. */
  493. value = AUDIO_CNTRL0_FRAMES_PER_BLOCK(0xc0) |
  494. AUDIO_CNTRL0_ERROR_TOLERANCE(6);
  495. if (!hdmi->config->has_hda)
  496. value |= source;
  497. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_AUDIO_CNTRL0);
  498. /*
  499. * Advertise support for High Bit-Rate on Tegra114 and later.
  500. */
  501. if (hdmi->config->has_hbr) {
  502. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_SOR_AUDIO_SPARE0);
  503. value |= SOR_AUDIO_SPARE0_HBR_ENABLE;
  504. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_AUDIO_SPARE0);
  505. }
  506. err = tegra_hdmi_get_audio_config(hdmi->format.sample_rate,
  507. hdmi->pixel_clock, &config);
  508. if (err < 0) {
  509. dev_err(hdmi->dev,
  510. "cannot set audio to %u Hz at %u Hz pixel clock\n",
  511. hdmi->format.sample_rate, hdmi->pixel_clock);
  512. return err;
  513. }
  514. dev_dbg(hdmi->dev, "audio: pixclk=%u, n=%u, cts=%u, aval=%u\n",
  515. hdmi->pixel_clock, config.n, config.cts, config.aval);
  516. tegra_hdmi_writel(hdmi, 0, HDMI_NV_PDISP_HDMI_ACR_CTRL);
  517. value = AUDIO_N_RESETF | AUDIO_N_GENERATE_ALTERNATE |
  518. AUDIO_N_VALUE(config.n - 1);
  519. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_AUDIO_N);
  520. tegra_hdmi_writel(hdmi, ACR_SUBPACK_N(config.n) | ACR_ENABLE,
  521. HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_HIGH);
  522. tegra_hdmi_writel(hdmi, ACR_SUBPACK_CTS(config.cts),
  523. HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_LOW);
  524. value = SPARE_HW_CTS | SPARE_FORCE_SW_CTS | SPARE_CTS_RESET_VAL(1);
  525. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_SPARE);
  526. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_AUDIO_N);
  527. value &= ~AUDIO_N_RESETF;
  528. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_AUDIO_N);
  529. if (hdmi->config->has_hda)
  530. tegra_hdmi_write_aval(hdmi, config.aval);
  531. tegra_hdmi_setup_audio_fs_tables(hdmi);
  532. return 0;
  533. }
  534. static void tegra_hdmi_disable_audio(struct tegra_hdmi *hdmi)
  535. {
  536. u32 value;
  537. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  538. value &= ~GENERIC_CTRL_AUDIO;
  539. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  540. }
  541. static void tegra_hdmi_enable_audio(struct tegra_hdmi *hdmi)
  542. {
  543. u32 value;
  544. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  545. value |= GENERIC_CTRL_AUDIO;
  546. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  547. }
  548. static void tegra_hdmi_write_eld(struct tegra_hdmi *hdmi)
  549. {
  550. size_t length = drm_eld_size(hdmi->output.connector.eld), i;
  551. u32 value;
  552. for (i = 0; i < length; i++)
  553. tegra_hdmi_writel(hdmi, i << 8 | hdmi->output.connector.eld[i],
  554. HDMI_NV_PDISP_SOR_AUDIO_HDA_ELD_BUFWR);
  555. /*
  556. * The HDA codec will always report an ELD buffer size of 96 bytes and
  557. * the HDA codec driver will check that each byte read from the buffer
  558. * is valid. Therefore every byte must be written, even if no 96 bytes
  559. * were parsed from EDID.
  560. */
  561. for (i = length; i < HDMI_ELD_BUFFER_SIZE; i++)
  562. tegra_hdmi_writel(hdmi, i << 8 | 0,
  563. HDMI_NV_PDISP_SOR_AUDIO_HDA_ELD_BUFWR);
  564. value = SOR_AUDIO_HDA_PRESENSE_VALID | SOR_AUDIO_HDA_PRESENSE_PRESENT;
  565. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_AUDIO_HDA_PRESENSE);
  566. }
  567. static inline u32 tegra_hdmi_subpack(const u8 *ptr, size_t size)
  568. {
  569. u32 value = 0;
  570. size_t i;
  571. for (i = size; i > 0; i--)
  572. value = (value << 8) | ptr[i - 1];
  573. return value;
  574. }
  575. static void tegra_hdmi_write_infopack(struct tegra_hdmi *hdmi, const void *data,
  576. size_t size)
  577. {
  578. const u8 *ptr = data;
  579. unsigned long offset;
  580. size_t i;
  581. u32 value;
  582. switch (ptr[0]) {
  583. case HDMI_INFOFRAME_TYPE_AVI:
  584. offset = HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_HEADER;
  585. break;
  586. case HDMI_INFOFRAME_TYPE_AUDIO:
  587. offset = HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_HEADER;
  588. break;
  589. case HDMI_INFOFRAME_TYPE_VENDOR:
  590. offset = HDMI_NV_PDISP_HDMI_GENERIC_HEADER;
  591. break;
  592. default:
  593. dev_err(hdmi->dev, "unsupported infoframe type: %02x\n",
  594. ptr[0]);
  595. return;
  596. }
  597. value = INFOFRAME_HEADER_TYPE(ptr[0]) |
  598. INFOFRAME_HEADER_VERSION(ptr[1]) |
  599. INFOFRAME_HEADER_LEN(ptr[2]);
  600. tegra_hdmi_writel(hdmi, value, offset);
  601. offset++;
  602. /*
  603. * Each subpack contains 7 bytes, divided into:
  604. * - subpack_low: bytes 0 - 3
  605. * - subpack_high: bytes 4 - 6 (with byte 7 padded to 0x00)
  606. */
  607. for (i = 3; i < size; i += 7) {
  608. size_t rem = size - i, num = min_t(size_t, rem, 4);
  609. value = tegra_hdmi_subpack(&ptr[i], num);
  610. tegra_hdmi_writel(hdmi, value, offset++);
  611. num = min_t(size_t, rem - num, 3);
  612. value = tegra_hdmi_subpack(&ptr[i + 4], num);
  613. tegra_hdmi_writel(hdmi, value, offset++);
  614. }
  615. }
  616. static void tegra_hdmi_setup_avi_infoframe(struct tegra_hdmi *hdmi,
  617. struct drm_display_mode *mode)
  618. {
  619. struct hdmi_avi_infoframe frame;
  620. u8 buffer[17];
  621. ssize_t err;
  622. err = drm_hdmi_avi_infoframe_from_display_mode(&frame,
  623. &hdmi->output.connector, mode);
  624. if (err < 0) {
  625. dev_err(hdmi->dev, "failed to setup AVI infoframe: %zd\n", err);
  626. return;
  627. }
  628. err = hdmi_avi_infoframe_pack(&frame, buffer, sizeof(buffer));
  629. if (err < 0) {
  630. dev_err(hdmi->dev, "failed to pack AVI infoframe: %zd\n", err);
  631. return;
  632. }
  633. tegra_hdmi_write_infopack(hdmi, buffer, err);
  634. }
  635. static void tegra_hdmi_disable_avi_infoframe(struct tegra_hdmi *hdmi)
  636. {
  637. u32 value;
  638. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_CTRL);
  639. value &= ~INFOFRAME_CTRL_ENABLE;
  640. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_CTRL);
  641. }
  642. static void tegra_hdmi_enable_avi_infoframe(struct tegra_hdmi *hdmi)
  643. {
  644. u32 value;
  645. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_CTRL);
  646. value |= INFOFRAME_CTRL_ENABLE;
  647. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_CTRL);
  648. }
  649. static void tegra_hdmi_setup_audio_infoframe(struct tegra_hdmi *hdmi)
  650. {
  651. struct hdmi_audio_infoframe frame;
  652. u8 buffer[14];
  653. ssize_t err;
  654. err = hdmi_audio_infoframe_init(&frame);
  655. if (err < 0) {
  656. dev_err(hdmi->dev, "failed to setup audio infoframe: %zd\n",
  657. err);
  658. return;
  659. }
  660. frame.channels = hdmi->format.channels;
  661. err = hdmi_audio_infoframe_pack(&frame, buffer, sizeof(buffer));
  662. if (err < 0) {
  663. dev_err(hdmi->dev, "failed to pack audio infoframe: %zd\n",
  664. err);
  665. return;
  666. }
  667. /*
  668. * The audio infoframe has only one set of subpack registers, so the
  669. * infoframe needs to be truncated. One set of subpack registers can
  670. * contain 7 bytes. Including the 3 byte header only the first 10
  671. * bytes can be programmed.
  672. */
  673. tegra_hdmi_write_infopack(hdmi, buffer, min_t(size_t, 10, err));
  674. }
  675. static void tegra_hdmi_disable_audio_infoframe(struct tegra_hdmi *hdmi)
  676. {
  677. u32 value;
  678. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_CTRL);
  679. value &= ~INFOFRAME_CTRL_ENABLE;
  680. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_CTRL);
  681. }
  682. static void tegra_hdmi_enable_audio_infoframe(struct tegra_hdmi *hdmi)
  683. {
  684. u32 value;
  685. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_CTRL);
  686. value |= INFOFRAME_CTRL_ENABLE;
  687. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_CTRL);
  688. }
  689. static void tegra_hdmi_setup_stereo_infoframe(struct tegra_hdmi *hdmi)
  690. {
  691. struct hdmi_vendor_infoframe frame;
  692. u8 buffer[10];
  693. ssize_t err;
  694. hdmi_vendor_infoframe_init(&frame);
  695. frame.s3d_struct = HDMI_3D_STRUCTURE_FRAME_PACKING;
  696. err = hdmi_vendor_infoframe_pack(&frame, buffer, sizeof(buffer));
  697. if (err < 0) {
  698. dev_err(hdmi->dev, "failed to pack vendor infoframe: %zd\n",
  699. err);
  700. return;
  701. }
  702. tegra_hdmi_write_infopack(hdmi, buffer, err);
  703. }
  704. static void tegra_hdmi_disable_stereo_infoframe(struct tegra_hdmi *hdmi)
  705. {
  706. u32 value;
  707. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  708. value &= ~GENERIC_CTRL_ENABLE;
  709. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  710. }
  711. static void tegra_hdmi_enable_stereo_infoframe(struct tegra_hdmi *hdmi)
  712. {
  713. u32 value;
  714. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  715. value |= GENERIC_CTRL_ENABLE;
  716. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_GENERIC_CTRL);
  717. }
  718. static void tegra_hdmi_setup_tmds(struct tegra_hdmi *hdmi,
  719. const struct tmds_config *tmds)
  720. {
  721. u32 value;
  722. tegra_hdmi_writel(hdmi, tmds->pll0, HDMI_NV_PDISP_SOR_PLL0);
  723. tegra_hdmi_writel(hdmi, tmds->pll1, HDMI_NV_PDISP_SOR_PLL1);
  724. tegra_hdmi_writel(hdmi, tmds->pe_current, HDMI_NV_PDISP_PE_CURRENT);
  725. tegra_hdmi_writel(hdmi, tmds->drive_current,
  726. HDMI_NV_PDISP_SOR_LANE_DRIVE_CURRENT);
  727. value = tegra_hdmi_readl(hdmi, hdmi->config->fuse_override_offset);
  728. value |= hdmi->config->fuse_override_value;
  729. tegra_hdmi_writel(hdmi, value, hdmi->config->fuse_override_offset);
  730. if (hdmi->config->has_sor_io_peak_current)
  731. tegra_hdmi_writel(hdmi, tmds->peak_current,
  732. HDMI_NV_PDISP_SOR_IO_PEAK_CURRENT);
  733. }
  734. static int tegra_hdmi_reconfigure_audio(struct tegra_hdmi *hdmi)
  735. {
  736. int err;
  737. err = tegra_hdmi_setup_audio(hdmi);
  738. if (err < 0) {
  739. tegra_hdmi_disable_audio_infoframe(hdmi);
  740. tegra_hdmi_disable_audio(hdmi);
  741. } else {
  742. tegra_hdmi_setup_audio_infoframe(hdmi);
  743. tegra_hdmi_enable_audio_infoframe(hdmi);
  744. tegra_hdmi_enable_audio(hdmi);
  745. }
  746. return err;
  747. }
  748. static bool tegra_output_is_hdmi(struct tegra_output *output)
  749. {
  750. return output->connector.display_info.is_hdmi;
  751. }
  752. static enum drm_connector_status
  753. tegra_hdmi_connector_detect(struct drm_connector *connector, bool force)
  754. {
  755. struct tegra_output *output = connector_to_output(connector);
  756. struct tegra_hdmi *hdmi = to_hdmi(output);
  757. enum drm_connector_status status;
  758. status = tegra_output_connector_detect(connector, force);
  759. if (status == connector_status_connected)
  760. return status;
  761. tegra_hdmi_writel(hdmi, 0, HDMI_NV_PDISP_SOR_AUDIO_HDA_PRESENSE);
  762. return status;
  763. }
  764. #define DEBUGFS_REG32(_name) { .name = #_name, .offset = _name }
  765. static const struct debugfs_reg32 tegra_hdmi_regs[] = {
  766. DEBUGFS_REG32(HDMI_CTXSW),
  767. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_STATE0),
  768. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_STATE1),
  769. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_STATE2),
  770. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_AN_MSB),
  771. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_AN_LSB),
  772. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CN_MSB),
  773. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CN_LSB),
  774. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_AKSV_MSB),
  775. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_AKSV_LSB),
  776. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_BKSV_MSB),
  777. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_BKSV_LSB),
  778. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CKSV_MSB),
  779. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CKSV_LSB),
  780. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_DKSV_MSB),
  781. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_DKSV_LSB),
  782. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CTRL),
  783. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CMODE),
  784. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_MPRIME_MSB),
  785. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_MPRIME_LSB),
  786. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_SPRIME_MSB),
  787. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_SPRIME_LSB2),
  788. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_SPRIME_LSB1),
  789. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_RI),
  790. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CS_MSB),
  791. DEBUGFS_REG32(HDMI_NV_PDISP_RG_HDCP_CS_LSB),
  792. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_EMU0),
  793. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_EMU_RDATA0),
  794. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_EMU1),
  795. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_EMU2),
  796. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_CTRL),
  797. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_STATUS),
  798. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_HEADER),
  799. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_SUBPACK0_LOW),
  800. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_SUBPACK0_HIGH),
  801. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_CTRL),
  802. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_STATUS),
  803. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_HEADER),
  804. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK0_LOW),
  805. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK0_HIGH),
  806. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK1_LOW),
  807. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK1_HIGH),
  808. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_CTRL),
  809. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_STATUS),
  810. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_HEADER),
  811. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK0_LOW),
  812. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK0_HIGH),
  813. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK1_LOW),
  814. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK1_HIGH),
  815. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK2_LOW),
  816. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK2_HIGH),
  817. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK3_LOW),
  818. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK3_HIGH),
  819. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_CTRL),
  820. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0320_SUBPACK_LOW),
  821. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0320_SUBPACK_HIGH),
  822. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_LOW),
  823. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_HIGH),
  824. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0882_SUBPACK_LOW),
  825. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0882_SUBPACK_HIGH),
  826. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_1764_SUBPACK_LOW),
  827. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_1764_SUBPACK_HIGH),
  828. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0480_SUBPACK_LOW),
  829. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0480_SUBPACK_HIGH),
  830. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0960_SUBPACK_LOW),
  831. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_0960_SUBPACK_HIGH),
  832. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_1920_SUBPACK_LOW),
  833. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_ACR_1920_SUBPACK_HIGH),
  834. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_CTRL),
  835. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_VSYNC_KEEPOUT),
  836. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_VSYNC_WINDOW),
  837. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GCP_CTRL),
  838. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GCP_STATUS),
  839. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_GCP_SUBPACK),
  840. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_CHANNEL_STATUS1),
  841. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_CHANNEL_STATUS2),
  842. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_EMU0),
  843. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_EMU1),
  844. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_EMU1_RDATA),
  845. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_SPARE),
  846. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_SPDIF_CHN_STATUS1),
  847. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_SPDIF_CHN_STATUS2),
  848. DEBUGFS_REG32(HDMI_NV_PDISP_HDMI_HDCPRIF_ROM_CTRL),
  849. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_CAP),
  850. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_PWR),
  851. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_TEST),
  852. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_PLL0),
  853. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_PLL1),
  854. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_PLL2),
  855. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_CSTM),
  856. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_LVDS),
  857. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_CRCA),
  858. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_CRCB),
  859. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_BLANK),
  860. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_CTL),
  861. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(0)),
  862. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(1)),
  863. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(2)),
  864. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(3)),
  865. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(4)),
  866. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(5)),
  867. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(6)),
  868. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(7)),
  869. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(8)),
  870. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(9)),
  871. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(10)),
  872. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(11)),
  873. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(12)),
  874. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(13)),
  875. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(14)),
  876. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_SEQ_INST(15)),
  877. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_VCRCA0),
  878. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_VCRCA1),
  879. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_CCRCA0),
  880. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_CCRCA1),
  881. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_EDATAA0),
  882. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_EDATAA1),
  883. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_COUNTA0),
  884. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_COUNTA1),
  885. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_DEBUGA0),
  886. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_DEBUGA1),
  887. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_TRIG),
  888. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_MSCHECK),
  889. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_LANE_DRIVE_CURRENT),
  890. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_DEBUG0),
  891. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_DEBUG1),
  892. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_DEBUG2),
  893. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_FS(0)),
  894. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_FS(1)),
  895. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_FS(2)),
  896. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_FS(3)),
  897. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_FS(4)),
  898. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_FS(5)),
  899. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_FS(6)),
  900. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_PULSE_WIDTH),
  901. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_THRESHOLD),
  902. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_CNTRL0),
  903. DEBUGFS_REG32(HDMI_NV_PDISP_AUDIO_N),
  904. DEBUGFS_REG32(HDMI_NV_PDISP_HDCPRIF_ROM_TIMING),
  905. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_REFCLK),
  906. DEBUGFS_REG32(HDMI_NV_PDISP_CRC_CONTROL),
  907. DEBUGFS_REG32(HDMI_NV_PDISP_INPUT_CONTROL),
  908. DEBUGFS_REG32(HDMI_NV_PDISP_SCRATCH),
  909. DEBUGFS_REG32(HDMI_NV_PDISP_PE_CURRENT),
  910. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_CTRL),
  911. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_DEBUG0),
  912. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_DEBUG1),
  913. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_DEBUG2),
  914. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_HDCP_KEY_0),
  915. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_HDCP_KEY_1),
  916. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_HDCP_KEY_2),
  917. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_HDCP_KEY_3),
  918. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_HDCP_KEY_TRIG),
  919. DEBUGFS_REG32(HDMI_NV_PDISP_KEY_SKEY_INDEX),
  920. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_AUDIO_CNTRL0),
  921. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_AUDIO_SPARE0),
  922. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_AUDIO_HDA_CODEC_SCRATCH0),
  923. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_AUDIO_HDA_CODEC_SCRATCH1),
  924. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_AUDIO_HDA_ELD_BUFWR),
  925. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_AUDIO_HDA_PRESENSE),
  926. DEBUGFS_REG32(HDMI_NV_PDISP_INT_STATUS),
  927. DEBUGFS_REG32(HDMI_NV_PDISP_INT_MASK),
  928. DEBUGFS_REG32(HDMI_NV_PDISP_INT_ENABLE),
  929. DEBUGFS_REG32(HDMI_NV_PDISP_SOR_IO_PEAK_CURRENT),
  930. };
  931. static int tegra_hdmi_show_regs(struct seq_file *s, void *data)
  932. {
  933. struct drm_info_node *node = s->private;
  934. struct tegra_hdmi *hdmi = node->info_ent->data;
  935. struct drm_crtc *crtc = hdmi->output.encoder.crtc;
  936. struct drm_device *drm = node->minor->dev;
  937. unsigned int i;
  938. int err = 0;
  939. drm_modeset_lock_all(drm);
  940. if (!crtc || !crtc->state->active) {
  941. err = -EBUSY;
  942. goto unlock;
  943. }
  944. for (i = 0; i < ARRAY_SIZE(tegra_hdmi_regs); i++) {
  945. unsigned int offset = tegra_hdmi_regs[i].offset;
  946. seq_printf(s, "%-56s %#05x %08x\n", tegra_hdmi_regs[i].name,
  947. offset, tegra_hdmi_readl(hdmi, offset));
  948. }
  949. unlock:
  950. drm_modeset_unlock_all(drm);
  951. return err;
  952. }
  953. static struct drm_info_list debugfs_files[] = {
  954. { "regs", tegra_hdmi_show_regs, 0, NULL },
  955. };
  956. static int tegra_hdmi_late_register(struct drm_connector *connector)
  957. {
  958. struct tegra_output *output = connector_to_output(connector);
  959. unsigned int i, count = ARRAY_SIZE(debugfs_files);
  960. struct drm_minor *minor = connector->dev->primary;
  961. struct dentry *root = connector->debugfs_entry;
  962. struct tegra_hdmi *hdmi = to_hdmi(output);
  963. hdmi->debugfs_files = kmemdup(debugfs_files, sizeof(debugfs_files),
  964. GFP_KERNEL);
  965. if (!hdmi->debugfs_files)
  966. return -ENOMEM;
  967. for (i = 0; i < count; i++)
  968. hdmi->debugfs_files[i].data = hdmi;
  969. drm_debugfs_create_files(hdmi->debugfs_files, count, root, minor);
  970. return 0;
  971. }
  972. static void tegra_hdmi_early_unregister(struct drm_connector *connector)
  973. {
  974. struct tegra_output *output = connector_to_output(connector);
  975. struct drm_minor *minor = connector->dev->primary;
  976. unsigned int count = ARRAY_SIZE(debugfs_files);
  977. struct tegra_hdmi *hdmi = to_hdmi(output);
  978. drm_debugfs_remove_files(hdmi->debugfs_files, count,
  979. connector->debugfs_entry, minor);
  980. kfree(hdmi->debugfs_files);
  981. hdmi->debugfs_files = NULL;
  982. }
  983. static const struct drm_connector_funcs tegra_hdmi_connector_funcs = {
  984. .reset = drm_atomic_helper_connector_reset,
  985. .detect = tegra_hdmi_connector_detect,
  986. .fill_modes = drm_helper_probe_single_connector_modes,
  987. .destroy = tegra_output_connector_destroy,
  988. .atomic_duplicate_state = drm_atomic_helper_connector_duplicate_state,
  989. .atomic_destroy_state = drm_atomic_helper_connector_destroy_state,
  990. .late_register = tegra_hdmi_late_register,
  991. .early_unregister = tegra_hdmi_early_unregister,
  992. };
  993. static enum drm_mode_status
  994. tegra_hdmi_connector_mode_valid(struct drm_connector *connector,
  995. const struct drm_display_mode *mode)
  996. {
  997. struct tegra_output *output = connector_to_output(connector);
  998. struct tegra_hdmi *hdmi = to_hdmi(output);
  999. unsigned long pclk = mode->clock * 1000;
  1000. enum drm_mode_status status = MODE_OK;
  1001. struct clk *parent;
  1002. long err;
  1003. parent = clk_get_parent(hdmi->clk_parent);
  1004. err = clk_round_rate(parent, pclk * 4);
  1005. if (err <= 0)
  1006. status = MODE_NOCLOCK;
  1007. return status;
  1008. }
  1009. static const struct drm_connector_helper_funcs
  1010. tegra_hdmi_connector_helper_funcs = {
  1011. .get_modes = tegra_output_connector_get_modes,
  1012. .mode_valid = tegra_hdmi_connector_mode_valid,
  1013. };
  1014. static void tegra_hdmi_encoder_disable(struct drm_encoder *encoder)
  1015. {
  1016. struct tegra_output *output = encoder_to_output(encoder);
  1017. struct tegra_dc *dc = to_tegra_dc(encoder->crtc);
  1018. struct tegra_hdmi *hdmi = to_hdmi(output);
  1019. u32 value;
  1020. int err;
  1021. tegra_hdmi_audio_lock(hdmi);
  1022. /*
  1023. * The following accesses registers of the display controller, so make
  1024. * sure it's only executed when the output is attached to one.
  1025. */
  1026. if (dc) {
  1027. value = tegra_dc_readl(dc, DC_DISP_DISP_WIN_OPTIONS);
  1028. value &= ~HDMI_ENABLE;
  1029. tegra_dc_writel(dc, value, DC_DISP_DISP_WIN_OPTIONS);
  1030. tegra_dc_commit(dc);
  1031. }
  1032. if (!hdmi->dvi) {
  1033. if (hdmi->stereo)
  1034. tegra_hdmi_disable_stereo_infoframe(hdmi);
  1035. tegra_hdmi_disable_audio_infoframe(hdmi);
  1036. tegra_hdmi_disable_avi_infoframe(hdmi);
  1037. tegra_hdmi_disable_audio(hdmi);
  1038. }
  1039. tegra_hdmi_writel(hdmi, 0, HDMI_NV_PDISP_INT_ENABLE);
  1040. tegra_hdmi_writel(hdmi, 0, HDMI_NV_PDISP_INT_MASK);
  1041. hdmi->pixel_clock = 0;
  1042. tegra_hdmi_audio_unlock(hdmi);
  1043. err = host1x_client_suspend(&hdmi->client);
  1044. if (err < 0)
  1045. dev_err(hdmi->dev, "failed to suspend: %d\n", err);
  1046. }
  1047. static void tegra_hdmi_encoder_enable(struct drm_encoder *encoder)
  1048. {
  1049. struct drm_display_mode *mode = &encoder->crtc->state->adjusted_mode;
  1050. unsigned int h_sync_width, h_front_porch, h_back_porch, i, rekey;
  1051. struct tegra_output *output = encoder_to_output(encoder);
  1052. struct tegra_dc *dc = to_tegra_dc(encoder->crtc);
  1053. struct tegra_hdmi *hdmi = to_hdmi(output);
  1054. unsigned int pulse_start, div82;
  1055. int retries = 1000;
  1056. u32 value;
  1057. int err;
  1058. err = host1x_client_resume(&hdmi->client);
  1059. if (err < 0) {
  1060. dev_err(hdmi->dev, "failed to resume: %d\n", err);
  1061. return;
  1062. }
  1063. tegra_hdmi_audio_lock(hdmi);
  1064. /*
  1065. * Enable and unmask the HDA codec SCRATCH0 register interrupt. This
  1066. * is used for interoperability between the HDA codec driver and the
  1067. * HDMI driver.
  1068. */
  1069. tegra_hdmi_writel(hdmi, INT_CODEC_SCRATCH0, HDMI_NV_PDISP_INT_ENABLE);
  1070. tegra_hdmi_writel(hdmi, INT_CODEC_SCRATCH0, HDMI_NV_PDISP_INT_MASK);
  1071. hdmi->pixel_clock = mode->clock * 1000;
  1072. h_sync_width = mode->hsync_end - mode->hsync_start;
  1073. h_back_porch = mode->htotal - mode->hsync_end;
  1074. h_front_porch = mode->hsync_start - mode->hdisplay;
  1075. err = dev_pm_opp_set_rate(hdmi->dev, hdmi->pixel_clock);
  1076. if (err < 0) {
  1077. dev_err(hdmi->dev, "failed to set HDMI clock frequency: %d\n",
  1078. err);
  1079. }
  1080. DRM_DEBUG_KMS("HDMI clock rate: %lu Hz\n", clk_get_rate(hdmi->clk));
  1081. /* power up sequence */
  1082. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_SOR_PLL0);
  1083. value &= ~SOR_PLL_PDBG;
  1084. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_PLL0);
  1085. usleep_range(10, 20);
  1086. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_SOR_PLL0);
  1087. value &= ~SOR_PLL_PWR;
  1088. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_PLL0);
  1089. tegra_dc_writel(dc, VSYNC_H_POSITION(1),
  1090. DC_DISP_DISP_TIMING_OPTIONS);
  1091. tegra_dc_writel(dc, DITHER_CONTROL_DISABLE | BASE_COLOR_SIZE_888,
  1092. DC_DISP_DISP_COLOR_CONTROL);
  1093. /* video_preamble uses h_pulse2 */
  1094. pulse_start = 1 + h_sync_width + h_back_porch - 10;
  1095. tegra_dc_writel(dc, H_PULSE2_ENABLE, DC_DISP_DISP_SIGNAL_OPTIONS0);
  1096. value = PULSE_MODE_NORMAL | PULSE_POLARITY_HIGH | PULSE_QUAL_VACTIVE |
  1097. PULSE_LAST_END_A;
  1098. tegra_dc_writel(dc, value, DC_DISP_H_PULSE2_CONTROL);
  1099. value = PULSE_START(pulse_start) | PULSE_END(pulse_start + 8);
  1100. tegra_dc_writel(dc, value, DC_DISP_H_PULSE2_POSITION_A);
  1101. value = VSYNC_WINDOW_END(0x210) | VSYNC_WINDOW_START(0x200) |
  1102. VSYNC_WINDOW_ENABLE;
  1103. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_VSYNC_WINDOW);
  1104. if (dc->pipe)
  1105. value = HDMI_SRC_DISPLAYB;
  1106. else
  1107. value = HDMI_SRC_DISPLAYA;
  1108. if ((mode->hdisplay == 720) && ((mode->vdisplay == 480) ||
  1109. (mode->vdisplay == 576)))
  1110. tegra_hdmi_writel(hdmi,
  1111. value | ARM_VIDEO_RANGE_FULL,
  1112. HDMI_NV_PDISP_INPUT_CONTROL);
  1113. else
  1114. tegra_hdmi_writel(hdmi,
  1115. value | ARM_VIDEO_RANGE_LIMITED,
  1116. HDMI_NV_PDISP_INPUT_CONTROL);
  1117. div82 = clk_get_rate(hdmi->clk) / 1000000 * 4;
  1118. value = SOR_REFCLK_DIV_INT(div82 >> 2) | SOR_REFCLK_DIV_FRAC(div82);
  1119. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_REFCLK);
  1120. hdmi->dvi = !tegra_output_is_hdmi(output);
  1121. if (!hdmi->dvi) {
  1122. /*
  1123. * Make sure that the audio format has been configured before
  1124. * enabling audio, otherwise we may try to divide by zero.
  1125. */
  1126. if (hdmi->format.sample_rate > 0) {
  1127. err = tegra_hdmi_setup_audio(hdmi);
  1128. if (err < 0)
  1129. hdmi->dvi = true;
  1130. }
  1131. }
  1132. if (hdmi->config->has_hda)
  1133. tegra_hdmi_write_eld(hdmi);
  1134. rekey = HDMI_REKEY_DEFAULT;
  1135. value = HDMI_CTRL_REKEY(rekey);
  1136. value |= HDMI_CTRL_MAX_AC_PACKET((h_sync_width + h_back_porch +
  1137. h_front_porch - rekey - 18) / 32);
  1138. if (!hdmi->dvi)
  1139. value |= HDMI_CTRL_ENABLE;
  1140. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_HDMI_CTRL);
  1141. if (!hdmi->dvi) {
  1142. tegra_hdmi_setup_avi_infoframe(hdmi, mode);
  1143. tegra_hdmi_setup_audio_infoframe(hdmi);
  1144. if (hdmi->stereo)
  1145. tegra_hdmi_setup_stereo_infoframe(hdmi);
  1146. }
  1147. /* TMDS CONFIG */
  1148. for (i = 0; i < hdmi->config->num_tmds; i++) {
  1149. if (hdmi->pixel_clock <= hdmi->config->tmds[i].pclk) {
  1150. tegra_hdmi_setup_tmds(hdmi, &hdmi->config->tmds[i]);
  1151. break;
  1152. }
  1153. }
  1154. tegra_hdmi_writel(hdmi,
  1155. SOR_SEQ_PU_PC(0) |
  1156. SOR_SEQ_PU_PC_ALT(0) |
  1157. SOR_SEQ_PD_PC(8) |
  1158. SOR_SEQ_PD_PC_ALT(8),
  1159. HDMI_NV_PDISP_SOR_SEQ_CTL);
  1160. value = SOR_SEQ_INST_WAIT_TIME(1) |
  1161. SOR_SEQ_INST_WAIT_UNITS_VSYNC |
  1162. SOR_SEQ_INST_HALT |
  1163. SOR_SEQ_INST_PIN_A_LOW |
  1164. SOR_SEQ_INST_PIN_B_LOW |
  1165. SOR_SEQ_INST_DRIVE_PWM_OUT_LO;
  1166. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_SEQ_INST(0));
  1167. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_SEQ_INST(8));
  1168. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_SOR_CSTM);
  1169. value &= ~SOR_CSTM_ROTCLK(~0);
  1170. value |= SOR_CSTM_ROTCLK(2);
  1171. value |= SOR_CSTM_PLLDIV;
  1172. value &= ~SOR_CSTM_LVDS_ENABLE;
  1173. value &= ~SOR_CSTM_MODE_MASK;
  1174. value |= SOR_CSTM_MODE_TMDS;
  1175. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_CSTM);
  1176. /* start SOR */
  1177. tegra_hdmi_writel(hdmi,
  1178. SOR_PWR_NORMAL_STATE_PU |
  1179. SOR_PWR_NORMAL_START_NORMAL |
  1180. SOR_PWR_SAFE_STATE_PD |
  1181. SOR_PWR_SETTING_NEW_TRIGGER,
  1182. HDMI_NV_PDISP_SOR_PWR);
  1183. tegra_hdmi_writel(hdmi,
  1184. SOR_PWR_NORMAL_STATE_PU |
  1185. SOR_PWR_NORMAL_START_NORMAL |
  1186. SOR_PWR_SAFE_STATE_PD |
  1187. SOR_PWR_SETTING_NEW_DONE,
  1188. HDMI_NV_PDISP_SOR_PWR);
  1189. do {
  1190. BUG_ON(--retries < 0);
  1191. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_SOR_PWR);
  1192. } while (value & SOR_PWR_SETTING_NEW_PENDING);
  1193. value = SOR_STATE_ASY_CRCMODE_COMPLETE |
  1194. SOR_STATE_ASY_OWNER_HEAD0 |
  1195. SOR_STATE_ASY_SUBOWNER_BOTH |
  1196. SOR_STATE_ASY_PROTOCOL_SINGLE_TMDS_A |
  1197. SOR_STATE_ASY_DEPOL_POS;
  1198. /* setup sync polarities */
  1199. if (mode->flags & DRM_MODE_FLAG_PHSYNC)
  1200. value |= SOR_STATE_ASY_HSYNCPOL_POS;
  1201. if (mode->flags & DRM_MODE_FLAG_NHSYNC)
  1202. value |= SOR_STATE_ASY_HSYNCPOL_NEG;
  1203. if (mode->flags & DRM_MODE_FLAG_PVSYNC)
  1204. value |= SOR_STATE_ASY_VSYNCPOL_POS;
  1205. if (mode->flags & DRM_MODE_FLAG_NVSYNC)
  1206. value |= SOR_STATE_ASY_VSYNCPOL_NEG;
  1207. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_STATE2);
  1208. value = SOR_STATE_ASY_HEAD_OPMODE_AWAKE | SOR_STATE_ASY_ORMODE_NORMAL;
  1209. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_SOR_STATE1);
  1210. tegra_hdmi_writel(hdmi, 0, HDMI_NV_PDISP_SOR_STATE0);
  1211. tegra_hdmi_writel(hdmi, SOR_STATE_UPDATE, HDMI_NV_PDISP_SOR_STATE0);
  1212. tegra_hdmi_writel(hdmi, value | SOR_STATE_ATTACHED,
  1213. HDMI_NV_PDISP_SOR_STATE1);
  1214. tegra_hdmi_writel(hdmi, 0, HDMI_NV_PDISP_SOR_STATE0);
  1215. value = tegra_dc_readl(dc, DC_DISP_DISP_WIN_OPTIONS);
  1216. value |= HDMI_ENABLE;
  1217. tegra_dc_writel(dc, value, DC_DISP_DISP_WIN_OPTIONS);
  1218. tegra_dc_commit(dc);
  1219. if (!hdmi->dvi) {
  1220. tegra_hdmi_enable_avi_infoframe(hdmi);
  1221. tegra_hdmi_enable_audio_infoframe(hdmi);
  1222. tegra_hdmi_enable_audio(hdmi);
  1223. if (hdmi->stereo)
  1224. tegra_hdmi_enable_stereo_infoframe(hdmi);
  1225. }
  1226. /* TODO: add HDCP support */
  1227. tegra_hdmi_audio_unlock(hdmi);
  1228. }
  1229. static int
  1230. tegra_hdmi_encoder_atomic_check(struct drm_encoder *encoder,
  1231. struct drm_crtc_state *crtc_state,
  1232. struct drm_connector_state *conn_state)
  1233. {
  1234. struct tegra_output *output = encoder_to_output(encoder);
  1235. struct tegra_dc *dc = to_tegra_dc(conn_state->crtc);
  1236. unsigned long pclk = crtc_state->mode.clock * 1000;
  1237. struct tegra_hdmi *hdmi = to_hdmi(output);
  1238. int err;
  1239. err = tegra_dc_state_setup_clock(dc, crtc_state, hdmi->clk_parent,
  1240. pclk, 0);
  1241. if (err < 0) {
  1242. dev_err(output->dev, "failed to setup CRTC state: %d\n", err);
  1243. return err;
  1244. }
  1245. return err;
  1246. }
  1247. static const struct drm_encoder_helper_funcs tegra_hdmi_encoder_helper_funcs = {
  1248. .disable = tegra_hdmi_encoder_disable,
  1249. .enable = tegra_hdmi_encoder_enable,
  1250. .atomic_check = tegra_hdmi_encoder_atomic_check,
  1251. };
  1252. static int tegra_hdmi_hw_params(struct device *dev, void *data,
  1253. struct hdmi_codec_daifmt *fmt,
  1254. struct hdmi_codec_params *hparms)
  1255. {
  1256. struct tegra_hdmi *hdmi = data;
  1257. int ret = 0;
  1258. tegra_hdmi_audio_lock(hdmi);
  1259. hdmi->format.sample_rate = hparms->sample_rate;
  1260. hdmi->format.channels = hparms->channels;
  1261. if (hdmi->pixel_clock && !hdmi->dvi)
  1262. ret = tegra_hdmi_reconfigure_audio(hdmi);
  1263. tegra_hdmi_audio_unlock(hdmi);
  1264. return ret;
  1265. }
  1266. static int tegra_hdmi_audio_startup(struct device *dev, void *data)
  1267. {
  1268. struct tegra_hdmi *hdmi = data;
  1269. int ret;
  1270. ret = host1x_client_resume(&hdmi->client);
  1271. if (ret < 0)
  1272. dev_err(hdmi->dev, "failed to resume: %d\n", ret);
  1273. return ret;
  1274. }
  1275. static void tegra_hdmi_audio_shutdown(struct device *dev, void *data)
  1276. {
  1277. struct tegra_hdmi *hdmi = data;
  1278. int ret;
  1279. tegra_hdmi_audio_lock(hdmi);
  1280. hdmi->format.sample_rate = 0;
  1281. hdmi->format.channels = 0;
  1282. tegra_hdmi_audio_unlock(hdmi);
  1283. ret = host1x_client_suspend(&hdmi->client);
  1284. if (ret < 0)
  1285. dev_err(hdmi->dev, "failed to suspend: %d\n", ret);
  1286. }
  1287. static const struct hdmi_codec_ops tegra_hdmi_codec_ops = {
  1288. .hw_params = tegra_hdmi_hw_params,
  1289. .audio_startup = tegra_hdmi_audio_startup,
  1290. .audio_shutdown = tegra_hdmi_audio_shutdown,
  1291. };
  1292. static int tegra_hdmi_codec_register(struct tegra_hdmi *hdmi)
  1293. {
  1294. struct hdmi_codec_pdata codec_data = {};
  1295. if (hdmi->config->has_hda)
  1296. return 0;
  1297. codec_data.ops = &tegra_hdmi_codec_ops;
  1298. codec_data.data = hdmi;
  1299. codec_data.spdif = 1;
  1300. hdmi->audio_pdev = platform_device_register_data(hdmi->dev,
  1301. HDMI_CODEC_DRV_NAME,
  1302. PLATFORM_DEVID_AUTO,
  1303. &codec_data,
  1304. sizeof(codec_data));
  1305. if (IS_ERR(hdmi->audio_pdev))
  1306. return PTR_ERR(hdmi->audio_pdev);
  1307. hdmi->format.channels = 2;
  1308. return 0;
  1309. }
  1310. static void tegra_hdmi_codec_unregister(struct tegra_hdmi *hdmi)
  1311. {
  1312. if (hdmi->audio_pdev)
  1313. platform_device_unregister(hdmi->audio_pdev);
  1314. }
  1315. static int tegra_hdmi_init(struct host1x_client *client)
  1316. {
  1317. struct tegra_hdmi *hdmi = host1x_client_to_hdmi(client);
  1318. struct drm_device *drm = dev_get_drvdata(client->host);
  1319. struct drm_connector *connector;
  1320. int err;
  1321. hdmi->output.dev = client->dev;
  1322. drm_simple_encoder_init(drm, &hdmi->output.encoder,
  1323. DRM_MODE_ENCODER_TMDS);
  1324. drm_encoder_helper_add(&hdmi->output.encoder,
  1325. &tegra_hdmi_encoder_helper_funcs);
  1326. if (hdmi->output.bridge) {
  1327. err = drm_bridge_attach(&hdmi->output.encoder, hdmi->output.bridge,
  1328. NULL, DRM_BRIDGE_ATTACH_NO_CONNECTOR);
  1329. if (err) {
  1330. dev_err(client->dev, "failed to attach bridge: %d\n",
  1331. err);
  1332. return err;
  1333. }
  1334. connector = drm_bridge_connector_init(drm, &hdmi->output.encoder);
  1335. if (IS_ERR(connector)) {
  1336. dev_err(client->dev,
  1337. "failed to initialize bridge connector: %pe\n",
  1338. connector);
  1339. return PTR_ERR(connector);
  1340. }
  1341. drm_connector_attach_encoder(connector, &hdmi->output.encoder);
  1342. } else {
  1343. drm_connector_init_with_ddc(drm, &hdmi->output.connector,
  1344. &tegra_hdmi_connector_funcs,
  1345. DRM_MODE_CONNECTOR_HDMIA,
  1346. hdmi->output.ddc);
  1347. drm_connector_helper_add(&hdmi->output.connector,
  1348. &tegra_hdmi_connector_helper_funcs);
  1349. hdmi->output.connector.dpms = DRM_MODE_DPMS_OFF;
  1350. drm_connector_attach_encoder(&hdmi->output.connector,
  1351. &hdmi->output.encoder);
  1352. drm_connector_register(&hdmi->output.connector);
  1353. }
  1354. err = tegra_output_init(drm, &hdmi->output);
  1355. if (err < 0) {
  1356. dev_err(client->dev, "failed to initialize output: %d\n", err);
  1357. return err;
  1358. }
  1359. hdmi->output.encoder.possible_crtcs = 0x3;
  1360. err = regulator_enable(hdmi->hdmi);
  1361. if (err < 0) {
  1362. dev_err(client->dev, "failed to enable HDMI regulator: %d\n",
  1363. err);
  1364. goto output_exit;
  1365. }
  1366. err = regulator_enable(hdmi->pll);
  1367. if (err < 0) {
  1368. dev_err(hdmi->dev, "failed to enable PLL regulator: %d\n", err);
  1369. goto disable_hdmi;
  1370. }
  1371. err = regulator_enable(hdmi->vdd);
  1372. if (err < 0) {
  1373. dev_err(hdmi->dev, "failed to enable VDD regulator: %d\n", err);
  1374. goto disable_pll;
  1375. }
  1376. err = tegra_hdmi_codec_register(hdmi);
  1377. if (err < 0) {
  1378. dev_err(hdmi->dev, "failed to register audio codec: %d\n", err);
  1379. goto disable_vdd;
  1380. }
  1381. return 0;
  1382. disable_vdd:
  1383. regulator_disable(hdmi->vdd);
  1384. disable_pll:
  1385. regulator_disable(hdmi->pll);
  1386. disable_hdmi:
  1387. regulator_disable(hdmi->hdmi);
  1388. output_exit:
  1389. tegra_output_exit(&hdmi->output);
  1390. return err;
  1391. }
  1392. static int tegra_hdmi_exit(struct host1x_client *client)
  1393. {
  1394. struct tegra_hdmi *hdmi = host1x_client_to_hdmi(client);
  1395. tegra_hdmi_codec_unregister(hdmi);
  1396. tegra_output_exit(&hdmi->output);
  1397. regulator_disable(hdmi->vdd);
  1398. regulator_disable(hdmi->pll);
  1399. regulator_disable(hdmi->hdmi);
  1400. return 0;
  1401. }
  1402. static int tegra_hdmi_runtime_suspend(struct host1x_client *client)
  1403. {
  1404. struct tegra_hdmi *hdmi = host1x_client_to_hdmi(client);
  1405. struct device *dev = client->dev;
  1406. int err;
  1407. err = reset_control_assert(hdmi->rst);
  1408. if (err < 0) {
  1409. dev_err(dev, "failed to assert reset: %d\n", err);
  1410. return err;
  1411. }
  1412. usleep_range(1000, 2000);
  1413. clk_disable_unprepare(hdmi->clk);
  1414. pm_runtime_put_sync(dev);
  1415. return 0;
  1416. }
  1417. static int tegra_hdmi_runtime_resume(struct host1x_client *client)
  1418. {
  1419. struct tegra_hdmi *hdmi = host1x_client_to_hdmi(client);
  1420. struct device *dev = client->dev;
  1421. int err;
  1422. err = pm_runtime_resume_and_get(dev);
  1423. if (err < 0) {
  1424. dev_err(dev, "failed to get runtime PM: %d\n", err);
  1425. return err;
  1426. }
  1427. err = clk_prepare_enable(hdmi->clk);
  1428. if (err < 0) {
  1429. dev_err(dev, "failed to enable clock: %d\n", err);
  1430. goto put_rpm;
  1431. }
  1432. usleep_range(1000, 2000);
  1433. err = reset_control_deassert(hdmi->rst);
  1434. if (err < 0) {
  1435. dev_err(dev, "failed to deassert reset: %d\n", err);
  1436. goto disable_clk;
  1437. }
  1438. return 0;
  1439. disable_clk:
  1440. clk_disable_unprepare(hdmi->clk);
  1441. put_rpm:
  1442. pm_runtime_put_sync(dev);
  1443. return err;
  1444. }
  1445. static const struct host1x_client_ops hdmi_client_ops = {
  1446. .init = tegra_hdmi_init,
  1447. .exit = tegra_hdmi_exit,
  1448. .suspend = tegra_hdmi_runtime_suspend,
  1449. .resume = tegra_hdmi_runtime_resume,
  1450. };
  1451. static const struct tegra_hdmi_config tegra20_hdmi_config = {
  1452. .tmds = tegra20_tmds_config,
  1453. .num_tmds = ARRAY_SIZE(tegra20_tmds_config),
  1454. .fuse_override_offset = HDMI_NV_PDISP_SOR_LANE_DRIVE_CURRENT,
  1455. .fuse_override_value = 1 << 31,
  1456. .has_sor_io_peak_current = false,
  1457. .has_hda = false,
  1458. .has_hbr = false,
  1459. };
  1460. static const struct tegra_hdmi_config tegra30_hdmi_config = {
  1461. .tmds = tegra30_tmds_config,
  1462. .num_tmds = ARRAY_SIZE(tegra30_tmds_config),
  1463. .fuse_override_offset = HDMI_NV_PDISP_SOR_LANE_DRIVE_CURRENT,
  1464. .fuse_override_value = 1 << 31,
  1465. .has_sor_io_peak_current = false,
  1466. .has_hda = true,
  1467. .has_hbr = false,
  1468. };
  1469. static const struct tegra_hdmi_config tegra114_hdmi_config = {
  1470. .tmds = tegra114_tmds_config,
  1471. .num_tmds = ARRAY_SIZE(tegra114_tmds_config),
  1472. .fuse_override_offset = HDMI_NV_PDISP_SOR_PAD_CTLS0,
  1473. .fuse_override_value = 1 << 31,
  1474. .has_sor_io_peak_current = true,
  1475. .has_hda = true,
  1476. .has_hbr = true,
  1477. };
  1478. static const struct tegra_hdmi_config tegra124_hdmi_config = {
  1479. .tmds = tegra124_tmds_config,
  1480. .num_tmds = ARRAY_SIZE(tegra124_tmds_config),
  1481. .fuse_override_offset = HDMI_NV_PDISP_SOR_PAD_CTLS0,
  1482. .fuse_override_value = 1 << 31,
  1483. .has_sor_io_peak_current = true,
  1484. .has_hda = true,
  1485. .has_hbr = true,
  1486. };
  1487. static const struct of_device_id tegra_hdmi_of_match[] = {
  1488. { .compatible = "nvidia,tegra124-hdmi", .data = &tegra124_hdmi_config },
  1489. { .compatible = "nvidia,tegra114-hdmi", .data = &tegra114_hdmi_config },
  1490. { .compatible = "nvidia,tegra30-hdmi", .data = &tegra30_hdmi_config },
  1491. { .compatible = "nvidia,tegra20-hdmi", .data = &tegra20_hdmi_config },
  1492. { },
  1493. };
  1494. MODULE_DEVICE_TABLE(of, tegra_hdmi_of_match);
  1495. static irqreturn_t tegra_hdmi_irq(int irq, void *data)
  1496. {
  1497. struct tegra_hdmi *hdmi = data;
  1498. u32 value;
  1499. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_INT_STATUS);
  1500. tegra_hdmi_writel(hdmi, value, HDMI_NV_PDISP_INT_STATUS);
  1501. if (value & INT_CODEC_SCRATCH0) {
  1502. unsigned int format;
  1503. u32 value;
  1504. value = tegra_hdmi_readl(hdmi, HDMI_NV_PDISP_SOR_AUDIO_HDA_CODEC_SCRATCH0);
  1505. if (value & SOR_AUDIO_HDA_CODEC_SCRATCH0_VALID) {
  1506. format = value & SOR_AUDIO_HDA_CODEC_SCRATCH0_FMT_MASK;
  1507. tegra_hda_parse_format(format, &hdmi->format);
  1508. tegra_hdmi_reconfigure_audio(hdmi);
  1509. } else {
  1510. tegra_hdmi_disable_audio_infoframe(hdmi);
  1511. tegra_hdmi_disable_audio(hdmi);
  1512. }
  1513. }
  1514. return IRQ_HANDLED;
  1515. }
  1516. static int tegra_hdmi_probe(struct platform_device *pdev)
  1517. {
  1518. struct tegra_hdmi *hdmi;
  1519. int err;
  1520. hdmi = devm_kzalloc(&pdev->dev, sizeof(*hdmi), GFP_KERNEL);
  1521. if (!hdmi)
  1522. return -ENOMEM;
  1523. hdmi->config = of_device_get_match_data(&pdev->dev);
  1524. hdmi->dev = &pdev->dev;
  1525. hdmi->audio_source = AUTO;
  1526. hdmi->stereo = false;
  1527. hdmi->dvi = false;
  1528. mutex_init(&hdmi->audio_lock);
  1529. hdmi->clk = devm_clk_get(&pdev->dev, NULL);
  1530. if (IS_ERR(hdmi->clk)) {
  1531. dev_err(&pdev->dev, "failed to get clock\n");
  1532. return PTR_ERR(hdmi->clk);
  1533. }
  1534. hdmi->rst = devm_reset_control_get(&pdev->dev, "hdmi");
  1535. if (IS_ERR(hdmi->rst)) {
  1536. dev_err(&pdev->dev, "failed to get reset\n");
  1537. return PTR_ERR(hdmi->rst);
  1538. }
  1539. hdmi->clk_parent = devm_clk_get(&pdev->dev, "parent");
  1540. if (IS_ERR(hdmi->clk_parent))
  1541. return PTR_ERR(hdmi->clk_parent);
  1542. err = clk_set_parent(hdmi->clk, hdmi->clk_parent);
  1543. if (err < 0) {
  1544. dev_err(&pdev->dev, "failed to setup clocks: %d\n", err);
  1545. return err;
  1546. }
  1547. hdmi->hdmi = devm_regulator_get(&pdev->dev, "hdmi");
  1548. err = PTR_ERR_OR_ZERO(hdmi->hdmi);
  1549. if (err)
  1550. return dev_err_probe(&pdev->dev, err,
  1551. "failed to get HDMI regulator\n");
  1552. hdmi->pll = devm_regulator_get(&pdev->dev, "pll");
  1553. err = PTR_ERR_OR_ZERO(hdmi->pll);
  1554. if (err)
  1555. return dev_err_probe(&pdev->dev, err,
  1556. "failed to get PLL regulator\n");
  1557. hdmi->vdd = devm_regulator_get(&pdev->dev, "vdd");
  1558. err = PTR_ERR_OR_ZERO(hdmi->vdd);
  1559. if (err)
  1560. return dev_err_probe(&pdev->dev, err,
  1561. "failed to get VDD regulator\n");
  1562. hdmi->output.dev = &pdev->dev;
  1563. err = tegra_output_probe(&hdmi->output);
  1564. if (err < 0)
  1565. return err;
  1566. hdmi->regs = devm_platform_ioremap_resource(pdev, 0);
  1567. if (IS_ERR(hdmi->regs)) {
  1568. err = PTR_ERR(hdmi->regs);
  1569. goto remove;
  1570. }
  1571. err = platform_get_irq(pdev, 0);
  1572. if (err < 0)
  1573. goto remove;
  1574. hdmi->irq = err;
  1575. err = devm_request_irq(hdmi->dev, hdmi->irq, tegra_hdmi_irq, 0,
  1576. dev_name(hdmi->dev), hdmi);
  1577. if (err < 0) {
  1578. dev_err(&pdev->dev, "failed to request IRQ#%u: %d\n",
  1579. hdmi->irq, err);
  1580. goto remove;
  1581. }
  1582. platform_set_drvdata(pdev, hdmi);
  1583. err = devm_pm_runtime_enable(&pdev->dev);
  1584. if (err)
  1585. goto remove;
  1586. err = devm_tegra_core_dev_init_opp_table_common(&pdev->dev);
  1587. if (err)
  1588. goto remove;
  1589. INIT_LIST_HEAD(&hdmi->client.list);
  1590. hdmi->client.ops = &hdmi_client_ops;
  1591. hdmi->client.dev = &pdev->dev;
  1592. err = host1x_client_register(&hdmi->client);
  1593. if (err < 0) {
  1594. dev_err(&pdev->dev, "failed to register host1x client: %d\n",
  1595. err);
  1596. goto remove;
  1597. }
  1598. return 0;
  1599. remove:
  1600. tegra_output_remove(&hdmi->output);
  1601. return err;
  1602. }
  1603. static void tegra_hdmi_remove(struct platform_device *pdev)
  1604. {
  1605. struct tegra_hdmi *hdmi = platform_get_drvdata(pdev);
  1606. host1x_client_unregister(&hdmi->client);
  1607. tegra_output_remove(&hdmi->output);
  1608. }
  1609. struct platform_driver tegra_hdmi_driver = {
  1610. .driver = {
  1611. .name = "tegra-hdmi",
  1612. .of_match_table = tegra_hdmi_of_match,
  1613. },
  1614. .probe = tegra_hdmi_probe,
  1615. .remove = tegra_hdmi_remove,
  1616. };