summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/tegra/gr3d.c
diff options
context:
space:
mode:
authorThierry Reding <treding@nvidia.com>2018-05-04 15:02:24 +0200
committerThierry Reding <treding@nvidia.com>2018-05-17 14:08:40 +0200
commit0c407de5ed1a329468122cbf4f3e727e0c1e3f36 (patch)
tree3f96f17886dcfc453e117f3820fb3c24f80133f1 /drivers/gpu/drm/tegra/gr3d.c
parent230630bd3834af0ea6ec75354ec21819de148ee1 (diff)
downloadlwn-0c407de5ed1a329468122cbf4f3e727e0c1e3f36.tar.gz
lwn-0c407de5ed1a329468122cbf4f3e727e0c1e3f36.zip
drm/tegra: Refactor IOMMU attach/detach
Attaching to and detaching from an IOMMU uses the same code sequence in every driver, so factor it out into separate helpers. Reviewed-by: Dmitry Osipenko <digetx@gmail.com> Signed-off-by: Thierry Reding <treding@nvidia.com>
Diffstat (limited to 'drivers/gpu/drm/tegra/gr3d.c')
-rw-r--r--drivers/gpu/drm/tegra/gr3d.c31
1 files changed, 7 insertions, 24 deletions
diff --git a/drivers/gpu/drm/tegra/gr3d.c b/drivers/gpu/drm/tegra/gr3d.c
index 9303278efc1d..b00002f1c590 100644
--- a/drivers/gpu/drm/tegra/gr3d.c
+++ b/drivers/gpu/drm/tegra/gr3d.c
@@ -42,7 +42,6 @@ static int gr3d_init(struct host1x_client *client)
struct tegra_drm_client *drm = host1x_to_drm_client(client);
struct drm_device *dev = dev_get_drvdata(client->parent);
unsigned long flags = HOST1X_SYNCPT_HAS_BASE;
- struct tegra_drm *tegra = dev->dev_private;
struct gr3d *gr3d = to_gr3d(drm);
int err;
@@ -57,19 +56,11 @@ static int gr3d_init(struct host1x_client *client)
goto put;
}
- if (tegra->domain) {
- gr3d->group = iommu_group_get(client->dev);
-
- if (gr3d->group) {
- err = iommu_attach_group(tegra->domain, gr3d->group);
- if (err < 0) {
- dev_err(client->dev,
- "failed to attach to domain: %d\n",
- err);
- iommu_group_put(gr3d->group);
- goto free;
- }
- }
+ gr3d->group = host1x_client_iommu_attach(client, false);
+ if (IS_ERR(gr3d->group)) {
+ err = PTR_ERR(gr3d->group);
+ dev_err(client->dev, "failed to attach to domain: %d\n", err);
+ goto free;
}
err = tegra_drm_register_client(dev->dev_private, drm);
@@ -81,10 +72,7 @@ static int gr3d_init(struct host1x_client *client)
return 0;
detach:
- if (gr3d->group) {
- iommu_detach_group(tegra->domain, gr3d->group);
- iommu_group_put(gr3d->group);
- }
+ host1x_client_iommu_detach(client, gr3d->group);
free:
host1x_syncpt_free(client->syncpts[0]);
put:
@@ -96,7 +84,6 @@ static int gr3d_exit(struct host1x_client *client)
{
struct tegra_drm_client *drm = host1x_to_drm_client(client);
struct drm_device *dev = dev_get_drvdata(client->parent);
- struct tegra_drm *tegra = dev->dev_private;
struct gr3d *gr3d = to_gr3d(drm);
int err;
@@ -104,14 +91,10 @@ static int gr3d_exit(struct host1x_client *client)
if (err < 0)
return err;
+ host1x_client_iommu_detach(client, gr3d->group);
host1x_syncpt_free(client->syncpts[0]);
host1x_channel_put(gr3d->channel);
- if (gr3d->group) {
- iommu_detach_group(tegra->domain, gr3d->group);
- iommu_group_put(gr3d->group);
- }
-
return 0;
}