Lines Matching refs:dsidev

110 #define REG_GET(dsidev, idx, start, end) \  argument
111 FLD_GET(dsi_read_reg(dsidev, idx), start, end)
113 #define REG_FLD_MOD(dsidev, idx, val, start, end) \ argument
114 dsi_write_reg(dsidev, idx, FLD_MOD(dsi_read_reg(dsidev, idx), val, start, end))
205 static int dsi_display_init_dispc(struct platform_device *dsidev,
207 static void dsi_display_uninit_dispc(struct platform_device *dsidev,
267 struct platform_device *dsidev; member
384 struct platform_device *dsidev; member
400 static inline struct dsi_data *dsi_get_dsidrv_data(struct platform_device *dsidev) in dsi_get_dsidrv_data() argument
402 return platform_get_drvdata(dsidev); in dsi_get_dsidrv_data()
431 static inline void dsi_write_reg(struct platform_device *dsidev, in dsi_write_reg() argument
434 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_write_reg()
447 static inline u32 dsi_read_reg(struct platform_device *dsidev, in dsi_read_reg() argument
450 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_read_reg()
465 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_bus_lock() local
466 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_bus_lock()
473 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_bus_unlock() local
474 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_bus_unlock()
479 static bool dsi_bus_is_locked(struct platform_device *dsidev) in dsi_bus_is_locked() argument
481 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_bus_is_locked()
491 static inline int wait_for_bit_change(struct platform_device *dsidev, in wait_for_bit_change() argument
501 if (REG_GET(dsidev, idx, bitnum, bitnum) == value) in wait_for_bit_change()
508 if (REG_GET(dsidev, idx, bitnum, bitnum) == value) in wait_for_bit_change()
536 static void dsi_perf_mark_setup(struct platform_device *dsidev) in dsi_perf_mark_setup() argument
538 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_perf_mark_setup()
542 static void dsi_perf_mark_start(struct platform_device *dsidev) in dsi_perf_mark_start() argument
544 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_perf_mark_start()
548 static void dsi_perf_show(struct platform_device *dsidev, const char *name) in dsi_perf_show() argument
550 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_perf_show()
585 static inline void dsi_perf_mark_setup(struct platform_device *dsidev) in dsi_perf_mark_setup() argument
589 static inline void dsi_perf_mark_start(struct platform_device *dsidev) in dsi_perf_mark_start() argument
593 static inline void dsi_perf_show(struct platform_device *dsidev, in dsi_perf_show() argument
691 static void dsi_collect_irq_stats(struct platform_device *dsidev, u32 irqstatus, in dsi_collect_irq_stats() argument
694 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_collect_irq_stats()
710 #define dsi_collect_irq_stats(dsidev, irqstatus, vcstatus, ciostatus) argument
715 static void dsi_handle_irq_errors(struct platform_device *dsidev, u32 irqstatus, in dsi_handle_irq_errors() argument
718 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_handle_irq_errors()
787 struct platform_device *dsidev; in omap_dsi_irq_handler() local
792 dsidev = (struct platform_device *) arg; in omap_dsi_irq_handler()
793 dsi = dsi_get_dsidrv_data(dsidev); in omap_dsi_irq_handler()
800 irqstatus = dsi_read_reg(dsidev, DSI_IRQSTATUS); in omap_dsi_irq_handler()
808 dsi_write_reg(dsidev, DSI_IRQSTATUS, irqstatus & ~DSI_IRQ_CHANNEL_MASK); in omap_dsi_irq_handler()
810 dsi_read_reg(dsidev, DSI_IRQSTATUS); in omap_dsi_irq_handler()
818 vcstatus[i] = dsi_read_reg(dsidev, DSI_VC_IRQSTATUS(i)); in omap_dsi_irq_handler()
820 dsi_write_reg(dsidev, DSI_VC_IRQSTATUS(i), vcstatus[i]); in omap_dsi_irq_handler()
822 dsi_read_reg(dsidev, DSI_VC_IRQSTATUS(i)); in omap_dsi_irq_handler()
826 ciostatus = dsi_read_reg(dsidev, DSI_COMPLEXIO_IRQ_STATUS); in omap_dsi_irq_handler()
828 dsi_write_reg(dsidev, DSI_COMPLEXIO_IRQ_STATUS, ciostatus); in omap_dsi_irq_handler()
830 dsi_read_reg(dsidev, DSI_COMPLEXIO_IRQ_STATUS); in omap_dsi_irq_handler()
849 dsi_handle_irq_errors(dsidev, irqstatus, vcstatus, ciostatus); in omap_dsi_irq_handler()
851 dsi_collect_irq_stats(dsidev, irqstatus, vcstatus, ciostatus); in omap_dsi_irq_handler()
857 static void _omap_dsi_configure_irqs(struct platform_device *dsidev, in _omap_dsi_configure_irqs() argument
879 old_mask = dsi_read_reg(dsidev, enable_reg); in _omap_dsi_configure_irqs()
881 dsi_write_reg(dsidev, status_reg, (mask ^ old_mask) & mask); in _omap_dsi_configure_irqs()
882 dsi_write_reg(dsidev, enable_reg, mask); in _omap_dsi_configure_irqs()
885 dsi_read_reg(dsidev, enable_reg); in _omap_dsi_configure_irqs()
886 dsi_read_reg(dsidev, status_reg); in _omap_dsi_configure_irqs()
890 static void _omap_dsi_set_irqs(struct platform_device *dsidev) in _omap_dsi_set_irqs() argument
892 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in _omap_dsi_set_irqs()
897 _omap_dsi_configure_irqs(dsidev, dsi->isr_tables.isr_table, in _omap_dsi_set_irqs()
903 static void _omap_dsi_set_irqs_vc(struct platform_device *dsidev, int vc) in _omap_dsi_set_irqs_vc() argument
905 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in _omap_dsi_set_irqs_vc()
907 _omap_dsi_configure_irqs(dsidev, dsi->isr_tables.isr_table_vc[vc], in _omap_dsi_set_irqs_vc()
914 static void _omap_dsi_set_irqs_cio(struct platform_device *dsidev) in _omap_dsi_set_irqs_cio() argument
916 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in _omap_dsi_set_irqs_cio()
918 _omap_dsi_configure_irqs(dsidev, dsi->isr_tables.isr_table_cio, in _omap_dsi_set_irqs_cio()
924 static void _dsi_initialize_irq(struct platform_device *dsidev) in _dsi_initialize_irq() argument
926 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in _dsi_initialize_irq()
934 _omap_dsi_set_irqs(dsidev); in _dsi_initialize_irq()
936 _omap_dsi_set_irqs_vc(dsidev, vc); in _dsi_initialize_irq()
937 _omap_dsi_set_irqs_cio(dsidev); in _dsi_initialize_irq()
998 static int dsi_register_isr(struct platform_device *dsidev, omap_dsi_isr_t isr, in dsi_register_isr() argument
1001 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_register_isr()
1011 _omap_dsi_set_irqs(dsidev); in dsi_register_isr()
1018 static int dsi_unregister_isr(struct platform_device *dsidev, in dsi_unregister_isr() argument
1021 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_unregister_isr()
1031 _omap_dsi_set_irqs(dsidev); in dsi_unregister_isr()
1038 static int dsi_register_isr_vc(struct platform_device *dsidev, int channel, in dsi_register_isr_vc() argument
1041 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_register_isr_vc()
1052 _omap_dsi_set_irqs_vc(dsidev, channel); in dsi_register_isr_vc()
1059 static int dsi_unregister_isr_vc(struct platform_device *dsidev, int channel, in dsi_unregister_isr_vc() argument
1062 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_unregister_isr_vc()
1073 _omap_dsi_set_irqs_vc(dsidev, channel); in dsi_unregister_isr_vc()
1080 static int dsi_register_isr_cio(struct platform_device *dsidev, in dsi_register_isr_cio() argument
1083 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_register_isr_cio()
1093 _omap_dsi_set_irqs_cio(dsidev); in dsi_register_isr_cio()
1100 static int dsi_unregister_isr_cio(struct platform_device *dsidev, in dsi_unregister_isr_cio() argument
1103 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_unregister_isr_cio()
1113 _omap_dsi_set_irqs_cio(dsidev); in dsi_unregister_isr_cio()
1120 static u32 dsi_get_errors(struct platform_device *dsidev) in dsi_get_errors() argument
1122 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_get_errors()
1132 static int dsi_runtime_get(struct platform_device *dsidev) in dsi_runtime_get() argument
1135 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_runtime_get()
1145 static void dsi_runtime_put(struct platform_device *dsidev) in dsi_runtime_put() argument
1147 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_runtime_put()
1156 static int dsi_regulator_init(struct platform_device *dsidev) in dsi_regulator_init() argument
1158 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_regulator_init()
1177 static void _dsi_print_reset_status(struct platform_device *dsidev) in _dsi_print_reset_status() argument
1184 dsi_read_reg(dsidev, DSI_DSIPHY_CFG5); in _dsi_print_reset_status()
1197 FLD_GET(dsi_read_reg(dsidev, DSI_##fld), start, end) in _dsi_print_reset_status()
1212 static inline int dsi_if_enable(struct platform_device *dsidev, bool enable) in dsi_if_enable() argument
1217 REG_FLD_MOD(dsidev, DSI_CTRL, enable, 0, 0); /* IF_EN */ in dsi_if_enable()
1219 if (wait_for_bit_change(dsidev, DSI_CTRL, 0, enable) != enable) { in dsi_if_enable()
1227 static unsigned long dsi_get_pll_hsdiv_dispc_rate(struct platform_device *dsidev) in dsi_get_pll_hsdiv_dispc_rate() argument
1229 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_get_pll_hsdiv_dispc_rate()
1234 static unsigned long dsi_get_pll_hsdiv_dsi_rate(struct platform_device *dsidev) in dsi_get_pll_hsdiv_dsi_rate() argument
1236 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_get_pll_hsdiv_dsi_rate()
1241 static unsigned long dsi_get_txbyteclkhs(struct platform_device *dsidev) in dsi_get_txbyteclkhs() argument
1243 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_get_txbyteclkhs()
1248 static unsigned long dsi_fclk_rate(struct platform_device *dsidev) in dsi_fclk_rate() argument
1251 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_fclk_rate()
1258 r = dsi_get_pll_hsdiv_dsi_rate(dsidev); in dsi_fclk_rate()
1283 static int dsi_set_lp_clk_divisor(struct platform_device *dsidev) in dsi_set_lp_clk_divisor() argument
1285 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_set_lp_clk_divisor()
1297 dsi_fclk = dsi_fclk_rate(dsidev); in dsi_set_lp_clk_divisor()
1306 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, lp_clk_div, 12, 0); in dsi_set_lp_clk_divisor()
1309 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, dsi_fclk > 30000000 ? 1 : 0, 21, 21); in dsi_set_lp_clk_divisor()
1314 static void dsi_enable_scp_clk(struct platform_device *dsidev) in dsi_enable_scp_clk() argument
1316 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_enable_scp_clk()
1319 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, 1, 14, 14); /* CIO_CLK_ICG */ in dsi_enable_scp_clk()
1322 static void dsi_disable_scp_clk(struct platform_device *dsidev) in dsi_disable_scp_clk() argument
1324 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_disable_scp_clk()
1328 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, 0, 14, 14); /* CIO_CLK_ICG */ in dsi_disable_scp_clk()
1338 static int dsi_pll_power(struct platform_device *dsidev, in dsi_pll_power() argument
1349 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, state, 31, 30); in dsi_pll_power()
1352 while (FLD_GET(dsi_read_reg(dsidev, DSI_CLK_CTRL), 29, 28) != state) { in dsi_pll_power()
1378 struct platform_device *dsidev = dsi->pdev; in dsi_pll_enable() local
1383 r = dsi_regulator_init(dsidev); in dsi_pll_enable()
1387 r = dsi_runtime_get(dsidev); in dsi_pll_enable()
1394 dsi_enable_scp_clk(dsidev); in dsi_pll_enable()
1406 if (wait_for_bit_change(dsidev, DSI_PLL_STATUS, 0, 1) != 1) { in dsi_pll_enable()
1417 r = dsi_pll_power(dsidev, DSI_PLL_POWER_ON_ALL); in dsi_pll_enable()
1431 dsi_disable_scp_clk(dsidev); in dsi_pll_enable()
1432 dsi_runtime_put(dsidev); in dsi_pll_enable()
1436 static void dsi_pll_uninit(struct platform_device *dsidev, bool disconnect_lanes) in dsi_pll_uninit() argument
1438 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_pll_uninit()
1440 dsi_pll_power(dsidev, DSI_PLL_POWER_OFF); in dsi_pll_uninit()
1447 dsi_disable_scp_clk(dsidev); in dsi_pll_uninit()
1448 dsi_runtime_put(dsidev); in dsi_pll_uninit()
1456 struct platform_device *dsidev = dsi->pdev; in dsi_pll_disable() local
1458 dsi_pll_uninit(dsidev, true); in dsi_pll_disable()
1461 static void dsi_dump_dsidev_clocks(struct platform_device *dsidev, in dsi_dump_dsidev_clocks() argument
1464 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_dump_dsidev_clocks()
1473 if (dsi_runtime_get(dsidev)) in dsi_dump_dsidev_clocks()
1509 seq_printf(s, "DSI_FCLK\t%lu\n", dsi_fclk_rate(dsidev)); in dsi_dump_dsidev_clocks()
1514 seq_printf(s, "TxByteClkHS\t%lu\n", dsi_get_txbyteclkhs(dsidev)); in dsi_dump_dsidev_clocks()
1518 dsi_runtime_put(dsidev); in dsi_dump_dsidev_clocks()
1523 struct platform_device *dsidev; in dsi_dump_clocks() local
1527 dsidev = dsi_get_dsidev_from_id(i); in dsi_dump_clocks()
1528 if (dsidev) in dsi_dump_clocks()
1529 dsi_dump_dsidev_clocks(dsidev, s); in dsi_dump_clocks()
1534 static void dsi_dump_dsidev_irqs(struct platform_device *dsidev, in dsi_dump_dsidev_irqs() argument
1537 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_dump_dsidev_irqs()
1633 struct platform_device *dsidev = dsi_get_dsidev_from_id(0); in dsi1_dump_irqs() local
1635 dsi_dump_dsidev_irqs(dsidev, s); in dsi1_dump_irqs()
1640 struct platform_device *dsidev = dsi_get_dsidev_from_id(1); in dsi2_dump_irqs() local
1642 dsi_dump_dsidev_irqs(dsidev, s); in dsi2_dump_irqs()
1646 static void dsi_dump_dsidev_regs(struct platform_device *dsidev, in dsi_dump_dsidev_regs() argument
1649 #define DUMPREG(r) seq_printf(s, "%-35s %08x\n", #r, dsi_read_reg(dsidev, r)) in dsi_dump_dsidev_regs()
1651 if (dsi_runtime_get(dsidev)) in dsi_dump_dsidev_regs()
1653 dsi_enable_scp_clk(dsidev); in dsi_dump_dsidev_regs()
1725 dsi_disable_scp_clk(dsidev); in dsi_dump_dsidev_regs()
1726 dsi_runtime_put(dsidev); in dsi_dump_dsidev_regs()
1732 struct platform_device *dsidev = dsi_get_dsidev_from_id(0); in dsi1_dump_regs() local
1734 dsi_dump_dsidev_regs(dsidev, s); in dsi1_dump_regs()
1739 struct platform_device *dsidev = dsi_get_dsidev_from_id(1); in dsi2_dump_regs() local
1741 dsi_dump_dsidev_regs(dsidev, s); in dsi2_dump_regs()
1750 static int dsi_cio_power(struct platform_device *dsidev, in dsi_cio_power() argument
1756 REG_FLD_MOD(dsidev, DSI_COMPLEXIO_CFG1, state, 28, 27); in dsi_cio_power()
1759 while (FLD_GET(dsi_read_reg(dsidev, DSI_COMPLEXIO_CFG1), in dsi_cio_power()
1772 static unsigned dsi_get_line_buf_size(struct platform_device *dsidev) in dsi_get_line_buf_size() argument
1783 val = REG_GET(dsidev, DSI_GNQ, 14, 12); /* VP1_LINE_BUFFER_SIZE */ in dsi_get_line_buf_size()
1806 static int dsi_set_lane_config(struct platform_device *dsidev) in dsi_set_lane_config() argument
1808 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_set_lane_config()
1820 r = dsi_read_reg(dsidev, DSI_COMPLEXIO_CFG1); in dsi_set_lane_config()
1849 dsi_write_reg(dsidev, DSI_COMPLEXIO_CFG1, r); in dsi_set_lane_config()
1854 static inline unsigned ns2ddr(struct platform_device *dsidev, unsigned ns) in ns2ddr() argument
1856 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in ns2ddr()
1863 static inline unsigned ddr2ns(struct platform_device *dsidev, unsigned ddr) in ddr2ns() argument
1865 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in ddr2ns()
1871 static void dsi_cio_timings(struct platform_device *dsidev) in dsi_cio_timings() argument
1883 ths_prepare = ns2ddr(dsidev, 70) + 2; in dsi_cio_timings()
1886 ths_prepare_ths_zero = ns2ddr(dsidev, 175) + 2; in dsi_cio_timings()
1889 ths_trail = ns2ddr(dsidev, 60) + 5; in dsi_cio_timings()
1892 ths_exit = ns2ddr(dsidev, 145); in dsi_cio_timings()
1895 tlpx_half = ns2ddr(dsidev, 25); in dsi_cio_timings()
1898 tclk_trail = ns2ddr(dsidev, 60) + 2; in dsi_cio_timings()
1901 tclk_prepare = ns2ddr(dsidev, 65); in dsi_cio_timings()
1904 tclk_zero = ns2ddr(dsidev, 260); in dsi_cio_timings()
1907 ths_prepare, ddr2ns(dsidev, ths_prepare), in dsi_cio_timings()
1908 ths_prepare_ths_zero, ddr2ns(dsidev, ths_prepare_ths_zero)); in dsi_cio_timings()
1910 ths_trail, ddr2ns(dsidev, ths_trail), in dsi_cio_timings()
1911 ths_exit, ddr2ns(dsidev, ths_exit)); in dsi_cio_timings()
1915 tlpx_half, ddr2ns(dsidev, tlpx_half), in dsi_cio_timings()
1916 tclk_trail, ddr2ns(dsidev, tclk_trail), in dsi_cio_timings()
1917 tclk_zero, ddr2ns(dsidev, tclk_zero)); in dsi_cio_timings()
1919 tclk_prepare, ddr2ns(dsidev, tclk_prepare)); in dsi_cio_timings()
1923 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG0); in dsi_cio_timings()
1928 dsi_write_reg(dsidev, DSI_DSIPHY_CFG0, r); in dsi_cio_timings()
1930 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG1); in dsi_cio_timings()
1941 dsi_write_reg(dsidev, DSI_DSIPHY_CFG1, r); in dsi_cio_timings()
1943 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG2); in dsi_cio_timings()
1945 dsi_write_reg(dsidev, DSI_DSIPHY_CFG2, r); in dsi_cio_timings()
1949 static void dsi_cio_enable_lane_override(struct platform_device *dsidev, in dsi_cio_enable_lane_override() argument
1952 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_cio_enable_lane_override()
1981 REG_FLD_MOD(dsidev, DSI_DSIPHY_CFG10, l, lptxscp_start, 17); in dsi_cio_enable_lane_override()
1986 REG_FLD_MOD(dsidev, DSI_DSIPHY_CFG10, 1, 27, 27); in dsi_cio_enable_lane_override()
1989 static void dsi_cio_disable_lane_override(struct platform_device *dsidev) in dsi_cio_disable_lane_override() argument
1992 REG_FLD_MOD(dsidev, DSI_DSIPHY_CFG10, 0, 27, 27); /* ENLPTXSCPDAT */ in dsi_cio_disable_lane_override()
1995 REG_FLD_MOD(dsidev, DSI_DSIPHY_CFG10, 0, 22, 17); in dsi_cio_disable_lane_override()
1998 static int dsi_cio_wait_tx_clk_esc_reset(struct platform_device *dsidev) in dsi_cio_wait_tx_clk_esc_reset() argument
2000 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_cio_wait_tx_clk_esc_reset()
2020 l = dsi_read_reg(dsidev, DSI_DSIPHY_CFG5); in dsi_cio_wait_tx_clk_esc_reset()
2047 static unsigned dsi_get_lane_mask(struct platform_device *dsidev) in dsi_get_lane_mask() argument
2049 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_get_lane_mask()
2061 static int dsi_cio_init(struct platform_device *dsidev) in dsi_cio_init() argument
2063 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_cio_init()
2069 r = dss_dsi_enable_pads(dsi->module_id, dsi_get_lane_mask(dsidev)); in dsi_cio_init()
2073 dsi_enable_scp_clk(dsidev); in dsi_cio_init()
2078 dsi_read_reg(dsidev, DSI_DSIPHY_CFG5); in dsi_cio_init()
2080 if (wait_for_bit_change(dsidev, DSI_DSIPHY_CFG5, 30, 1) != 1) { in dsi_cio_init()
2086 r = dsi_set_lane_config(dsidev); in dsi_cio_init()
2091 l = dsi_read_reg(dsidev, DSI_TIMING1); in dsi_cio_init()
2096 dsi_write_reg(dsidev, DSI_TIMING1, l); in dsi_cio_init()
2121 dsi_cio_enable_lane_override(dsidev, mask_p, 0); in dsi_cio_init()
2124 r = dsi_cio_power(dsidev, DSI_COMPLEXIO_POWER_ON); in dsi_cio_init()
2128 if (wait_for_bit_change(dsidev, DSI_COMPLEXIO_CFG1, 29, 1) != 1) { in dsi_cio_init()
2134 dsi_if_enable(dsidev, true); in dsi_cio_init()
2135 dsi_if_enable(dsidev, false); in dsi_cio_init()
2136 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, 1, 20, 20); /* LP_CLK_ENABLE */ in dsi_cio_init()
2138 r = dsi_cio_wait_tx_clk_esc_reset(dsidev); in dsi_cio_init()
2150 dsi_cio_disable_lane_override(dsidev); in dsi_cio_init()
2154 REG_FLD_MOD(dsidev, DSI_TIMING1, 0, 15, 15); in dsi_cio_init()
2156 dsi_cio_timings(dsidev); in dsi_cio_init()
2160 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, in dsi_cio_init()
2171 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, 0, 20, 20); /* LP_CLK_ENABLE */ in dsi_cio_init()
2173 dsi_cio_power(dsidev, DSI_COMPLEXIO_POWER_OFF); in dsi_cio_init()
2176 dsi_cio_disable_lane_override(dsidev); in dsi_cio_init()
2178 dsi_disable_scp_clk(dsidev); in dsi_cio_init()
2179 dss_dsi_disable_pads(dsi->module_id, dsi_get_lane_mask(dsidev)); in dsi_cio_init()
2183 static void dsi_cio_uninit(struct platform_device *dsidev) in dsi_cio_uninit() argument
2185 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_cio_uninit()
2188 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, 0, 13, 13); in dsi_cio_uninit()
2190 dsi_cio_power(dsidev, DSI_COMPLEXIO_POWER_OFF); in dsi_cio_uninit()
2191 dsi_disable_scp_clk(dsidev); in dsi_cio_uninit()
2192 dss_dsi_disable_pads(dsi->module_id, dsi_get_lane_mask(dsidev)); in dsi_cio_uninit()
2195 static void dsi_config_tx_fifo(struct platform_device *dsidev, in dsi_config_tx_fifo() argument
2199 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_config_tx_fifo()
2225 dsi_write_reg(dsidev, DSI_TX_FIFO_VC_SIZE, r); in dsi_config_tx_fifo()
2228 static void dsi_config_rx_fifo(struct platform_device *dsidev, in dsi_config_rx_fifo() argument
2232 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_config_rx_fifo()
2258 dsi_write_reg(dsidev, DSI_RX_FIFO_VC_SIZE, r); in dsi_config_rx_fifo()
2261 static int dsi_force_tx_stop_mode_io(struct platform_device *dsidev) in dsi_force_tx_stop_mode_io() argument
2265 r = dsi_read_reg(dsidev, DSI_TIMING1); in dsi_force_tx_stop_mode_io()
2267 dsi_write_reg(dsidev, DSI_TIMING1, r); in dsi_force_tx_stop_mode_io()
2269 if (wait_for_bit_change(dsidev, DSI_TIMING1, 15, 0) != 0) { in dsi_force_tx_stop_mode_io()
2277 static bool dsi_vc_is_enabled(struct platform_device *dsidev, int channel) in dsi_vc_is_enabled() argument
2279 return REG_GET(dsidev, DSI_VC_CTRL(channel), 0, 0); in dsi_vc_is_enabled()
2286 struct dsi_data *dsi = dsi_get_dsidrv_data(vp_data->dsidev); in dsi_packet_sent_handler_vp()
2290 if (REG_GET(vp_data->dsidev, DSI_VC_TE(channel), bit, bit) == 0) in dsi_packet_sent_handler_vp()
2294 static int dsi_sync_vc_vp(struct platform_device *dsidev, int channel) in dsi_sync_vc_vp() argument
2296 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_sync_vc_vp()
2299 .dsidev = dsidev, in dsi_sync_vc_vp()
2307 r = dsi_register_isr_vc(dsidev, channel, dsi_packet_sent_handler_vp, in dsi_sync_vc_vp()
2313 if (REG_GET(dsidev, DSI_VC_TE(channel), bit, bit)) { in dsi_sync_vc_vp()
2322 dsi_unregister_isr_vc(dsidev, channel, dsi_packet_sent_handler_vp, in dsi_sync_vc_vp()
2327 dsi_unregister_isr_vc(dsidev, channel, dsi_packet_sent_handler_vp, in dsi_sync_vc_vp()
2337 struct dsi_data *dsi = dsi_get_dsidrv_data(l4_data->dsidev); in dsi_packet_sent_handler_l4()
2340 if (REG_GET(l4_data->dsidev, DSI_VC_CTRL(channel), 5, 5) == 0) in dsi_packet_sent_handler_l4()
2344 static int dsi_sync_vc_l4(struct platform_device *dsidev, int channel) in dsi_sync_vc_l4() argument
2348 .dsidev = dsidev, in dsi_sync_vc_l4()
2353 r = dsi_register_isr_vc(dsidev, channel, dsi_packet_sent_handler_l4, in dsi_sync_vc_l4()
2359 if (REG_GET(dsidev, DSI_VC_CTRL(channel), 5, 5)) { in dsi_sync_vc_l4()
2368 dsi_unregister_isr_vc(dsidev, channel, dsi_packet_sent_handler_l4, in dsi_sync_vc_l4()
2373 dsi_unregister_isr_vc(dsidev, channel, dsi_packet_sent_handler_l4, in dsi_sync_vc_l4()
2379 static int dsi_sync_vc(struct platform_device *dsidev, int channel) in dsi_sync_vc() argument
2381 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_sync_vc()
2383 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_sync_vc()
2385 if (!dsi_vc_is_enabled(dsidev, channel)) in dsi_sync_vc()
2390 return dsi_sync_vc_vp(dsidev, channel); in dsi_sync_vc()
2392 return dsi_sync_vc_l4(dsidev, channel); in dsi_sync_vc()
2399 static int dsi_vc_enable(struct platform_device *dsidev, int channel, in dsi_vc_enable() argument
2407 REG_FLD_MOD(dsidev, DSI_VC_CTRL(channel), enable, 0, 0); in dsi_vc_enable()
2409 if (wait_for_bit_change(dsidev, DSI_VC_CTRL(channel), in dsi_vc_enable()
2418 static void dsi_vc_initial_config(struct platform_device *dsidev, int channel) in dsi_vc_initial_config() argument
2420 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_initial_config()
2425 r = dsi_read_reg(dsidev, DSI_VC_CTRL(channel)); in dsi_vc_initial_config()
2444 dsi_write_reg(dsidev, DSI_VC_CTRL(channel), r); in dsi_vc_initial_config()
2449 static int dsi_vc_config_source(struct platform_device *dsidev, int channel, in dsi_vc_config_source() argument
2452 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_config_source()
2459 dsi_sync_vc(dsidev, channel); in dsi_vc_config_source()
2461 dsi_vc_enable(dsidev, channel, 0); in dsi_vc_config_source()
2464 if (wait_for_bit_change(dsidev, DSI_VC_CTRL(channel), 15, 0) != 0) { in dsi_vc_config_source()
2470 REG_FLD_MOD(dsidev, DSI_VC_CTRL(channel), source, 1, 1); in dsi_vc_config_source()
2475 REG_FLD_MOD(dsidev, DSI_VC_CTRL(channel), enable, 30, 30); in dsi_vc_config_source()
2478 dsi_vc_enable(dsidev, channel, 1); in dsi_vc_config_source()
2488 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_enable_hs() local
2489 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_enable_hs()
2493 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_vc_enable_hs()
2495 dsi_vc_enable(dsidev, channel, 0); in dsi_vc_enable_hs()
2496 dsi_if_enable(dsidev, 0); in dsi_vc_enable_hs()
2498 REG_FLD_MOD(dsidev, DSI_VC_CTRL(channel), enable, 9, 9); in dsi_vc_enable_hs()
2500 dsi_vc_enable(dsidev, channel, 1); in dsi_vc_enable_hs()
2501 dsi_if_enable(dsidev, 1); in dsi_vc_enable_hs()
2503 dsi_force_tx_stop_mode_io(dsidev); in dsi_vc_enable_hs()
2510 static void dsi_vc_flush_long_data(struct platform_device *dsidev, int channel) in dsi_vc_flush_long_data() argument
2512 while (REG_GET(dsidev, DSI_VC_CTRL(channel), 20, 20)) { in dsi_vc_flush_long_data()
2514 val = dsi_read_reg(dsidev, DSI_VC_SHORT_PACKET_HEADER(channel)); in dsi_vc_flush_long_data()
2560 static u16 dsi_vc_flush_receive_data(struct platform_device *dsidev, in dsi_vc_flush_receive_data() argument
2564 while (REG_GET(dsidev, DSI_VC_CTRL(channel), 20, 20)) { in dsi_vc_flush_receive_data()
2567 val = dsi_read_reg(dsidev, DSI_VC_SHORT_PACKET_HEADER(channel)); in dsi_vc_flush_receive_data()
2582 dsi_vc_flush_long_data(dsidev, channel); in dsi_vc_flush_receive_data()
2590 static int dsi_vc_send_bta(struct platform_device *dsidev, int channel) in dsi_vc_send_bta() argument
2592 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_send_bta()
2597 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_vc_send_bta()
2600 if (REG_GET(dsidev, DSI_VC_CTRL(channel), 20, 20)) { in dsi_vc_send_bta()
2602 dsi_vc_flush_receive_data(dsidev, channel); in dsi_vc_send_bta()
2605 REG_FLD_MOD(dsidev, DSI_VC_CTRL(channel), 1, 6, 6); /* BTA_EN */ in dsi_vc_send_bta()
2608 dsi_read_reg(dsidev, DSI_VC_CTRL(channel)); in dsi_vc_send_bta()
2615 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_send_bta_sync() local
2620 r = dsi_register_isr_vc(dsidev, channel, dsi_completion_handler, in dsi_vc_send_bta_sync()
2625 r = dsi_register_isr(dsidev, dsi_completion_handler, &completion, in dsi_vc_send_bta_sync()
2630 r = dsi_vc_send_bta(dsidev, channel); in dsi_vc_send_bta_sync()
2641 err = dsi_get_errors(dsidev); in dsi_vc_send_bta_sync()
2648 dsi_unregister_isr(dsidev, dsi_completion_handler, &completion, in dsi_vc_send_bta_sync()
2651 dsi_unregister_isr_vc(dsidev, channel, dsi_completion_handler, in dsi_vc_send_bta_sync()
2657 static inline void dsi_vc_write_long_header(struct platform_device *dsidev, in dsi_vc_write_long_header() argument
2660 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_write_long_header()
2664 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_vc_write_long_header()
2671 dsi_write_reg(dsidev, DSI_VC_LONG_PACKET_HEADER(channel), val); in dsi_vc_write_long_header()
2674 static inline void dsi_vc_write_long_payload(struct platform_device *dsidev, in dsi_vc_write_long_payload() argument
2684 dsi_write_reg(dsidev, DSI_VC_LONG_PACKET_PAYLOAD(channel), val); in dsi_vc_write_long_payload()
2687 static int dsi_vc_send_long(struct platform_device *dsidev, int channel, in dsi_vc_send_long() argument
2691 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_send_long()
2706 dsi_vc_config_source(dsidev, channel, DSI_VC_SOURCE_L4); in dsi_vc_send_long()
2708 dsi_vc_write_long_header(dsidev, channel, data_type, len, ecc); in dsi_vc_send_long()
2720 dsi_vc_write_long_payload(dsidev, channel, b1, b2, b3, b4); in dsi_vc_send_long()
2745 dsi_vc_write_long_payload(dsidev, channel, b1, b2, b3, 0); in dsi_vc_send_long()
2751 static int dsi_vc_send_short(struct platform_device *dsidev, int channel, in dsi_vc_send_short() argument
2754 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_send_short()
2758 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_vc_send_short()
2765 dsi_vc_config_source(dsidev, channel, DSI_VC_SOURCE_L4); in dsi_vc_send_short()
2767 if (FLD_GET(dsi_read_reg(dsidev, DSI_VC_CTRL(channel)), 16, 16)) { in dsi_vc_send_short()
2776 dsi_write_reg(dsidev, DSI_VC_SHORT_PACKET_HEADER(channel), r); in dsi_vc_send_short()
2783 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_send_null() local
2785 return dsi_vc_send_long(dsidev, channel, MIPI_DSI_NULL_PACKET, NULL, in dsi_vc_send_null()
2789 static int dsi_vc_write_nosync_common(struct platform_device *dsidev, in dsi_vc_write_nosync_common() argument
2796 r = dsi_vc_send_short(dsidev, channel, in dsi_vc_write_nosync_common()
2799 r = dsi_vc_send_short(dsidev, channel, in dsi_vc_write_nosync_common()
2804 r = dsi_vc_send_short(dsidev, channel, in dsi_vc_write_nosync_common()
2810 r = dsi_vc_send_long(dsidev, channel, in dsi_vc_write_nosync_common()
2822 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_dcs_write_nosync() local
2824 return dsi_vc_write_nosync_common(dsidev, channel, data, len, in dsi_vc_dcs_write_nosync()
2831 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_generic_write_nosync() local
2833 return dsi_vc_write_nosync_common(dsidev, channel, data, len, in dsi_vc_generic_write_nosync()
2840 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_write_common() local
2843 r = dsi_vc_write_nosync_common(dsidev, channel, data, len, type); in dsi_vc_write_common()
2852 if (REG_GET(dsidev, DSI_VC_CTRL(channel), 20, 20)) { in dsi_vc_write_common()
2854 dsi_vc_flush_receive_data(dsidev, channel); in dsi_vc_write_common()
2880 static int dsi_vc_dcs_send_read_request(struct platform_device *dsidev, in dsi_vc_dcs_send_read_request() argument
2883 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_dcs_send_read_request()
2890 r = dsi_vc_send_short(dsidev, channel, MIPI_DSI_DCS_READ, dcs_cmd, 0); in dsi_vc_dcs_send_read_request()
2900 static int dsi_vc_generic_send_read_request(struct platform_device *dsidev, in dsi_vc_generic_send_read_request() argument
2903 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_generic_send_read_request()
2926 r = dsi_vc_send_short(dsidev, channel, data_type, data, 0); in dsi_vc_generic_send_read_request()
2936 static int dsi_vc_read_rx_fifo(struct platform_device *dsidev, int channel, in dsi_vc_read_rx_fifo() argument
2939 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_vc_read_rx_fifo()
2945 if (REG_GET(dsidev, DSI_VC_CTRL(channel), 20, 20) == 0) { in dsi_vc_read_rx_fifo()
2951 val = dsi_read_reg(dsidev, DSI_VC_SHORT_PACKET_HEADER(channel)); in dsi_vc_read_rx_fifo()
3014 val = dsi_read_reg(dsidev, in dsi_vc_read_rx_fifo()
3048 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_dcs_read() local
3051 r = dsi_vc_dcs_send_read_request(dsidev, channel, dcs_cmd); in dsi_vc_dcs_read()
3059 r = dsi_vc_read_rx_fifo(dsidev, channel, buf, buflen, in dsi_vc_dcs_read()
3078 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_generic_read() local
3081 r = dsi_vc_generic_send_read_request(dsidev, channel, reqdata, reqlen); in dsi_vc_generic_read()
3089 r = dsi_vc_read_rx_fifo(dsidev, channel, buf, buflen, in dsi_vc_generic_read()
3105 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_vc_set_max_rx_packet_size() local
3107 return dsi_vc_send_short(dsidev, channel, in dsi_vc_set_max_rx_packet_size()
3111 static int dsi_enter_ulps(struct platform_device *dsidev) in dsi_enter_ulps() argument
3113 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_enter_ulps()
3120 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_enter_ulps()
3128 if (REG_GET(dsidev, DSI_CLK_CTRL, 13, 13)) { in dsi_enter_ulps()
3129 dsi_if_enable(dsidev, 0); in dsi_enter_ulps()
3130 REG_FLD_MOD(dsidev, DSI_CLK_CTRL, 0, 13, 13); in dsi_enter_ulps()
3131 dsi_if_enable(dsidev, 1); in dsi_enter_ulps()
3134 dsi_sync_vc(dsidev, 0); in dsi_enter_ulps()
3135 dsi_sync_vc(dsidev, 1); in dsi_enter_ulps()
3136 dsi_sync_vc(dsidev, 2); in dsi_enter_ulps()
3137 dsi_sync_vc(dsidev, 3); in dsi_enter_ulps()
3139 dsi_force_tx_stop_mode_io(dsidev); in dsi_enter_ulps()
3141 dsi_vc_enable(dsidev, 0, false); in dsi_enter_ulps()
3142 dsi_vc_enable(dsidev, 1, false); in dsi_enter_ulps()
3143 dsi_vc_enable(dsidev, 2, false); in dsi_enter_ulps()
3144 dsi_vc_enable(dsidev, 3, false); in dsi_enter_ulps()
3146 if (REG_GET(dsidev, DSI_COMPLEXIO_CFG2, 16, 16)) { /* HS_BUSY */ in dsi_enter_ulps()
3151 if (REG_GET(dsidev, DSI_COMPLEXIO_CFG2, 17, 17)) { /* LP_BUSY */ in dsi_enter_ulps()
3156 r = dsi_register_isr_cio(dsidev, dsi_completion_handler, &completion, in dsi_enter_ulps()
3170 REG_FLD_MOD(dsidev, DSI_COMPLEXIO_CFG2, mask, 9, 5); in dsi_enter_ulps()
3173 dsi_read_reg(dsidev, DSI_COMPLEXIO_CFG2); in dsi_enter_ulps()
3182 dsi_unregister_isr_cio(dsidev, dsi_completion_handler, &completion, in dsi_enter_ulps()
3186 REG_FLD_MOD(dsidev, DSI_COMPLEXIO_CFG2, 0, 9, 5); in dsi_enter_ulps()
3189 dsi_read_reg(dsidev, DSI_COMPLEXIO_CFG2); in dsi_enter_ulps()
3191 dsi_cio_power(dsidev, DSI_COMPLEXIO_POWER_ULPS); in dsi_enter_ulps()
3193 dsi_if_enable(dsidev, false); in dsi_enter_ulps()
3200 dsi_unregister_isr_cio(dsidev, dsi_completion_handler, &completion, in dsi_enter_ulps()
3205 static void dsi_set_lp_rx_timeout(struct platform_device *dsidev, in dsi_set_lp_rx_timeout() argument
3215 fck = dsi_fclk_rate(dsidev); in dsi_set_lp_rx_timeout()
3217 r = dsi_read_reg(dsidev, DSI_TIMING2); in dsi_set_lp_rx_timeout()
3222 dsi_write_reg(dsidev, DSI_TIMING2, r); in dsi_set_lp_rx_timeout()
3232 static void dsi_set_ta_timeout(struct platform_device *dsidev, unsigned ticks, in dsi_set_ta_timeout() argument
3242 fck = dsi_fclk_rate(dsidev); in dsi_set_ta_timeout()
3244 r = dsi_read_reg(dsidev, DSI_TIMING1); in dsi_set_ta_timeout()
3249 dsi_write_reg(dsidev, DSI_TIMING1, r); in dsi_set_ta_timeout()
3259 static void dsi_set_stop_state_counter(struct platform_device *dsidev, in dsi_set_stop_state_counter() argument
3269 fck = dsi_fclk_rate(dsidev); in dsi_set_stop_state_counter()
3271 r = dsi_read_reg(dsidev, DSI_TIMING1); in dsi_set_stop_state_counter()
3276 dsi_write_reg(dsidev, DSI_TIMING1, r); in dsi_set_stop_state_counter()
3286 static void dsi_set_hs_tx_timeout(struct platform_device *dsidev, in dsi_set_hs_tx_timeout() argument
3296 fck = dsi_get_txbyteclkhs(dsidev); in dsi_set_hs_tx_timeout()
3298 r = dsi_read_reg(dsidev, DSI_TIMING2); in dsi_set_hs_tx_timeout()
3303 dsi_write_reg(dsidev, DSI_TIMING2, r); in dsi_set_hs_tx_timeout()
3313 static void dsi_config_vp_num_line_buffers(struct platform_device *dsidev) in dsi_config_vp_num_line_buffers() argument
3315 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_config_vp_num_line_buffers()
3335 REG_FLD_MOD(dsidev, DSI_CTRL, num_line_buffers, 13, 12); in dsi_config_vp_num_line_buffers()
3338 static void dsi_config_vp_sync_events(struct platform_device *dsidev) in dsi_config_vp_sync_events() argument
3340 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_config_vp_sync_events()
3349 r = dsi_read_reg(dsidev, DSI_CTRL); in dsi_config_vp_sync_events()
3357 dsi_write_reg(dsidev, DSI_CTRL, r); in dsi_config_vp_sync_events()
3360 static void dsi_config_blanking_modes(struct platform_device *dsidev) in dsi_config_blanking_modes() argument
3362 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_config_blanking_modes()
3373 r = dsi_read_reg(dsidev, DSI_CTRL); in dsi_config_blanking_modes()
3378 dsi_write_reg(dsidev, DSI_CTRL, r); in dsi_config_blanking_modes()
3443 static void dsi_config_cmd_mode_interleaving(struct platform_device *dsidev) in dsi_config_cmd_mode_interleaving() argument
3445 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_config_cmd_mode_interleaving()
3462 r = dsi_read_reg(dsidev, DSI_CTRL); in dsi_config_cmd_mode_interleaving()
3468 r = dsi_read_reg(dsidev, DSI_VM_TIMING1); in dsi_config_cmd_mode_interleaving()
3473 r = dsi_read_reg(dsidev, DSI_CLK_TIMING); in dsi_config_cmd_mode_interleaving()
3477 r = dsi_read_reg(dsidev, DSI_VM_TIMING7); in dsi_config_cmd_mode_interleaving()
3481 r = dsi_read_reg(dsidev, DSI_CLK_CTRL); in dsi_config_cmd_mode_interleaving()
3485 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG0); in dsi_config_cmd_mode_interleaving()
3488 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG1); in dsi_config_cmd_mode_interleaving()
3542 r = dsi_read_reg(dsidev, DSI_VM_TIMING4); in dsi_config_cmd_mode_interleaving()
3546 dsi_write_reg(dsidev, DSI_VM_TIMING4, r); in dsi_config_cmd_mode_interleaving()
3548 r = dsi_read_reg(dsidev, DSI_VM_TIMING5); in dsi_config_cmd_mode_interleaving()
3552 dsi_write_reg(dsidev, DSI_VM_TIMING5, r); in dsi_config_cmd_mode_interleaving()
3554 r = dsi_read_reg(dsidev, DSI_VM_TIMING6); in dsi_config_cmd_mode_interleaving()
3557 dsi_write_reg(dsidev, DSI_VM_TIMING6, r); in dsi_config_cmd_mode_interleaving()
3560 static int dsi_proto_config(struct platform_device *dsidev) in dsi_proto_config() argument
3562 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_proto_config()
3566 dsi_config_tx_fifo(dsidev, DSI_FIFO_SIZE_32, in dsi_proto_config()
3571 dsi_config_rx_fifo(dsidev, DSI_FIFO_SIZE_32, in dsi_proto_config()
3577 dsi_set_stop_state_counter(dsidev, 0x1000, false, false); in dsi_proto_config()
3578 dsi_set_ta_timeout(dsidev, 0x1fff, true, true); in dsi_proto_config()
3579 dsi_set_lp_rx_timeout(dsidev, 0x1fff, true, true); in dsi_proto_config()
3580 dsi_set_hs_tx_timeout(dsidev, 0x1fff, true, true); in dsi_proto_config()
3597 r = dsi_read_reg(dsidev, DSI_CTRL); in dsi_proto_config()
3612 dsi_write_reg(dsidev, DSI_CTRL, r); in dsi_proto_config()
3614 dsi_config_vp_num_line_buffers(dsidev); in dsi_proto_config()
3617 dsi_config_vp_sync_events(dsidev); in dsi_proto_config()
3618 dsi_config_blanking_modes(dsidev); in dsi_proto_config()
3619 dsi_config_cmd_mode_interleaving(dsidev); in dsi_proto_config()
3622 dsi_vc_initial_config(dsidev, 0); in dsi_proto_config()
3623 dsi_vc_initial_config(dsidev, 1); in dsi_proto_config()
3624 dsi_vc_initial_config(dsidev, 2); in dsi_proto_config()
3625 dsi_vc_initial_config(dsidev, 3); in dsi_proto_config()
3630 static void dsi_proto_timings(struct platform_device *dsidev) in dsi_proto_timings() argument
3632 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_proto_timings()
3643 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG0); in dsi_proto_timings()
3650 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG1); in dsi_proto_timings()
3654 r = dsi_read_reg(dsidev, DSI_DSIPHY_CFG2); in dsi_proto_timings()
3660 tclk_post = ns2ddr(dsidev, 60) + 26; in dsi_proto_timings()
3671 r = dsi_read_reg(dsidev, DSI_CLK_TIMING); in dsi_proto_timings()
3674 dsi_write_reg(dsidev, DSI_CLK_TIMING, r); in dsi_proto_timings()
3688 dsi_write_reg(dsidev, DSI_VM_TIMING7, r); in dsi_proto_timings()
3722 r = dsi_read_reg(dsidev, DSI_VM_TIMING1); in dsi_proto_timings()
3726 dsi_write_reg(dsidev, DSI_VM_TIMING1, r); in dsi_proto_timings()
3728 r = dsi_read_reg(dsidev, DSI_VM_TIMING2); in dsi_proto_timings()
3733 dsi_write_reg(dsidev, DSI_VM_TIMING2, r); in dsi_proto_timings()
3735 r = dsi_read_reg(dsidev, DSI_VM_TIMING3); in dsi_proto_timings()
3738 dsi_write_reg(dsidev, DSI_VM_TIMING3, r); in dsi_proto_timings()
3745 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_configure_pins() local
3746 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_configure_pins()
3811 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_enable_video_output() local
3812 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_enable_video_output()
3825 r = dsi_display_init_dispc(dsidev, mgr); in dsi_enable_video_output()
3848 dsi_if_enable(dsidev, false); in dsi_enable_video_output()
3849 dsi_vc_enable(dsidev, channel, false); in dsi_enable_video_output()
3852 REG_FLD_MOD(dsidev, DSI_VC_CTRL(channel), 1, 4, 4); in dsi_enable_video_output()
3856 dsi_vc_write_long_header(dsidev, channel, data_type, in dsi_enable_video_output()
3859 dsi_vc_enable(dsidev, channel, true); in dsi_enable_video_output()
3860 dsi_if_enable(dsidev, true); in dsi_enable_video_output()
3871 dsi_if_enable(dsidev, false); in dsi_enable_video_output()
3872 dsi_vc_enable(dsidev, channel, false); in dsi_enable_video_output()
3875 dsi_display_uninit_dispc(dsidev, mgr); in dsi_enable_video_output()
3882 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_disable_video_output() local
3883 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_disable_video_output()
3887 dsi_if_enable(dsidev, false); in dsi_disable_video_output()
3888 dsi_vc_enable(dsidev, channel, false); in dsi_disable_video_output()
3891 REG_FLD_MOD(dsidev, DSI_VC_CTRL(channel), 0, 4, 4); in dsi_disable_video_output()
3893 dsi_vc_enable(dsidev, channel, true); in dsi_disable_video_output()
3894 dsi_if_enable(dsidev, true); in dsi_disable_video_output()
3899 dsi_display_uninit_dispc(dsidev, mgr); in dsi_disable_video_output()
3902 static void dsi_update_screen_dispc(struct platform_device *dsidev) in dsi_update_screen_dispc() argument
3904 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_update_screen_dispc()
3921 dsi_vc_config_source(dsidev, channel, DSI_VC_SOURCE_VP); in dsi_update_screen_dispc()
3942 dsi_write_reg(dsidev, DSI_VC_TE(channel), l); in dsi_update_screen_dispc()
3944 dsi_vc_write_long_header(dsidev, channel, MIPI_DSI_DCS_LONG_WRITE, in dsi_update_screen_dispc()
3951 dsi_write_reg(dsidev, DSI_VC_TE(channel), l); in dsi_update_screen_dispc()
3961 dsi_perf_mark_start(dsidev); in dsi_update_screen_dispc()
3974 REG_FLD_MOD(dsidev, DSI_TIMING2, 0, 15, 15); /* LP_RX_TO */ in dsi_update_screen_dispc()
3976 dsi_vc_send_bta(dsidev, channel); in dsi_update_screen_dispc()
3991 static void dsi_handle_framedone(struct platform_device *dsidev, int error) in dsi_handle_framedone() argument
3993 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_handle_framedone()
4000 REG_FLD_MOD(dsidev, DSI_TIMING2, 1, 15, 15); /* LP_RX_TO */ in dsi_handle_framedone()
4006 dsi_perf_show(dsidev, "DISPC"); in dsi_handle_framedone()
4027 struct platform_device *dsidev = (struct platform_device *) data; in dsi_framedone_irq_callback() local
4028 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_framedone_irq_callback()
4037 dsi_handle_framedone(dsidev, 0); in dsi_framedone_irq_callback()
4043 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_update() local
4044 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_update()
4046 dsi_perf_mark_setup(dsidev); in dsi_update()
4057 dsi_update_screen_dispc(dsidev); in dsi_update()
4064 static int dsi_configure_dispc_clocks(struct platform_device *dsidev) in dsi_configure_dispc_clocks() argument
4066 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_configure_dispc_clocks()
4071 fck = dsi_get_pll_hsdiv_dispc_rate(dsidev); in dsi_configure_dispc_clocks()
4087 static int dsi_display_init_dispc(struct platform_device *dsidev, in dsi_display_init_dispc() argument
4090 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_display_init_dispc()
4099 dsi_framedone_irq_callback, dsidev); in dsi_display_init_dispc()
4125 r = dsi_configure_dispc_clocks(dsidev); in dsi_display_init_dispc()
4140 dsi_framedone_irq_callback, dsidev); in dsi_display_init_dispc()
4146 static void dsi_display_uninit_dispc(struct platform_device *dsidev, in dsi_display_uninit_dispc() argument
4149 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_display_uninit_dispc()
4153 dsi_framedone_irq_callback, dsidev); in dsi_display_uninit_dispc()
4158 static int dsi_configure_dsi_clocks(struct platform_device *dsidev) in dsi_configure_dsi_clocks() argument
4160 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_configure_dsi_clocks()
4175 static int dsi_display_init_dsi(struct platform_device *dsidev) in dsi_display_init_dsi() argument
4177 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_display_init_dsi()
4184 r = dsi_configure_dsi_clocks(dsidev); in dsi_display_init_dsi()
4194 r = dsi_cio_init(dsidev); in dsi_display_init_dsi()
4198 _dsi_print_reset_status(dsidev); in dsi_display_init_dsi()
4200 dsi_proto_timings(dsidev); in dsi_display_init_dsi()
4201 dsi_set_lp_clk_divisor(dsidev); in dsi_display_init_dsi()
4204 _dsi_print_reset_status(dsidev); in dsi_display_init_dsi()
4206 r = dsi_proto_config(dsidev); in dsi_display_init_dsi()
4211 dsi_vc_enable(dsidev, 0, 1); in dsi_display_init_dsi()
4212 dsi_vc_enable(dsidev, 1, 1); in dsi_display_init_dsi()
4213 dsi_vc_enable(dsidev, 2, 1); in dsi_display_init_dsi()
4214 dsi_vc_enable(dsidev, 3, 1); in dsi_display_init_dsi()
4215 dsi_if_enable(dsidev, 1); in dsi_display_init_dsi()
4216 dsi_force_tx_stop_mode_io(dsidev); in dsi_display_init_dsi()
4220 dsi_cio_uninit(dsidev); in dsi_display_init_dsi()
4229 static void dsi_display_uninit_dsi(struct platform_device *dsidev, in dsi_display_uninit_dsi() argument
4232 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_display_uninit_dsi()
4235 dsi_enter_ulps(dsidev); in dsi_display_uninit_dsi()
4238 dsi_if_enable(dsidev, 0); in dsi_display_uninit_dsi()
4239 dsi_vc_enable(dsidev, 0, 0); in dsi_display_uninit_dsi()
4240 dsi_vc_enable(dsidev, 1, 0); in dsi_display_uninit_dsi()
4241 dsi_vc_enable(dsidev, 2, 0); in dsi_display_uninit_dsi()
4242 dsi_vc_enable(dsidev, 3, 0); in dsi_display_uninit_dsi()
4245 dsi_cio_uninit(dsidev); in dsi_display_uninit_dsi()
4246 dsi_pll_uninit(dsidev, disconnect_lanes); in dsi_display_uninit_dsi()
4251 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_display_enable() local
4252 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_display_enable()
4257 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_display_enable()
4261 r = dsi_runtime_get(dsidev); in dsi_display_enable()
4265 _dsi_initialize_irq(dsidev); in dsi_display_enable()
4267 r = dsi_display_init_dsi(dsidev); in dsi_display_enable()
4276 dsi_runtime_put(dsidev); in dsi_display_enable()
4286 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_display_disable() local
4287 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_display_disable()
4291 WARN_ON(!dsi_bus_is_locked(dsidev)); in dsi_display_disable()
4295 dsi_sync_vc(dsidev, 0); in dsi_display_disable()
4296 dsi_sync_vc(dsidev, 1); in dsi_display_disable()
4297 dsi_sync_vc(dsidev, 2); in dsi_display_disable()
4298 dsi_sync_vc(dsidev, 3); in dsi_display_disable()
4300 dsi_display_uninit_dsi(dsidev, disconnect_lanes, enter_ulps); in dsi_display_disable()
4302 dsi_runtime_put(dsidev); in dsi_display_disable()
4309 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_enable_te() local
4310 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_enable_te()
4474 ctx->dsidev = dsi->pdev; in dsi_cm_calc()
4491 struct dsi_data *dsi = dsi_get_dsidrv_data(ctx->dsidev); in dsi_vm_calc_blanking()
4763 ctx->dsidev = dsi->pdev; in dsi_vm_calc()
4793 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_set_config() local
4794 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_set_config()
4891 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_request_vc() local
4892 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_request_vc()
4909 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_set_vc_id() local
4910 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_set_vc_id()
4935 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_release_vc() local
4936 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_release_vc()
4946 static int dsi_get_clocks(struct platform_device *dsidev) in dsi_get_clocks() argument
4948 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_get_clocks()
4951 clk = devm_clk_get(&dsidev->dev, "fck"); in dsi_get_clocks()
4965 struct platform_device *dsidev = dsi_get_dsidev_from_dssdev(dssdev); in dsi_connect() local
4969 r = dsi_regulator_init(dsidev); in dsi_connect()
5045 static void dsi_init_output(struct platform_device *dsidev) in dsi_init_output() argument
5047 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_init_output()
5050 out->dev = &dsidev->dev; in dsi_init_output()
5063 static void dsi_uninit_output(struct platform_device *dsidev) in dsi_uninit_output() argument
5065 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_uninit_output()
5208 static int dsi_init_pll_data(struct platform_device *dsidev) in dsi_init_pll_data() argument
5210 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_init_pll_data()
5215 clk = devm_clk_get(&dsidev->dev, "sys_clk"); in dsi_init_pll_data()
5260 struct platform_device *dsidev = to_platform_device(dev); in dsi_bind() local
5268 dsi = devm_kzalloc(&dsidev->dev, sizeof(*dsi), GFP_KERNEL); in dsi_bind()
5272 dsi->pdev = dsidev; in dsi_bind()
5273 platform_set_drvdata(dsidev, dsi); in dsi_bind()
5294 res = platform_get_resource_byname(dsidev, IORESOURCE_MEM, "proto"); in dsi_bind()
5296 res = platform_get_resource(dsidev, IORESOURCE_MEM, 0); in dsi_bind()
5309 dsi->proto_base = devm_ioremap(&dsidev->dev, res->start, in dsi_bind()
5316 res = platform_get_resource_byname(dsidev, IORESOURCE_MEM, "phy"); in dsi_bind()
5318 res = platform_get_resource(dsidev, IORESOURCE_MEM, 0); in dsi_bind()
5329 dsi->phy_base = devm_ioremap(&dsidev->dev, res->start, in dsi_bind()
5336 res = platform_get_resource_byname(dsidev, IORESOURCE_MEM, "pll"); in dsi_bind()
5338 res = platform_get_resource(dsidev, IORESOURCE_MEM, 0); in dsi_bind()
5349 dsi->pll_base = devm_ioremap(&dsidev->dev, res->start, in dsi_bind()
5362 r = devm_request_irq(&dsidev->dev, dsi->irq, omap_dsi_irq_handler, in dsi_bind()
5363 IRQF_SHARED, dev_name(&dsidev->dev), dsi->pdev); in dsi_bind()
5369 if (dsidev->dev.of_node) { in dsi_bind()
5373 match = of_match_node(dsi_of_match, dsidev->dev.of_node); in dsi_bind()
5391 dsi->module_id = dsidev->id; in dsi_bind()
5401 r = dsi_get_clocks(dsidev); in dsi_bind()
5405 dsi_init_pll_data(dsidev); in dsi_bind()
5407 pm_runtime_enable(&dsidev->dev); in dsi_bind()
5409 r = dsi_runtime_get(dsidev); in dsi_bind()
5413 rev = dsi_read_reg(dsidev, DSI_REVISION); in dsi_bind()
5414 dev_dbg(&dsidev->dev, "OMAP DSI rev %d.%d\n", in dsi_bind()
5421 dsi->num_lanes_supported = 1 + REG_GET(dsidev, DSI_GNQ, 11, 9); in dsi_bind()
5425 dsi->line_buffer_size = dsi_get_line_buf_size(dsidev); in dsi_bind()
5427 dsi_init_output(dsidev); in dsi_bind()
5429 if (dsidev->dev.of_node) { in dsi_bind()
5430 r = dsi_probe_of(dsidev); in dsi_bind()
5436 r = of_platform_populate(dsidev->dev.of_node, NULL, NULL, in dsi_bind()
5437 &dsidev->dev); in dsi_bind()
5442 dsi_runtime_put(dsidev); in dsi_bind()
5459 dsi_uninit_output(dsidev); in dsi_bind()
5460 dsi_runtime_put(dsidev); in dsi_bind()
5463 pm_runtime_disable(&dsidev->dev); in dsi_bind()
5469 struct platform_device *dsidev = to_platform_device(dev); in dsi_unbind() local
5470 struct dsi_data *dsi = dsi_get_dsidrv_data(dsidev); in dsi_unbind()
5472 of_platform_depopulate(&dsidev->dev); in dsi_unbind()
5478 dsi_uninit_output(dsidev); in dsi_unbind()
5480 pm_runtime_disable(&dsidev->dev); in dsi_unbind()