Lines Matching +full:imx8mq +full:- +full:mipi +full:- +full:csi2
1 // SPDX-License-Identifier: GPL-2.0+
8 * Copyright 2015-2017 Pengutronix, Lucas Stach <kernel@pengutronix.de>
20 #include <dt-bindings/power/imx7-power.h>
21 #include <dt-bindings/power/imx8mq-power.h>
22 #include <dt-bindings/power/imx8mm-power.h>
23 #include <dt-bindings/power/imx8mn-power.h>
24 #include <dt-bindings/power/imx8mp-power.h>
322 ret = pm_runtime_get_sync(domain->dev); in imx_pgc_power_up()
324 pm_runtime_put_noidle(domain->dev); in imx_pgc_power_up()
328 if (!IS_ERR(domain->regulator)) { in imx_pgc_power_up()
329 ret = regulator_enable(domain->regulator); in imx_pgc_power_up()
331 dev_err(domain->dev, in imx_pgc_power_up()
338 reset_control_assert(domain->reset); in imx_pgc_power_up()
341 ret = clk_bulk_prepare_enable(domain->num_clks, domain->clks); in imx_pgc_power_up()
343 dev_err(domain->dev, "failed to enable reset clocks\n"); in imx_pgc_power_up()
350 if (domain->bits.pxx) { in imx_pgc_power_up()
352 regmap_update_bits(domain->regmap, domain->regs->pup, in imx_pgc_power_up()
353 domain->bits.pxx, domain->bits.pxx); in imx_pgc_power_up()
358 ret = regmap_read_poll_timeout(domain->regmap, in imx_pgc_power_up()
359 domain->regs->pup, reg_val, in imx_pgc_power_up()
360 !(reg_val & domain->bits.pxx), in imx_pgc_power_up()
363 dev_err(domain->dev, "failed to command PGC\n"); in imx_pgc_power_up()
368 for_each_set_bit(pgc, &domain->pgc, 32) { in imx_pgc_power_up()
369 regmap_clear_bits(domain->regmap, GPC_PGC_CTRL(pgc), in imx_pgc_power_up()
377 reset_control_deassert(domain->reset); in imx_pgc_power_up()
380 if (domain->bits.hskreq) { in imx_pgc_power_up()
381 regmap_update_bits(domain->regmap, domain->regs->hsk, in imx_pgc_power_up()
382 domain->bits.hskreq, domain->bits.hskreq); in imx_pgc_power_up()
385 * ret = regmap_read_poll_timeout(domain->regmap, domain->regs->hsk, reg_val, in imx_pgc_power_up()
386 * (reg_val & domain->bits.hskack), 0, in imx_pgc_power_up()
389 * the BLK-CTL module BUS clk-en bit being set. in imx_pgc_power_up()
391 * There is a separate BLK-CTL module and we will have such a driver for it, in imx_pgc_power_up()
392 * that driver will set the BUS clk-en bit and handshake will be triggered in imx_pgc_power_up()
399 if (!domain->keep_clocks) in imx_pgc_power_up()
400 clk_bulk_disable_unprepare(domain->num_clks, domain->clks); in imx_pgc_power_up()
405 clk_bulk_disable_unprepare(domain->num_clks, domain->clks); in imx_pgc_power_up()
407 if (!IS_ERR(domain->regulator)) in imx_pgc_power_up()
408 regulator_disable(domain->regulator); in imx_pgc_power_up()
410 pm_runtime_put(domain->dev); in imx_pgc_power_up()
422 if (!domain->keep_clocks) { in imx_pgc_power_down()
423 ret = clk_bulk_prepare_enable(domain->num_clks, domain->clks); in imx_pgc_power_down()
425 dev_err(domain->dev, "failed to enable reset clocks\n"); in imx_pgc_power_down()
431 if (domain->bits.hskreq) { in imx_pgc_power_down()
432 regmap_clear_bits(domain->regmap, domain->regs->hsk, in imx_pgc_power_down()
433 domain->bits.hskreq); in imx_pgc_power_down()
435 ret = regmap_read_poll_timeout(domain->regmap, domain->regs->hsk, in imx_pgc_power_down()
437 !(reg_val & domain->bits.hskack), in imx_pgc_power_down()
440 dev_err(domain->dev, "failed to power down ADB400\n"); in imx_pgc_power_down()
445 if (domain->bits.pxx) { in imx_pgc_power_down()
447 for_each_set_bit(pgc, &domain->pgc, 32) { in imx_pgc_power_down()
448 regmap_update_bits(domain->regmap, GPC_PGC_CTRL(pgc), in imx_pgc_power_down()
453 regmap_update_bits(domain->regmap, domain->regs->pdn, in imx_pgc_power_down()
454 domain->bits.pxx, domain->bits.pxx); in imx_pgc_power_down()
459 ret = regmap_read_poll_timeout(domain->regmap, in imx_pgc_power_down()
460 domain->regs->pdn, reg_val, in imx_pgc_power_down()
461 !(reg_val & domain->bits.pxx), in imx_pgc_power_down()
464 dev_err(domain->dev, "failed to command PGC\n"); in imx_pgc_power_down()
470 clk_bulk_disable_unprepare(domain->num_clks, domain->clks); in imx_pgc_power_down()
472 if (!IS_ERR(domain->regulator)) { in imx_pgc_power_down()
473 ret = regulator_disable(domain->regulator); in imx_pgc_power_down()
475 dev_err(domain->dev, in imx_pgc_power_down()
482 pm_runtime_put_sync_suspend(domain->dev); in imx_pgc_power_down()
487 if (!domain->keep_clocks) in imx_pgc_power_down()
488 clk_bulk_disable_unprepare(domain->num_clks, domain->clks); in imx_pgc_power_down()
496 .name = "mipi-phy",
508 .name = "pcie-phy",
520 .name = "usb-hsic-phy",
564 .name = "mipi",
586 .name = "usb-otg1",
597 .name = "usb-otg2",
659 .name = "mipi-csi1",
670 .name = "mipi-csi2",
757 .name = "usb-otg1",
768 .name = "usb-otg2",
820 .name = "vpu-g1",
831 .name = "vpu-g2",
842 .name = "vpu-h1",
868 .name = "mipi",
924 .name = "mipi-phy1",
935 .name = "pcie-phy1",
946 .name = "usb-otg1",
957 .name = "usb-otg2",
1060 .name = "vpu-g1",
1071 .name = "vpu-g2",
1082 .name = "vpu-h1",
1107 .name = "hdmi-phy",
1118 .name = "mipi-phy2",
1143 .name = "mediamix-isp-dwp",
1234 .name = "usb-otg1",
1273 .name = "mipi",
1312 struct imx_pgc_domain *domain = pdev->dev.platform_data; in imx_pgc_domain_probe()
1315 domain->dev = &pdev->dev; in imx_pgc_domain_probe()
1317 domain->regulator = devm_regulator_get_optional(domain->dev, "power"); in imx_pgc_domain_probe()
1318 if (IS_ERR(domain->regulator)) { in imx_pgc_domain_probe()
1319 if (PTR_ERR(domain->regulator) != -ENODEV) in imx_pgc_domain_probe()
1320 return dev_err_probe(domain->dev, PTR_ERR(domain->regulator), in imx_pgc_domain_probe()
1322 } else if (domain->voltage) { in imx_pgc_domain_probe()
1323 regulator_set_voltage(domain->regulator, in imx_pgc_domain_probe()
1324 domain->voltage, domain->voltage); in imx_pgc_domain_probe()
1327 domain->num_clks = devm_clk_bulk_get_all(domain->dev, &domain->clks); in imx_pgc_domain_probe()
1328 if (domain->num_clks < 0) in imx_pgc_domain_probe()
1329 return dev_err_probe(domain->dev, domain->num_clks, in imx_pgc_domain_probe()
1332 domain->reset = devm_reset_control_array_get_optional_exclusive(domain->dev); in imx_pgc_domain_probe()
1333 if (IS_ERR(domain->reset)) in imx_pgc_domain_probe()
1334 return dev_err_probe(domain->dev, PTR_ERR(domain->reset), in imx_pgc_domain_probe()
1337 pm_runtime_enable(domain->dev); in imx_pgc_domain_probe()
1339 if (domain->bits.map) in imx_pgc_domain_probe()
1340 regmap_update_bits(domain->regmap, domain->regs->map, in imx_pgc_domain_probe()
1341 domain->bits.map, domain->bits.map); in imx_pgc_domain_probe()
1343 ret = pm_genpd_init(&domain->genpd, NULL, true); in imx_pgc_domain_probe()
1345 dev_err(domain->dev, "Failed to init power domain\n"); in imx_pgc_domain_probe()
1350 of_property_read_bool(domain->dev->of_node, "power-domains")) in imx_pgc_domain_probe()
1351 lockdep_set_subclass(&domain->genpd.mlock, 1); in imx_pgc_domain_probe()
1353 ret = of_genpd_add_provider_simple(domain->dev->of_node, in imx_pgc_domain_probe()
1354 &domain->genpd); in imx_pgc_domain_probe()
1356 dev_err(domain->dev, "Failed to add genpd provider\n"); in imx_pgc_domain_probe()
1363 pm_genpd_remove(&domain->genpd); in imx_pgc_domain_probe()
1365 if (domain->bits.map) in imx_pgc_domain_probe()
1366 regmap_update_bits(domain->regmap, domain->regs->map, in imx_pgc_domain_probe()
1367 domain->bits.map, 0); in imx_pgc_domain_probe()
1368 pm_runtime_disable(domain->dev); in imx_pgc_domain_probe()
1375 struct imx_pgc_domain *domain = pdev->dev.platform_data; in imx_pgc_domain_remove()
1377 of_genpd_del_provider(domain->dev->of_node); in imx_pgc_domain_remove()
1378 pm_genpd_remove(&domain->genpd); in imx_pgc_domain_remove()
1380 if (domain->bits.map) in imx_pgc_domain_remove()
1381 regmap_update_bits(domain->regmap, domain->regs->map, in imx_pgc_domain_remove()
1382 domain->bits.map, 0); in imx_pgc_domain_remove()
1384 pm_runtime_disable(domain->dev); in imx_pgc_domain_remove()
1420 { "imx-pgc-domain", },
1426 .name = "imx-pgc",
1438 of_device_get_match_data(&pdev->dev); in builtin_platform_driver()
1444 .rd_table = domain_data->reg_access_table, in builtin_platform_driver()
1445 .wr_table = domain_data->reg_access_table, in builtin_platform_driver()
1448 struct device *dev = &pdev->dev; in builtin_platform_driver()
1454 pgc_np = of_get_child_by_name(dev->of_node, "pgc"); in builtin_platform_driver()
1457 return -EINVAL; in builtin_platform_driver()
1486 if (domain_index >= domain_data->domains_num) { in builtin_platform_driver()
1493 pd_pdev = platform_device_alloc("imx-pgc-domain", in builtin_platform_driver()
1498 return -ENOMEM; in builtin_platform_driver()
1502 &domain_data->domains[domain_index], in builtin_platform_driver()
1503 sizeof(domain_data->domains[domain_index])); in builtin_platform_driver()
1510 domain = pd_pdev->dev.platform_data; in builtin_platform_driver()
1511 domain->regmap = regmap; in builtin_platform_driver()
1512 domain->regs = domain_data->pgc_regs; in builtin_platform_driver()
1514 domain->genpd.power_on = imx_pgc_power_up; in builtin_platform_driver()
1515 domain->genpd.power_off = imx_pgc_power_down; in builtin_platform_driver()
1517 pd_pdev->dev.parent = dev; in builtin_platform_driver()
1518 pd_pdev->dev.of_node = np; in builtin_platform_driver()
1532 { .compatible = "fsl,imx7d-gpc", .data = &imx7_pgc_domain_data, },
1533 { .compatible = "fsl,imx8mm-gpc", .data = &imx8mm_pgc_domain_data, },
1534 { .compatible = "fsl,imx8mn-gpc", .data = &imx8mn_pgc_domain_data, },
1535 { .compatible = "fsl,imx8mp-gpc", .data = &imx8mp_pgc_domain_data, },
1536 { .compatible = "fsl,imx8mq-gpc", .data = &imx8m_pgc_domain_data, },
1542 .name = "imx-gpcv2",