Lines Matching +full:ext +full:- +full:refclk

1 // SPDX-License-Identifier: GPL-2.0+
18 #include <linux/media-bus-format.h>
155 struct clk *refclk; member
214 return ret == val_size ? 0 : -EINVAL; in chipone_dsi_read()
240 ret = regmap_read(icn->regmap, reg, &pval); in chipone_readb()
247 return regmap_write(icn->regmap, reg, val); in chipone_writeb()
254 unsigned int mode_clock = mode->clock * 1000; in chipone_configure_pll()
271 * P is pre-divider, register PLL_REF_DIV[3:0] is 1:n divider in chipone_configure_pll()
274 * S is post-divider, register PLL_REF_DIV[7:5] is 2^(n+1) divider in chipone_configure_pll()
276 * It seems the PLL input clock after applying P pre-divider have in chipone_configure_pll()
279 if (icn->refclk) in chipone_configure_pll()
280 fin = icn->refclk_rate; in chipone_configure_pll()
282 fin = icn->dsi->hs_rate / 4; /* in Hz */ in chipone_configure_pll()
311 /* Apply post-divider */ in chipone_configure_pll()
314 delta = abs(mode_clock - freq_out); in chipone_configure_pll()
326 dev_dbg(icn->dev, in chipone_configure_pll()
329 min_delta, icn->refclk ? "EXT" : "DSI", fin, in chipone_configure_pll()
333 if (best_p_pot) /* Prefer /2 pre-divider */ in chipone_configure_pll()
338 icn->refclk ? PLL_CTRL_6_EXTERNAL : PLL_CTRL_6_MIPI_CLK); in chipone_configure_pll()
347 struct drm_atomic_state *state = old_bridge_state->base.state; in chipone_atomic_enable()
348 struct drm_display_mode *mode = &icn->mode; in chipone_atomic_enable()
359 dev_dbg(icn->dev, in chipone_atomic_enable()
364 dev_dbg(icn->dev, "Invalid Chip IDs, aborting configuration\n"); in chipone_atomic_enable()
370 bus_flags = bridge_state->output_bus_cfg.flags; in chipone_atomic_enable()
372 if (icn->interface_i2c) in chipone_atomic_enable()
377 chipone_writeb(icn, HACTIVE_LI, mode->hdisplay & 0xff); in chipone_atomic_enable()
379 chipone_writeb(icn, VACTIVE_LI, mode->vdisplay & 0xff); in chipone_atomic_enable()
386 ((mode->hdisplay >> 8) & 0xf) | in chipone_atomic_enable()
387 (((mode->vdisplay >> 8) & 0xf) << 4)); in chipone_atomic_enable()
389 hfp = mode->hsync_start - mode->hdisplay; in chipone_atomic_enable()
390 hsync = mode->hsync_end - mode->hsync_start; in chipone_atomic_enable()
391 hbp = mode->htotal - mode->hsync_end; in chipone_atomic_enable()
402 chipone_writeb(icn, VFP, mode->vsync_start - mode->vdisplay); in chipone_atomic_enable()
404 chipone_writeb(icn, VSYNC, mode->vsync_end - mode->vsync_start); in chipone_atomic_enable()
406 chipone_writeb(icn, VBP, mode->vtotal - mode->vsync_end); in chipone_atomic_enable()
414 DSI_CTRL_UNKNOWN | DSI_CTRL_DSI_LANES(icn->dsi->lanes - 1)); in chipone_atomic_enable()
421 pol = ((mode->flags & DRM_MODE_FLAG_PHSYNC) ? BIST_POL_HSYNC_POL : 0) | in chipone_atomic_enable()
422 ((mode->flags & DRM_MODE_FLAG_PVSYNC) ? BIST_POL_VSYNC_POL : 0) | in chipone_atomic_enable()
453 if (icn->vdd1) { in chipone_atomic_pre_enable()
454 ret = regulator_enable(icn->vdd1); in chipone_atomic_pre_enable()
456 DRM_DEV_ERROR(icn->dev, in chipone_atomic_pre_enable()
460 if (icn->vdd2) { in chipone_atomic_pre_enable()
461 ret = regulator_enable(icn->vdd2); in chipone_atomic_pre_enable()
463 DRM_DEV_ERROR(icn->dev, in chipone_atomic_pre_enable()
467 if (icn->vdd3) { in chipone_atomic_pre_enable()
468 ret = regulator_enable(icn->vdd3); in chipone_atomic_pre_enable()
470 DRM_DEV_ERROR(icn->dev, in chipone_atomic_pre_enable()
474 ret = clk_prepare_enable(icn->refclk); in chipone_atomic_pre_enable()
476 DRM_DEV_ERROR(icn->dev, in chipone_atomic_pre_enable()
479 gpiod_set_value(icn->enable_gpio, 1); in chipone_atomic_pre_enable()
489 clk_disable_unprepare(icn->refclk); in chipone_atomic_post_disable()
491 if (icn->vdd1) in chipone_atomic_post_disable()
492 regulator_disable(icn->vdd1); in chipone_atomic_post_disable()
494 if (icn->vdd2) in chipone_atomic_post_disable()
495 regulator_disable(icn->vdd2); in chipone_atomic_post_disable()
497 if (icn->vdd3) in chipone_atomic_post_disable()
498 regulator_disable(icn->vdd3); in chipone_atomic_post_disable()
500 gpiod_set_value(icn->enable_gpio, 0); in chipone_atomic_post_disable()
509 drm_mode_copy(&icn->mode, adjusted_mode); in chipone_mode_set()
514 struct mipi_dsi_device *dsi = icn->dsi; in chipone_dsi_attach()
515 struct device *dev = icn->dev; in chipone_dsi_attach()
518 dsi_lanes = drm_of_get_data_lanes_count_ep(dev->of_node, 0, 0, 1, 4); in chipone_dsi_attach()
521 * If the 'data-lanes' property does not exist in DT or is invalid, in chipone_dsi_attach()
522 * default to previously hard-coded behavior, which was 4 data lanes. in chipone_dsi_attach()
525 icn->dsi->lanes = 4; in chipone_dsi_attach()
527 icn->dsi->lanes = dsi_lanes; in chipone_dsi_attach()
529 dsi->format = MIPI_DSI_FMT_RGB888; in chipone_dsi_attach()
530 dsi->mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_BURST | in chipone_dsi_attach()
532 dsi->hs_rate = 500000000; in chipone_dsi_attach()
533 dsi->lp_rate = 16000000; in chipone_dsi_attach()
537 dev_err(icn->dev, "failed to attach dsi\n"); in chipone_dsi_attach()
544 struct device *dev = icn->dev; in chipone_dsi_host_attach()
557 endpoint = of_graph_get_endpoint_by_regs(dev->of_node, 0, 0); in chipone_dsi_host_attach()
562 return -EINVAL; in chipone_dsi_host_attach()
567 return dev_err_probe(dev, -EPROBE_DEFER, "failed to find dsi host\n"); in chipone_dsi_host_attach()
575 icn->dsi = dsi; in chipone_dsi_host_attach()
588 return drm_bridge_attach(bridge->encoder, icn->panel_bridge, bridge, flags); in chipone_attach()
610 /* This is the DSI-end bus format */ in chipone_atomic_get_input_bus_fmts()
631 struct device *dev = icn->dev; in chipone_parse_dt()
634 icn->refclk = devm_clk_get_optional(dev, "refclk"); in chipone_parse_dt()
635 if (IS_ERR(icn->refclk)) { in chipone_parse_dt()
636 ret = PTR_ERR(icn->refclk); in chipone_parse_dt()
637 DRM_DEV_ERROR(dev, "failed to get REFCLK clock: %d\n", ret); in chipone_parse_dt()
639 } else if (icn->refclk) { in chipone_parse_dt()
640 icn->refclk_rate = clk_get_rate(icn->refclk); in chipone_parse_dt()
641 if (icn->refclk_rate < 10000000 || icn->refclk_rate > 154000000) { in chipone_parse_dt()
642 DRM_DEV_ERROR(dev, "REFCLK out of range: %ld Hz\n", in chipone_parse_dt()
643 icn->refclk_rate); in chipone_parse_dt()
644 return -EINVAL; in chipone_parse_dt()
648 icn->vdd1 = devm_regulator_get_optional(dev, "vdd1"); in chipone_parse_dt()
649 if (IS_ERR(icn->vdd1)) { in chipone_parse_dt()
650 ret = PTR_ERR(icn->vdd1); in chipone_parse_dt()
651 if (ret == -EPROBE_DEFER) in chipone_parse_dt()
652 return -EPROBE_DEFER; in chipone_parse_dt()
653 icn->vdd1 = NULL; in chipone_parse_dt()
657 icn->vdd2 = devm_regulator_get_optional(dev, "vdd2"); in chipone_parse_dt()
658 if (IS_ERR(icn->vdd2)) { in chipone_parse_dt()
659 ret = PTR_ERR(icn->vdd2); in chipone_parse_dt()
660 if (ret == -EPROBE_DEFER) in chipone_parse_dt()
661 return -EPROBE_DEFER; in chipone_parse_dt()
662 icn->vdd2 = NULL; in chipone_parse_dt()
666 icn->vdd3 = devm_regulator_get_optional(dev, "vdd3"); in chipone_parse_dt()
667 if (IS_ERR(icn->vdd3)) { in chipone_parse_dt()
668 ret = PTR_ERR(icn->vdd3); in chipone_parse_dt()
669 if (ret == -EPROBE_DEFER) in chipone_parse_dt()
670 return -EPROBE_DEFER; in chipone_parse_dt()
671 icn->vdd3 = NULL; in chipone_parse_dt()
675 icn->enable_gpio = devm_gpiod_get(dev, "enable", GPIOD_OUT_LOW); in chipone_parse_dt()
676 if (IS_ERR(icn->enable_gpio)) { in chipone_parse_dt()
678 return PTR_ERR(icn->enable_gpio); in chipone_parse_dt()
681 icn->panel_bridge = devm_drm_of_get_bridge(dev, dev->of_node, 1, 0); in chipone_parse_dt()
682 if (IS_ERR(icn->panel_bridge)) in chipone_parse_dt()
683 return PTR_ERR(icn->panel_bridge); in chipone_parse_dt()
695 return -ENOMEM; in chipone_common_probe()
697 icn->dev = dev; in chipone_common_probe()
703 icn->bridge.funcs = &chipone_bridge_funcs; in chipone_common_probe()
704 icn->bridge.type = DRM_MODE_CONNECTOR_DPI; in chipone_common_probe()
705 icn->bridge.of_node = dev->of_node; in chipone_common_probe()
714 struct device *dev = &dsi->dev; in chipone_dsi_probe()
722 icn->regmap = devm_regmap_init(dev, &chipone_dsi_regmap_bus, in chipone_dsi_probe()
724 if (IS_ERR(icn->regmap)) in chipone_dsi_probe()
725 return PTR_ERR(icn->regmap); in chipone_dsi_probe()
727 icn->interface_i2c = false; in chipone_dsi_probe()
728 icn->dsi = dsi; in chipone_dsi_probe()
732 drm_bridge_add(&icn->bridge); in chipone_dsi_probe()
736 drm_bridge_remove(&icn->bridge); in chipone_dsi_probe()
743 struct device *dev = &client->dev; in chipone_i2c_probe()
751 icn->regmap = devm_regmap_init_i2c(client, &chipone_regmap_config); in chipone_i2c_probe()
752 if (IS_ERR(icn->regmap)) in chipone_i2c_probe()
753 return PTR_ERR(icn->regmap); in chipone_i2c_probe()
755 icn->interface_i2c = true; in chipone_i2c_probe()
756 icn->client = client; in chipone_i2c_probe()
760 drm_bridge_add(&icn->bridge); in chipone_i2c_probe()
770 drm_bridge_remove(&icn->bridge); in chipone_dsi_remove()
783 .name = "chipone-icn6211",
798 .name = "chipone-icn6211-i2c",
822 MODULE_DESCRIPTION("Chipone ICN6211 MIPI-DSI to RGB Converter Bridge");