Commit 43bb3a6d authored by Vijendar Mukunda's avatar Vijendar Mukunda Committed by Alex Deucher

drm/amd/amdgpu: Disabling Power Gating for Stoney platform

Power Gating is disabled in Stoney platform.
Reviewed-by: default avatarAlex Deucher <alexander.deucher@amd.com>
Signed-off-by: default avatarVijendar Mukunda <Vijendar.Mukunda@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 81454cad
...@@ -285,19 +285,20 @@ static int acp_hw_init(void *handle) ...@@ -285,19 +285,20 @@ static int acp_hw_init(void *handle)
return 0; return 0;
else if (r) else if (r)
return r; return r;
if (adev->asic_type != CHIP_STONEY) {
adev->acp.acp_genpd = kzalloc(sizeof(struct acp_pm_domain), GFP_KERNEL);
if (adev->acp.acp_genpd == NULL)
return -ENOMEM;
adev->acp.acp_genpd = kzalloc(sizeof(struct acp_pm_domain), GFP_KERNEL); adev->acp.acp_genpd->gpd.name = "ACP_AUDIO";
if (adev->acp.acp_genpd == NULL) adev->acp.acp_genpd->gpd.power_off = acp_poweroff;
return -ENOMEM; adev->acp.acp_genpd->gpd.power_on = acp_poweron;
adev->acp.acp_genpd->gpd.name = "ACP_AUDIO";
adev->acp.acp_genpd->gpd.power_off = acp_poweroff;
adev->acp.acp_genpd->gpd.power_on = acp_poweron;
adev->acp.acp_genpd->cgs_dev = adev->acp.cgs_device; adev->acp.acp_genpd->cgs_dev = adev->acp.cgs_device;
pm_genpd_init(&adev->acp.acp_genpd->gpd, NULL, false); pm_genpd_init(&adev->acp.acp_genpd->gpd, NULL, false);
}
adev->acp.acp_cell = kzalloc(sizeof(struct mfd_cell) * ACP_DEVS, adev->acp.acp_cell = kzalloc(sizeof(struct mfd_cell) * ACP_DEVS,
GFP_KERNEL); GFP_KERNEL);
...@@ -388,12 +389,14 @@ static int acp_hw_init(void *handle) ...@@ -388,12 +389,14 @@ static int acp_hw_init(void *handle)
if (r) if (r)
return r; return r;
for (i = 0; i < ACP_DEVS ; i++) { if (adev->asic_type != CHIP_STONEY) {
dev = get_mfd_cell_dev(adev->acp.acp_cell[i].name, i); for (i = 0; i < ACP_DEVS ; i++) {
r = pm_genpd_add_device(&adev->acp.acp_genpd->gpd, dev); dev = get_mfd_cell_dev(adev->acp.acp_cell[i].name, i);
if (r) { r = pm_genpd_add_device(&adev->acp.acp_genpd->gpd, dev);
dev_err(dev, "Failed to add dev to genpd\n"); if (r) {
return r; dev_err(dev, "Failed to add dev to genpd\n");
return r;
}
} }
} }
...@@ -413,20 +416,22 @@ static int acp_hw_fini(void *handle) ...@@ -413,20 +416,22 @@ static int acp_hw_fini(void *handle)
struct amdgpu_device *adev = (struct amdgpu_device *)handle; struct amdgpu_device *adev = (struct amdgpu_device *)handle;
/* return early if no ACP */ /* return early if no ACP */
if (!adev->acp.acp_genpd) if (!adev->acp.acp_cell)
return 0; return 0;
for (i = 0; i < ACP_DEVS ; i++) { if (adev->acp.acp_genpd) {
dev = get_mfd_cell_dev(adev->acp.acp_cell[i].name, i); for (i = 0; i < ACP_DEVS ; i++) {
ret = pm_genpd_remove_device(&adev->acp.acp_genpd->gpd, dev); dev = get_mfd_cell_dev(adev->acp.acp_cell[i].name, i);
/* If removal fails, dont giveup and try rest */ ret = pm_genpd_remove_device(&adev->acp.acp_genpd->gpd, dev);
if (ret) /* If removal fails, dont giveup and try rest */
dev_err(dev, "remove dev from genpd failed\n"); if (ret)
dev_err(dev, "remove dev from genpd failed\n");
}
kfree(adev->acp.acp_genpd);
} }
mfd_remove_devices(adev->acp.parent); mfd_remove_devices(adev->acp.parent);
kfree(adev->acp.acp_res); kfree(adev->acp.acp_res);
kfree(adev->acp.acp_genpd);
kfree(adev->acp.acp_cell); kfree(adev->acp.acp_cell);
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment