dsi_ctrl.h 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2015-2019, The Linux Foundation. All rights reserved.
  4. */
  5. #ifndef _DSI_CTRL_H_
  6. #define _DSI_CTRL_H_
  7. #include <linux/debugfs.h>
  8. #include "dsi_defs.h"
  9. #include "dsi_ctrl_hw.h"
  10. #include "dsi_clk.h"
  11. #include "dsi_pwr.h"
  12. #include "drm_mipi_dsi.h"
  13. /*
  14. * DSI Command transfer modifiers
  15. * @DSI_CTRL_CMD_READ: The current transfer involves reading data.
  16. * @DSI_CTRL_CMD_BROADCAST: The current transfer needs to be done in
  17. * broadcast mode to multiple slaves.
  18. * @DSI_CTRL_CMD_BROADCAST_MASTER: This controller is the master and the slaves
  19. * sync to this trigger.
  20. * @DSI_CTRL_CMD_DEFER_TRIGGER: Defer the command trigger to later.
  21. * @DSI_CTRL_CMD_FIFO_STORE: Use FIFO for command transfer in place of
  22. * reading data from memory.
  23. * @DSI_CTRL_CMD_FETCH_MEMORY: Fetch command from memory through AXI bus
  24. * and transfer it.
  25. * @DSI_CTRL_CMD_LAST_COMMAND: Trigger the DMA cmd transfer if this is last
  26. * command in the batch.
  27. * @DSI_CTRL_CMD_NON_EMBEDDED_MODE:Transfer cmd packets in non embedded mode.
  28. * @DSI_CTRL_CMD_CUSTOM_DMA_SCHED: Use the dma scheduling line number defined in
  29. * display panel dtsi file instead of default.
  30. * @DSI_CTRL_CMD_ASYNC_WAIT: Command flag to indicate that the wait for done
  31. * for this command is asynchronous and must be queued.
  32. */
  33. #define DSI_CTRL_CMD_READ 0x1
  34. #define DSI_CTRL_CMD_BROADCAST 0x2
  35. #define DSI_CTRL_CMD_BROADCAST_MASTER 0x4
  36. #define DSI_CTRL_CMD_DEFER_TRIGGER 0x8
  37. #define DSI_CTRL_CMD_FIFO_STORE 0x10
  38. #define DSI_CTRL_CMD_FETCH_MEMORY 0x20
  39. #define DSI_CTRL_CMD_LAST_COMMAND 0x40
  40. #define DSI_CTRL_CMD_NON_EMBEDDED_MODE 0x80
  41. #define DSI_CTRL_CMD_CUSTOM_DMA_SCHED 0x100
  42. #define DSI_CTRL_CMD_ASYNC_WAIT 0x200
  43. /* DSI embedded mode fifo size
  44. * If the command is greater than 256 bytes it is sent in non-embedded mode.
  45. */
  46. #define DSI_EMBEDDED_MODE_DMA_MAX_SIZE_BYTES 256
  47. /* max size supported for dsi cmd transfer using TPG */
  48. #define DSI_CTRL_MAX_CMD_FIFO_STORE_SIZE 64
  49. /**
  50. * enum dsi_power_state - defines power states for dsi controller.
  51. * @DSI_CTRL_POWER_VREG_OFF: Digital and analog supplies for DSI controller
  52. turned off
  53. * @DSI_CTRL_POWER_VREG_ON: Digital and analog supplies for DSI controller
  54. * @DSI_CTRL_POWER_MAX: Maximum value.
  55. */
  56. enum dsi_power_state {
  57. DSI_CTRL_POWER_VREG_OFF = 0,
  58. DSI_CTRL_POWER_VREG_ON,
  59. DSI_CTRL_POWER_MAX,
  60. };
  61. /**
  62. * enum dsi_engine_state - define engine status for dsi controller.
  63. * @DSI_CTRL_ENGINE_OFF: Engine is turned off.
  64. * @DSI_CTRL_ENGINE_ON: Engine is turned on.
  65. * @DSI_CTRL_ENGINE_MAX: Maximum value.
  66. */
  67. enum dsi_engine_state {
  68. DSI_CTRL_ENGINE_OFF = 0,
  69. DSI_CTRL_ENGINE_ON,
  70. DSI_CTRL_ENGINE_MAX,
  71. };
  72. /**
  73. * enum dsi_ctrl_driver_ops - controller driver ops
  74. */
  75. enum dsi_ctrl_driver_ops {
  76. DSI_CTRL_OP_POWER_STATE_CHANGE,
  77. DSI_CTRL_OP_CMD_ENGINE,
  78. DSI_CTRL_OP_VID_ENGINE,
  79. DSI_CTRL_OP_HOST_ENGINE,
  80. DSI_CTRL_OP_CMD_TX,
  81. DSI_CTRL_OP_HOST_INIT,
  82. DSI_CTRL_OP_TPG,
  83. DSI_CTRL_OP_PHY_SW_RESET,
  84. DSI_CTRL_OP_ASYNC_TIMING,
  85. DSI_CTRL_OP_MAX
  86. };
  87. /**
  88. * struct dsi_ctrl_power_info - digital and analog power supplies for dsi host
  89. * @digital: Digital power supply required to turn on DSI controller hardware.
  90. * @host_pwr: Analog power supplies required to turn on DSI controller hardware.
  91. * Even though DSI controller it self does not require an analog
  92. * power supply, supplies required for PLL can be defined here to
  93. * allow proper control over these supplies.
  94. */
  95. struct dsi_ctrl_power_info {
  96. struct dsi_regulator_info digital;
  97. struct dsi_regulator_info host_pwr;
  98. };
  99. /**
  100. * struct dsi_ctrl_clk_info - clock information for DSI controller
  101. * @core_clks: Core clocks needed to access DSI controller registers.
  102. * @hs_link_clks: Clocks required to transmit high speed data over DSI
  103. * @lp_link_clks: Clocks required to perform low power ops over DSI
  104. * @rcg_clks: Root clock generation clocks generated in MMSS_CC. The
  105. * output of the PLL is set as parent for these root
  106. * clocks. These clocks are specific to controller
  107. * instance.
  108. * @mux_clks: Mux clocks used for Dynamic refresh feature.
  109. * @ext_clks: External byte/pixel clocks from the MMSS block. These
  110. * clocks are set as parent to rcg clocks.
  111. * @pll_op_clks: TODO:
  112. * @shadow_clks: TODO:
  113. */
  114. struct dsi_ctrl_clk_info {
  115. /* Clocks parsed from DT */
  116. struct dsi_core_clk_info core_clks;
  117. struct dsi_link_hs_clk_info hs_link_clks;
  118. struct dsi_link_lp_clk_info lp_link_clks;
  119. struct dsi_clk_link_set rcg_clks;
  120. /* Clocks set by DSI Manager */
  121. struct dsi_clk_link_set mux_clks;
  122. struct dsi_clk_link_set ext_clks;
  123. struct dsi_clk_link_set pll_op_clks;
  124. struct dsi_clk_link_set shadow_clks;
  125. };
  126. /**
  127. * struct dsi_ctrl_state_info - current driver state information
  128. * @power_state: Status of power states on DSI controller.
  129. * @cmd_engine_state: Status of DSI command engine.
  130. * @vid_engine_state: Status of DSI video engine.
  131. * @controller_state: Status of DSI Controller engine.
  132. * @host_initialized: Boolean to indicate status of DSi host Initialization
  133. * @tpg_enabled: Boolean to indicate whether tpg is enabled.
  134. */
  135. struct dsi_ctrl_state_info {
  136. enum dsi_power_state power_state;
  137. enum dsi_engine_state cmd_engine_state;
  138. enum dsi_engine_state vid_engine_state;
  139. enum dsi_engine_state controller_state;
  140. bool host_initialized;
  141. bool tpg_enabled;
  142. };
  143. /**
  144. * struct dsi_ctrl_interrupts - define interrupt information
  145. * @irq_lock: Spinlock for ISR handler.
  146. * @irq_num: Linux interrupt number associated with device.
  147. * @irq_stat_mask: Hardware mask of currently enabled interrupts.
  148. * @irq_stat_refcount: Number of times each interrupt has been requested.
  149. * @irq_stat_cb: Status IRQ callback definitions.
  150. * @irq_err_cb: IRQ callback definition to handle DSI ERRORs.
  151. * @cmd_dma_done: Completion signal for DSI_CMD_MODE_DMA_DONE interrupt
  152. * @vid_frame_done: Completion signal for DSI_VIDEO_MODE_FRAME_DONE int.
  153. * @cmd_frame_done: Completion signal for DSI_CMD_FRAME_DONE interrupt.
  154. */
  155. struct dsi_ctrl_interrupts {
  156. spinlock_t irq_lock;
  157. int irq_num;
  158. uint32_t irq_stat_mask;
  159. int irq_stat_refcount[DSI_STATUS_INTERRUPT_COUNT];
  160. struct dsi_event_cb_info irq_stat_cb[DSI_STATUS_INTERRUPT_COUNT];
  161. struct dsi_event_cb_info irq_err_cb;
  162. struct completion cmd_dma_done;
  163. struct completion vid_frame_done;
  164. struct completion cmd_frame_done;
  165. struct completion bta_done;
  166. };
  167. /**
  168. * struct dsi_ctrl - DSI controller object
  169. * @pdev: Pointer to platform device.
  170. * @cell_index: Instance cell id.
  171. * @horiz_index: Index in physical horizontal CTRL layout, 0 = leftmost
  172. * @name: Name of the controller instance.
  173. * @refcount: ref counter.
  174. * @ctrl_lock: Mutex for hardware and object access.
  175. * @drm_dev: Pointer to DRM device.
  176. * @version: DSI controller version.
  177. * @hw: DSI controller hardware object.
  178. * @current_state: Current driver and hardware state.
  179. * @clk_cb: Callback for DSI clock control.
  180. * @irq_info: Interrupt information.
  181. * @recovery_cb: Recovery call back to SDE.
  182. * @clk_info: Clock information.
  183. * @clk_freq: DSi Link clock frequency information.
  184. * @pwr_info: Power information.
  185. * @host_config: Current host configuration.
  186. * @mode_bounds: Boundaries of the default mode ROI.
  187. * Origin is at top left of all CTRLs.
  188. * @roi: Partial update region of interest.
  189. * Origin is top left of this CTRL.
  190. * @tx_cmd_buf: Tx command buffer.
  191. * @cmd_buffer_iova: cmd buffer mapped address.
  192. * @cmd_buffer_size: Size of command buffer.
  193. * @vaddr: CPU virtual address of cmd buffer.
  194. * @secure_mode: Indicates if secure-session is in progress
  195. * @esd_check_underway: Indicates if esd status check is in progress
  196. * @dma_cmd_wait: Work object waiting on DMA command transfer done.
  197. * @dma_cmd_workq: Pointer to the workqueue of DMA command transfer done
  198. * wait sequence.
  199. * @dma_wait_queued: Indicates if any DMA command transfer wait work
  200. * is queued.
  201. * @dma_irq_trig: Atomic state to indicate DMA done IRQ
  202. * triggered.
  203. * @debugfs_root: Root for debugfs entries.
  204. * @misr_enable: Frame MISR enable/disable
  205. * @misr_cache: Cached Frame MISR value
  206. * @frame_threshold_time_us: Frame threshold time in microseconds, where
  207. * dsi data lane will be idle i.e from pingpong done to
  208. * next TE for command mode.
  209. * @phy_isolation_enabled: A boolean property allows to isolate the phy from
  210. * dsi controller and run only dsi controller.
  211. * @null_insertion_enabled: A boolean property to allow dsi controller to
  212. * insert null packet.
  213. * @modeupdated: Boolean to send new roi if mode is updated.
  214. * @split_link_supported: Boolean to check if hw supports split link.
  215. */
  216. struct dsi_ctrl {
  217. struct platform_device *pdev;
  218. u32 cell_index;
  219. u32 horiz_index;
  220. const char *name;
  221. u32 refcount;
  222. struct mutex ctrl_lock;
  223. struct drm_device *drm_dev;
  224. enum dsi_ctrl_version version;
  225. struct dsi_ctrl_hw hw;
  226. /* Current state */
  227. struct dsi_ctrl_state_info current_state;
  228. struct clk_ctrl_cb clk_cb;
  229. struct dsi_ctrl_interrupts irq_info;
  230. struct dsi_event_cb_info recovery_cb;
  231. /* Clock and power states */
  232. struct dsi_ctrl_clk_info clk_info;
  233. struct link_clk_freq clk_freq;
  234. struct dsi_ctrl_power_info pwr_info;
  235. struct dsi_host_config host_config;
  236. struct dsi_rect mode_bounds;
  237. struct dsi_rect roi;
  238. /* Command tx and rx */
  239. struct drm_gem_object *tx_cmd_buf;
  240. u32 cmd_buffer_size;
  241. u32 cmd_buffer_iova;
  242. u32 cmd_len;
  243. void *vaddr;
  244. bool secure_mode;
  245. bool esd_check_underway;
  246. struct work_struct dma_cmd_wait;
  247. struct workqueue_struct *dma_cmd_workq;
  248. bool dma_wait_queued;
  249. atomic_t dma_irq_trig;
  250. /* Debug Information */
  251. struct dentry *debugfs_root;
  252. /* MISR */
  253. bool misr_enable;
  254. u32 misr_cache;
  255. u32 frame_threshold_time_us;
  256. /* Check for spurious interrupts */
  257. unsigned long jiffies_start;
  258. unsigned int error_interrupt_count;
  259. bool phy_isolation_enabled;
  260. bool null_insertion_enabled;
  261. bool modeupdated;
  262. bool split_link_supported;
  263. };
  264. /**
  265. * dsi_ctrl_get() - get a dsi_ctrl handle from an of_node
  266. * @of_node: of_node of the DSI controller.
  267. *
  268. * Gets the DSI controller handle for the corresponding of_node. The ref count
  269. * is incremented to one and all subsequent gets will fail until the original
  270. * clients calls a put.
  271. *
  272. * Return: DSI Controller handle.
  273. */
  274. struct dsi_ctrl *dsi_ctrl_get(struct device_node *of_node);
  275. /**
  276. * dsi_ctrl_put() - releases a dsi controller handle.
  277. * @dsi_ctrl: DSI controller handle.
  278. *
  279. * Releases the DSI controller. Driver will clean up all resources and puts back
  280. * the DSI controller into reset state.
  281. */
  282. void dsi_ctrl_put(struct dsi_ctrl *dsi_ctrl);
  283. /**
  284. * dsi_ctrl_drv_init() - initialize dsi controller driver.
  285. * @dsi_ctrl: DSI controller handle.
  286. * @parent: Parent directory for debug fs.
  287. *
  288. * Initializes DSI controller driver. Driver should be initialized after
  289. * dsi_ctrl_get() succeeds.
  290. *
  291. * Return: error code.
  292. */
  293. int dsi_ctrl_drv_init(struct dsi_ctrl *dsi_ctrl, struct dentry *parent);
  294. /**
  295. * dsi_ctrl_drv_deinit() - de-initializes dsi controller driver
  296. * @dsi_ctrl: DSI controller handle.
  297. *
  298. * Releases all resources acquired by dsi_ctrl_drv_init().
  299. *
  300. * Return: error code.
  301. */
  302. int dsi_ctrl_drv_deinit(struct dsi_ctrl *dsi_ctrl);
  303. /**
  304. * dsi_ctrl_validate_timing() - validate a video timing configuration
  305. * @dsi_ctrl: DSI controller handle.
  306. * @timing: Pointer to timing data.
  307. *
  308. * Driver will validate if the timing configuration is supported on the
  309. * controller hardware.
  310. *
  311. * Return: error code if timing is not supported.
  312. */
  313. int dsi_ctrl_validate_timing(struct dsi_ctrl *dsi_ctrl,
  314. struct dsi_mode_info *timing);
  315. /**
  316. * dsi_ctrl_update_host_config() - update dsi host configuration
  317. * @dsi_ctrl: DSI controller handle.
  318. * @config: DSI host configuration.
  319. * @mode: DSI host mode selected.
  320. * @flags: dsi_mode_flags modifying the behavior
  321. * @clk_handle: Clock handle for DSI clocks
  322. *
  323. * Updates driver with new Host configuration to use for host initialization.
  324. * This function call will only update the software context. The stored
  325. * configuration information will be used when the host is initialized.
  326. *
  327. * Return: error code.
  328. */
  329. int dsi_ctrl_update_host_config(struct dsi_ctrl *dsi_ctrl,
  330. struct dsi_host_config *config,
  331. struct dsi_display_mode *mode, int flags,
  332. void *clk_handle);
  333. /**
  334. * dsi_ctrl_timing_db_update() - update only controller Timing DB
  335. * @dsi_ctrl: DSI controller handle.
  336. * @enable: Enable/disable Timing DB register
  337. *
  338. * Update timing db register value during dfps usecases
  339. *
  340. * Return: error code.
  341. */
  342. int dsi_ctrl_timing_db_update(struct dsi_ctrl *dsi_ctrl,
  343. bool enable);
  344. /**
  345. * dsi_ctrl_async_timing_update() - update only controller timing
  346. * @dsi_ctrl: DSI controller handle.
  347. * @timing: New DSI timing info
  348. *
  349. * Updates host timing values to asynchronously transition to new timing
  350. * For example, to update the porch values in a seamless/dynamic fps switch.
  351. *
  352. * Return: error code.
  353. */
  354. int dsi_ctrl_async_timing_update(struct dsi_ctrl *dsi_ctrl,
  355. struct dsi_mode_info *timing);
  356. /**
  357. * dsi_ctrl_phy_sw_reset() - perform a PHY software reset
  358. * @dsi_ctrl: DSI controller handle.
  359. *
  360. * Performs a PHY software reset on the DSI controller. Reset should be done
  361. * when the controller power state is DSI_CTRL_POWER_CORE_CLK_ON and the PHY is
  362. * not enabled.
  363. *
  364. * This function will fail if driver is in any other state.
  365. *
  366. * Return: error code.
  367. */
  368. int dsi_ctrl_phy_sw_reset(struct dsi_ctrl *dsi_ctrl);
  369. /**
  370. * dsi_ctrl_phy_reset_config() - Mask/unmask propagation of ahb reset signal
  371. * to DSI PHY hardware.
  372. * @dsi_ctrl: DSI controller handle.
  373. * @enable: Mask/unmask the PHY reset signal.
  374. *
  375. * Return: error code.
  376. */
  377. int dsi_ctrl_phy_reset_config(struct dsi_ctrl *dsi_ctrl, bool enable);
  378. /**
  379. * dsi_ctrl_config_clk_gating() - Enable/Disable DSI PHY clk gating
  380. * @dsi_ctrl: DSI controller handle.
  381. * @enable: Enable/disable DSI PHY clk gating
  382. * @clk_selection: clock selection for gating
  383. *
  384. * Return: error code.
  385. */
  386. int dsi_ctrl_config_clk_gating(struct dsi_ctrl *dsi_ctrl, bool enable,
  387. enum dsi_clk_gate_type clk_selection);
  388. /**
  389. * dsi_ctrl_soft_reset() - perform a soft reset on DSI controller
  390. * @dsi_ctrl: DSI controller handle.
  391. *
  392. * The video, command and controller engines will be disabled before the
  393. * reset is triggered. After, the engines will be re-enabled to the same state
  394. * as before the reset.
  395. *
  396. * If the reset is done while MDP timing engine is turned on, the video
  397. * engine should be re-enabled only during the vertical blanking time.
  398. *
  399. * Return: error code
  400. */
  401. int dsi_ctrl_soft_reset(struct dsi_ctrl *dsi_ctrl);
  402. /**
  403. * dsi_ctrl_host_timing_update - reinitialize host with new timing values
  404. * @dsi_ctrl: DSI controller handle.
  405. *
  406. * Reinitialize DSI controller hardware with new display timing values
  407. * when resolution is switched dynamically.
  408. *
  409. * Return: error code
  410. */
  411. int dsi_ctrl_host_timing_update(struct dsi_ctrl *dsi_ctrl);
  412. /**
  413. * dsi_ctrl_host_init() - Initialize DSI host hardware.
  414. * @dsi_ctrl: DSI controller handle.
  415. * @is_splash_enabled: boolean signifying splash status.
  416. *
  417. * Initializes DSI controller hardware with host configuration provided by
  418. * dsi_ctrl_update_host_config(). Initialization can be performed only during
  419. * DSI_CTRL_POWER_CORE_CLK_ON state and after the PHY SW reset has been
  420. * performed.
  421. *
  422. * Return: error code.
  423. */
  424. int dsi_ctrl_host_init(struct dsi_ctrl *dsi_ctrl, bool is_splash_enabled);
  425. /**
  426. * dsi_ctrl_host_deinit() - De-Initialize DSI host hardware.
  427. * @dsi_ctrl: DSI controller handle.
  428. *
  429. * De-initializes DSI controller hardware. It can be performed only during
  430. * DSI_CTRL_POWER_CORE_CLK_ON state after LINK clocks have been turned off.
  431. *
  432. * Return: error code.
  433. */
  434. int dsi_ctrl_host_deinit(struct dsi_ctrl *dsi_ctrl);
  435. /**
  436. * dsi_ctrl_set_ulps() - set ULPS state for DSI lanes.
  437. * @dsi_ctrl: DSI controller handle.
  438. * @enable: enable/disable ULPS.
  439. *
  440. * ULPS can be enabled/disabled after DSI host engine is turned on.
  441. *
  442. * Return: error code.
  443. */
  444. int dsi_ctrl_set_ulps(struct dsi_ctrl *dsi_ctrl, bool enable);
  445. /**
  446. * dsi_ctrl_timing_setup() - Setup DSI host config
  447. * @dsi_ctrl: DSI controller handle.
  448. *
  449. * Initializes DSI controller hardware with host configuration provided by
  450. * dsi_ctrl_update_host_config(). This is called while setting up DSI host
  451. * through dsi_ctrl_setup() and after any ROI change.
  452. *
  453. * Also used to program the video mode timing values.
  454. *
  455. * Return: error code.
  456. */
  457. int dsi_ctrl_timing_setup(struct dsi_ctrl *dsi_ctrl);
  458. /**
  459. * dsi_ctrl_setup() - Setup DSI host hardware while coming out of idle screen.
  460. * @dsi_ctrl: DSI controller handle.
  461. *
  462. * Initialization of DSI controller hardware with host configuration and
  463. * enabling required interrupts. Initialization can be performed only during
  464. * DSI_CTRL_POWER_CORE_CLK_ON state and after the PHY SW reset has been
  465. * performed.
  466. *
  467. * Return: error code.
  468. */
  469. int dsi_ctrl_setup(struct dsi_ctrl *dsi_ctrl);
  470. /**
  471. * dsi_ctrl_set_roi() - Set DSI controller's region of interest
  472. * @dsi_ctrl: DSI controller handle.
  473. * @roi: Region of interest rectangle, must be less than mode bounds
  474. * @changed: Output parameter, set to true of the controller's ROI was
  475. * dirtied by setting the new ROI, and DCS cmd update needed
  476. *
  477. * Return: error code.
  478. */
  479. int dsi_ctrl_set_roi(struct dsi_ctrl *dsi_ctrl, struct dsi_rect *roi,
  480. bool *changed);
  481. /**
  482. * dsi_ctrl_set_tpg_state() - enable/disable test pattern on the controller
  483. * @dsi_ctrl: DSI controller handle.
  484. * @on: enable/disable test pattern.
  485. *
  486. * Test pattern can be enabled only after Video engine (for video mode panels)
  487. * or command engine (for cmd mode panels) is enabled.
  488. *
  489. * Return: error code.
  490. */
  491. int dsi_ctrl_set_tpg_state(struct dsi_ctrl *dsi_ctrl, bool on);
  492. /**
  493. * dsi_ctrl_cmd_transfer() - Transfer commands on DSI link
  494. * @dsi_ctrl: DSI controller handle.
  495. * @msg: Message to transfer on DSI link.
  496. * @flags: Modifiers for message transfer.
  497. *
  498. * Command transfer can be done only when command engine is enabled. The
  499. * transfer API will until either the command transfer finishes or the timeout
  500. * value is reached. If the trigger is deferred, it will return without
  501. * triggering the transfer. Command parameters are programmed to hardware.
  502. *
  503. * Return: error code.
  504. */
  505. int dsi_ctrl_cmd_transfer(struct dsi_ctrl *dsi_ctrl,
  506. const struct mipi_dsi_msg *msg,
  507. u32 flags);
  508. /**
  509. * dsi_ctrl_cmd_tx_trigger() - Trigger a deferred command.
  510. * @dsi_ctrl: DSI controller handle.
  511. * @flags: Modifiers.
  512. *
  513. * Return: error code.
  514. */
  515. int dsi_ctrl_cmd_tx_trigger(struct dsi_ctrl *dsi_ctrl, u32 flags);
  516. /**
  517. * dsi_ctrl_update_host_engine_state_for_cont_splash() - update engine
  518. * states for cont splash usecase
  519. * @dsi_ctrl: DSI controller handle.
  520. * @state: DSI engine state
  521. *
  522. * Return: error code.
  523. */
  524. int dsi_ctrl_update_host_engine_state_for_cont_splash(struct dsi_ctrl *dsi_ctrl,
  525. enum dsi_engine_state state);
  526. /**
  527. * dsi_ctrl_set_power_state() - set power state for dsi controller
  528. * @dsi_ctrl: DSI controller handle.
  529. * @state: Power state.
  530. *
  531. * Set power state for DSI controller. Power state can be changed only when
  532. * Controller, Video and Command engines are turned off.
  533. *
  534. * Return: error code.
  535. */
  536. int dsi_ctrl_set_power_state(struct dsi_ctrl *dsi_ctrl,
  537. enum dsi_power_state state);
  538. /**
  539. * dsi_ctrl_set_cmd_engine_state() - set command engine state
  540. * @dsi_ctrl: DSI Controller handle.
  541. * @state: Engine state.
  542. *
  543. * Command engine state can be modified only when DSI controller power state is
  544. * set to DSI_CTRL_POWER_LINK_CLK_ON.
  545. *
  546. * Return: error code.
  547. */
  548. int dsi_ctrl_set_cmd_engine_state(struct dsi_ctrl *dsi_ctrl,
  549. enum dsi_engine_state state);
  550. /**
  551. * dsi_ctrl_validate_host_state() - validate DSI ctrl host state
  552. * @dsi_ctrl: DSI Controller handle.
  553. *
  554. * Validate DSI cotroller host state
  555. *
  556. * Return: boolean indicating whether host is not initialized.
  557. */
  558. bool dsi_ctrl_validate_host_state(struct dsi_ctrl *dsi_ctrl);
  559. /**
  560. * dsi_ctrl_set_vid_engine_state() - set video engine state
  561. * @dsi_ctrl: DSI Controller handle.
  562. * @state: Engine state.
  563. *
  564. * Video engine state can be modified only when DSI controller power state is
  565. * set to DSI_CTRL_POWER_LINK_CLK_ON.
  566. *
  567. * Return: error code.
  568. */
  569. int dsi_ctrl_set_vid_engine_state(struct dsi_ctrl *dsi_ctrl,
  570. enum dsi_engine_state state);
  571. /**
  572. * dsi_ctrl_set_host_engine_state() - set host engine state
  573. * @dsi_ctrl: DSI Controller handle.
  574. * @state: Engine state.
  575. *
  576. * Host engine state can be modified only when DSI controller power state is
  577. * set to DSI_CTRL_POWER_LINK_CLK_ON and cmd, video engines are disabled.
  578. *
  579. * Return: error code.
  580. */
  581. int dsi_ctrl_set_host_engine_state(struct dsi_ctrl *dsi_ctrl,
  582. enum dsi_engine_state state);
  583. /**
  584. * dsi_ctrl_set_ulps() - set ULPS state for DSI lanes.
  585. * @dsi_ctrl: DSI controller handle.
  586. * @enable: enable/disable ULPS.
  587. *
  588. * ULPS can be enabled/disabled after DSI host engine is turned on.
  589. *
  590. * Return: error code.
  591. */
  592. int dsi_ctrl_set_ulps(struct dsi_ctrl *dsi_ctrl, bool enable);
  593. /**
  594. * dsi_ctrl_clk_cb_register() - Register DSI controller clk control callback
  595. * @dsi_ctrl: DSI controller handle.
  596. * @clk__cb: Structure containing callback for clock control.
  597. *
  598. * Register call for DSI clock control
  599. *
  600. * Return: error code.
  601. */
  602. int dsi_ctrl_clk_cb_register(struct dsi_ctrl *dsi_ctrl,
  603. struct clk_ctrl_cb *clk_cb);
  604. /**
  605. * dsi_ctrl_set_clamp_state() - set clamp state for DSI phy
  606. * @dsi_ctrl: DSI controller handle.
  607. * @enable: enable/disable clamping.
  608. * @ulps_enabled: ulps state.
  609. *
  610. * Clamps can be enabled/disabled while DSI controller is still turned on.
  611. *
  612. * Return: error code.
  613. */
  614. int dsi_ctrl_set_clamp_state(struct dsi_ctrl *dsi_Ctrl,
  615. bool enable, bool ulps_enabled);
  616. /**
  617. * dsi_ctrl_set_clock_source() - set clock source fpr dsi link clocks
  618. * @dsi_ctrl: DSI controller handle.
  619. * @source_clks: Source clocks for DSI link clocks.
  620. *
  621. * Clock source should be changed while link clocks are disabled.
  622. *
  623. * Return: error code.
  624. */
  625. int dsi_ctrl_set_clock_source(struct dsi_ctrl *dsi_ctrl,
  626. struct dsi_clk_link_set *source_clks);
  627. /**
  628. * dsi_ctrl_enable_status_interrupt() - enable status interrupts
  629. * @dsi_ctrl: DSI controller handle.
  630. * @intr_idx: Index interrupt to disable.
  631. * @event_info: Pointer to event callback definition
  632. */
  633. void dsi_ctrl_enable_status_interrupt(struct dsi_ctrl *dsi_ctrl,
  634. uint32_t intr_idx, struct dsi_event_cb_info *event_info);
  635. /**
  636. * dsi_ctrl_disable_status_interrupt() - disable status interrupts
  637. * @dsi_ctrl: DSI controller handle.
  638. * @intr_idx: Index interrupt to disable.
  639. */
  640. void dsi_ctrl_disable_status_interrupt(
  641. struct dsi_ctrl *dsi_ctrl, uint32_t intr_idx);
  642. /**
  643. * dsi_ctrl_setup_misr() - Setup frame MISR
  644. * @dsi_ctrl: DSI controller handle.
  645. * @enable: enable/disable MISR.
  646. * @frame_count: Number of frames to accumulate MISR.
  647. *
  648. * Return: error code.
  649. */
  650. int dsi_ctrl_setup_misr(struct dsi_ctrl *dsi_ctrl,
  651. bool enable,
  652. u32 frame_count);
  653. /**
  654. * dsi_ctrl_collect_misr() - Read frame MISR
  655. * @dsi_ctrl: DSI controller handle.
  656. *
  657. * Return: MISR value.
  658. */
  659. u32 dsi_ctrl_collect_misr(struct dsi_ctrl *dsi_ctrl);
  660. /**
  661. * dsi_ctrl_cache_misr - Cache frame MISR value
  662. * @dsi_ctrl: DSI controller handle.
  663. */
  664. void dsi_ctrl_cache_misr(struct dsi_ctrl *dsi_ctrl);
  665. /**
  666. * dsi_ctrl_drv_register() - register platform driver for dsi controller
  667. */
  668. void dsi_ctrl_drv_register(void);
  669. /**
  670. * dsi_ctrl_drv_unregister() - unregister platform driver
  671. */
  672. void dsi_ctrl_drv_unregister(void);
  673. /**
  674. * dsi_ctrl_reset() - Reset DSI PHY CLK/DATA lane
  675. * @dsi_ctrl: DSI controller handle.
  676. * @mask: Mask to indicate if CLK and/or DATA lane needs reset.
  677. */
  678. int dsi_ctrl_reset(struct dsi_ctrl *dsi_ctrl, int mask);
  679. /**
  680. * dsi_ctrl_get_hw_version() - read dsi controller hw revision
  681. * @dsi_ctrl: DSI controller handle.
  682. */
  683. int dsi_ctrl_get_hw_version(struct dsi_ctrl *dsi_ctrl);
  684. /**
  685. * dsi_ctrl_vid_engine_en() - Control DSI video engine HW state
  686. * @dsi_ctrl: DSI controller handle.
  687. * @on: variable to control video engine ON/OFF.
  688. */
  689. int dsi_ctrl_vid_engine_en(struct dsi_ctrl *dsi_ctrl, bool on);
  690. /**
  691. * dsi_ctrl_setup_avr() - Set/Clear the AVR_SUPPORT_ENABLE bit
  692. * @dsi_ctrl: DSI controller handle.
  693. * @enable: variable to control AVR support ON/OFF.
  694. */
  695. int dsi_ctrl_setup_avr(struct dsi_ctrl *dsi_ctrl, bool enable);
  696. /**
  697. * @dsi_ctrl: DSI controller handle.
  698. * cmd_len: Length of command.
  699. * flags: Config mode flags.
  700. */
  701. void dsi_message_setup_tx_mode(struct dsi_ctrl *dsi_ctrl, u32 cmd_len,
  702. u32 *flags);
  703. /**
  704. * @dsi_ctrl: DSI controller handle.
  705. * cmd_len: Length of command.
  706. * flags: Config mode flags.
  707. */
  708. int dsi_message_validate_tx_mode(struct dsi_ctrl *dsi_ctrl, u32 cmd_len,
  709. u32 *flags);
  710. /**
  711. * dsi_ctrl_isr_configure() - API to register/deregister dsi isr
  712. * @dsi_ctrl: DSI controller handle.
  713. * @enable: variable to control register/deregister isr
  714. */
  715. void dsi_ctrl_isr_configure(struct dsi_ctrl *dsi_ctrl, bool enable);
  716. /**
  717. * dsi_ctrl_mask_error_status_interrupts() - API to mask dsi ctrl error status
  718. * interrupts
  719. * @dsi_ctrl: DSI controller handle.
  720. * @idx: id indicating which interrupts to enable/disable.
  721. * @mask_enable: boolean to enable/disable masking.
  722. */
  723. void dsi_ctrl_mask_error_status_interrupts(struct dsi_ctrl *dsi_ctrl, u32 idx,
  724. bool mask_enable);
  725. /**
  726. * dsi_ctrl_irq_update() - Put a irq vote to process DSI error
  727. * interrupts at any time.
  728. * @dsi_ctrl: DSI controller handle.
  729. * @enable: variable to control enable/disable irq line
  730. */
  731. void dsi_ctrl_irq_update(struct dsi_ctrl *dsi_ctrl, bool enable);
  732. /**
  733. * dsi_ctrl_get_host_engine_init_state() - Return host init state
  734. */
  735. int dsi_ctrl_get_host_engine_init_state(struct dsi_ctrl *dsi_ctrl,
  736. bool *state);
  737. /**
  738. * dsi_ctrl_wait_for_cmd_mode_mdp_idle() - Wait for command mode engine not to
  739. * be busy sending data from display engine.
  740. * @dsi_ctrl: DSI controller handle.
  741. */
  742. int dsi_ctrl_wait_for_cmd_mode_mdp_idle(struct dsi_ctrl *dsi_ctrl);
  743. /**
  744. * dsi_ctrl_update_host_state() - Set the host state
  745. */
  746. int dsi_ctrl_update_host_state(struct dsi_ctrl *dsi_ctrl,
  747. enum dsi_ctrl_driver_ops op, bool en);
  748. /**
  749. * dsi_ctrl_pixel_format_to_bpp() - returns number of bits per pxl
  750. */
  751. int dsi_ctrl_pixel_format_to_bpp(enum dsi_pixel_format dst_format);
  752. /**
  753. * dsi_ctrl_hs_req_sel() - API to enable continuous clk support through phy
  754. * @dsi_ctrl: DSI controller handle.
  755. * @sel_phy: Boolean to control whether to select phy or
  756. * controller
  757. */
  758. void dsi_ctrl_hs_req_sel(struct dsi_ctrl *dsi_ctrl, bool sel_phy);
  759. /**
  760. * dsi_ctrl_set_continuous_clk() - API to set/unset force clock lane HS request.
  761. * @dsi_ctrl: DSI controller handle.
  762. * @enable: variable to control continuous clock.
  763. */
  764. void dsi_ctrl_set_continuous_clk(struct dsi_ctrl *dsi_ctrl, bool enable);
  765. /**
  766. * dsi_ctrl_wait4dynamic_refresh_done() - Poll for dynamic refresh done
  767. * interrupt.
  768. * @dsi_ctrl: DSI controller handle.
  769. */
  770. int dsi_ctrl_wait4dynamic_refresh_done(struct dsi_ctrl *ctrl);
  771. #endif /* _DSI_CTRL_H_ */