aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2
diff options
context:
space:
mode:
authorTomi Valkeinen <tomi.valkeinen@ti.com>2011-07-09 22:39:45 -0400
committerPaul Walmsley <paul@pwsan.com>2011-07-10 07:26:30 -0400
commitda7cdfac1b0c58d6863532dd3b432c3fbc034978 (patch)
tree3b31a71585cf8902d723ca5598fc9b6e81369017 /arch/arm/mach-omap2
parent3a23aafcde66f6327bda0a6423586dfd8d694eb4 (diff)
OMAP4: hwmod data: Change DSS main_clk scheme
Currently using pm_runtime with DSS requires the DSS driver to enable the DSS functional clock before calling pm_runtime_get(). That makes it impossible to use pm_runtime in DSS as it is meant to be used, with pm_runtime callbacks. This patch changes the hwmod database for OMAP4 so that enabling the hwmod via pm_runtime will also enable the DSS functional clock, allowing us to use pm_runtime properly in DSS driver. The DSS HWMOD side is not really correct, not before nor after this patch, and getting DSS to retention will probably not work currently. However, it is not supported in the mainline kernel anyway, so this won't break anything. So this patch allows us to write the pm_runtime adaptation for the DSS driver the way it should be done, and the HWMOD/PM side can be fixed later. Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com> Signed-off-by: Benoit Cousson <b-cousson@ti.com> Signed-off-by: Paul Walmsley <paul@pwsan.com>
Diffstat (limited to 'arch/arm/mach-omap2')
-rw-r--r--arch/arm/mach-omap2/omap_hwmod_44xx_data.c28
1 files changed, 14 insertions, 14 deletions
diff --git a/arch/arm/mach-omap2/omap_hwmod_44xx_data.c b/arch/arm/mach-omap2/omap_hwmod_44xx_data.c
index a7fbe5cb81d3..b25ab836fbf0 100644
--- a/arch/arm/mach-omap2/omap_hwmod_44xx_data.c
+++ b/arch/arm/mach-omap2/omap_hwmod_44xx_data.c
@@ -1136,7 +1136,7 @@ static struct omap_hwmod_addr_space omap44xx_dss_dma_addrs[] = {
1136static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss = { 1136static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss = {
1137 .master = &omap44xx_l3_main_2_hwmod, 1137 .master = &omap44xx_l3_main_2_hwmod,
1138 .slave = &omap44xx_dss_hwmod, 1138 .slave = &omap44xx_dss_hwmod,
1139 .clk = "l3_div_ck", 1139 .clk = "dss_fck",
1140 .addr = omap44xx_dss_dma_addrs, 1140 .addr = omap44xx_dss_dma_addrs,
1141 .user = OCP_USER_SDMA, 1141 .user = OCP_USER_SDMA,
1142}; 1142};
@@ -1175,7 +1175,7 @@ static struct omap_hwmod_opt_clk dss_opt_clks[] = {
1175static struct omap_hwmod omap44xx_dss_hwmod = { 1175static struct omap_hwmod omap44xx_dss_hwmod = {
1176 .name = "dss_core", 1176 .name = "dss_core",
1177 .class = &omap44xx_dss_hwmod_class, 1177 .class = &omap44xx_dss_hwmod_class,
1178 .main_clk = "dss_fck", 1178 .main_clk = "dss_dss_clk",
1179 .prcm = { 1179 .prcm = {
1180 .omap4 = { 1180 .omap4 = {
1181 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL, 1181 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
@@ -1238,7 +1238,7 @@ static struct omap_hwmod_addr_space omap44xx_dss_dispc_dma_addrs[] = {
1238static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_dispc = { 1238static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_dispc = {
1239 .master = &omap44xx_l3_main_2_hwmod, 1239 .master = &omap44xx_l3_main_2_hwmod,
1240 .slave = &omap44xx_dss_dispc_hwmod, 1240 .slave = &omap44xx_dss_dispc_hwmod,
1241 .clk = "l3_div_ck", 1241 .clk = "dss_fck",
1242 .addr = omap44xx_dss_dispc_dma_addrs, 1242 .addr = omap44xx_dss_dispc_dma_addrs,
1243 .user = OCP_USER_SDMA, 1243 .user = OCP_USER_SDMA,
1244}; 1244};
@@ -1279,7 +1279,7 @@ static struct omap_hwmod omap44xx_dss_dispc_hwmod = {
1279 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET, 1279 .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
1280 .mpu_irqs = omap44xx_dss_dispc_irqs, 1280 .mpu_irqs = omap44xx_dss_dispc_irqs,
1281 .sdma_reqs = omap44xx_dss_dispc_sdma_reqs, 1281 .sdma_reqs = omap44xx_dss_dispc_sdma_reqs,
1282 .main_clk = "dss_fck", 1282 .main_clk = "dss_dss_clk",
1283 .prcm = { 1283 .prcm = {
1284 .omap4 = { 1284 .omap4 = {
1285 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL, 1285 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
@@ -1338,7 +1338,7 @@ static struct omap_hwmod_addr_space omap44xx_dss_dsi1_dma_addrs[] = {
1338static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_dsi1 = { 1338static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_dsi1 = {
1339 .master = &omap44xx_l3_main_2_hwmod, 1339 .master = &omap44xx_l3_main_2_hwmod,
1340 .slave = &omap44xx_dss_dsi1_hwmod, 1340 .slave = &omap44xx_dss_dsi1_hwmod,
1341 .clk = "l3_div_ck", 1341 .clk = "dss_fck",
1342 .addr = omap44xx_dss_dsi1_dma_addrs, 1342 .addr = omap44xx_dss_dsi1_dma_addrs,
1343 .user = OCP_USER_SDMA, 1343 .user = OCP_USER_SDMA,
1344}; 1344};
@@ -1376,7 +1376,7 @@ static struct omap_hwmod omap44xx_dss_dsi1_hwmod = {
1376 .class = &omap44xx_dsi_hwmod_class, 1376 .class = &omap44xx_dsi_hwmod_class,
1377 .mpu_irqs = omap44xx_dss_dsi1_irqs, 1377 .mpu_irqs = omap44xx_dss_dsi1_irqs,
1378 .sdma_reqs = omap44xx_dss_dsi1_sdma_reqs, 1378 .sdma_reqs = omap44xx_dss_dsi1_sdma_reqs,
1379 .main_clk = "dss_fck", 1379 .main_clk = "dss_dss_clk",
1380 .prcm = { 1380 .prcm = {
1381 .omap4 = { 1381 .omap4 = {
1382 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL, 1382 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
@@ -1414,7 +1414,7 @@ static struct omap_hwmod_addr_space omap44xx_dss_dsi2_dma_addrs[] = {
1414static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_dsi2 = { 1414static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_dsi2 = {
1415 .master = &omap44xx_l3_main_2_hwmod, 1415 .master = &omap44xx_l3_main_2_hwmod,
1416 .slave = &omap44xx_dss_dsi2_hwmod, 1416 .slave = &omap44xx_dss_dsi2_hwmod,
1417 .clk = "l3_div_ck", 1417 .clk = "dss_fck",
1418 .addr = omap44xx_dss_dsi2_dma_addrs, 1418 .addr = omap44xx_dss_dsi2_dma_addrs,
1419 .user = OCP_USER_SDMA, 1419 .user = OCP_USER_SDMA,
1420}; 1420};
@@ -1452,7 +1452,7 @@ static struct omap_hwmod omap44xx_dss_dsi2_hwmod = {
1452 .class = &omap44xx_dsi_hwmod_class, 1452 .class = &omap44xx_dsi_hwmod_class,
1453 .mpu_irqs = omap44xx_dss_dsi2_irqs, 1453 .mpu_irqs = omap44xx_dss_dsi2_irqs,
1454 .sdma_reqs = omap44xx_dss_dsi2_sdma_reqs, 1454 .sdma_reqs = omap44xx_dss_dsi2_sdma_reqs,
1455 .main_clk = "dss_fck", 1455 .main_clk = "dss_dss_clk",
1456 .prcm = { 1456 .prcm = {
1457 .omap4 = { 1457 .omap4 = {
1458 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL, 1458 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
@@ -1510,7 +1510,7 @@ static struct omap_hwmod_addr_space omap44xx_dss_hdmi_dma_addrs[] = {
1510static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_hdmi = { 1510static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_hdmi = {
1511 .master = &omap44xx_l3_main_2_hwmod, 1511 .master = &omap44xx_l3_main_2_hwmod,
1512 .slave = &omap44xx_dss_hdmi_hwmod, 1512 .slave = &omap44xx_dss_hdmi_hwmod,
1513 .clk = "l3_div_ck", 1513 .clk = "dss_fck",
1514 .addr = omap44xx_dss_hdmi_dma_addrs, 1514 .addr = omap44xx_dss_hdmi_dma_addrs,
1515 .user = OCP_USER_SDMA, 1515 .user = OCP_USER_SDMA,
1516}; 1516};
@@ -1548,7 +1548,7 @@ static struct omap_hwmod omap44xx_dss_hdmi_hwmod = {
1548 .class = &omap44xx_hdmi_hwmod_class, 1548 .class = &omap44xx_hdmi_hwmod_class,
1549 .mpu_irqs = omap44xx_dss_hdmi_irqs, 1549 .mpu_irqs = omap44xx_dss_hdmi_irqs,
1550 .sdma_reqs = omap44xx_dss_hdmi_sdma_reqs, 1550 .sdma_reqs = omap44xx_dss_hdmi_sdma_reqs,
1551 .main_clk = "dss_fck", 1551 .main_clk = "dss_dss_clk",
1552 .prcm = { 1552 .prcm = {
1553 .omap4 = { 1553 .omap4 = {
1554 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL, 1554 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
@@ -1601,7 +1601,7 @@ static struct omap_hwmod_addr_space omap44xx_dss_rfbi_dma_addrs[] = {
1601static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_rfbi = { 1601static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_rfbi = {
1602 .master = &omap44xx_l3_main_2_hwmod, 1602 .master = &omap44xx_l3_main_2_hwmod,
1603 .slave = &omap44xx_dss_rfbi_hwmod, 1603 .slave = &omap44xx_dss_rfbi_hwmod,
1604 .clk = "l3_div_ck", 1604 .clk = "dss_fck",
1605 .addr = omap44xx_dss_rfbi_dma_addrs, 1605 .addr = omap44xx_dss_rfbi_dma_addrs,
1606 .user = OCP_USER_SDMA, 1606 .user = OCP_USER_SDMA,
1607}; 1607};
@@ -1638,7 +1638,7 @@ static struct omap_hwmod omap44xx_dss_rfbi_hwmod = {
1638 .name = "dss_rfbi", 1638 .name = "dss_rfbi",
1639 .class = &omap44xx_rfbi_hwmod_class, 1639 .class = &omap44xx_rfbi_hwmod_class,
1640 .sdma_reqs = omap44xx_dss_rfbi_sdma_reqs, 1640 .sdma_reqs = omap44xx_dss_rfbi_sdma_reqs,
1641 .main_clk = "dss_fck", 1641 .main_clk = "dss_dss_clk",
1642 .prcm = { 1642 .prcm = {
1643 .omap4 = { 1643 .omap4 = {
1644 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL, 1644 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,
@@ -1675,7 +1675,7 @@ static struct omap_hwmod_addr_space omap44xx_dss_venc_dma_addrs[] = {
1675static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_venc = { 1675static struct omap_hwmod_ocp_if omap44xx_l3_main_2__dss_venc = {
1676 .master = &omap44xx_l3_main_2_hwmod, 1676 .master = &omap44xx_l3_main_2_hwmod,
1677 .slave = &omap44xx_dss_venc_hwmod, 1677 .slave = &omap44xx_dss_venc_hwmod,
1678 .clk = "l3_div_ck", 1678 .clk = "dss_fck",
1679 .addr = omap44xx_dss_venc_dma_addrs, 1679 .addr = omap44xx_dss_venc_dma_addrs,
1680 .user = OCP_USER_SDMA, 1680 .user = OCP_USER_SDMA,
1681}; 1681};
@@ -1707,7 +1707,7 @@ static struct omap_hwmod_ocp_if *omap44xx_dss_venc_slaves[] = {
1707static struct omap_hwmod omap44xx_dss_venc_hwmod = { 1707static struct omap_hwmod omap44xx_dss_venc_hwmod = {
1708 .name = "dss_venc", 1708 .name = "dss_venc",
1709 .class = &omap44xx_venc_hwmod_class, 1709 .class = &omap44xx_venc_hwmod_class,
1710 .main_clk = "dss_fck", 1710 .main_clk = "dss_dss_clk",
1711 .prcm = { 1711 .prcm = {
1712 .omap4 = { 1712 .omap4 = {
1713 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL, 1713 .clkctrl_reg = OMAP4430_CM_DSS_DSS_CLKCTRL,