summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/tegra/vic.c
diff options
context:
space:
mode:
authorThierry Reding <treding@nvidia.com>2019-02-08 16:35:13 +0300
committerThierry Reding <treding@nvidia.com>2019-10-28 13:18:37 +0300
commitaacdf19849734d1be5e407932228ae101ba5b92f (patch)
tree743e7f58ea9476bd65390628f4d25d7bfdc6541f /drivers/gpu/drm/tegra/vic.c
parent7baa943e0bb22454887edd1fffb2d00a4b842fe5 (diff)
downloadlinux-aacdf19849734d1be5e407932228ae101ba5b92f.tar.xz
drm/tegra: Move IOMMU group into host1x client
Handling of the IOMMU group attachment is common to all clients, so move the group into the client to simplify code. Signed-off-by: Thierry Reding <treding@nvidia.com>
Diffstat (limited to 'drivers/gpu/drm/tegra/vic.c')
-rw-r--r--drivers/gpu/drm/tegra/vic.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/drivers/gpu/drm/tegra/vic.c b/drivers/gpu/drm/tegra/vic.c
index e4b17c7ce708..d34b1ada422c 100644
--- a/drivers/gpu/drm/tegra/vic.c
+++ b/drivers/gpu/drm/tegra/vic.c
@@ -34,7 +34,6 @@ struct vic {
void __iomem *regs;
struct tegra_drm_client client;
struct host1x_channel *channel;
- struct iommu_group *group;
struct device *dev;
struct clk *clk;
struct reset_control *rst;
@@ -188,9 +187,8 @@ static int vic_init(struct host1x_client *client)
struct vic *vic = to_vic(drm);
int err;
- vic->group = host1x_client_iommu_attach(client, false);
- if (IS_ERR(vic->group)) {
- err = PTR_ERR(vic->group);
+ err = host1x_client_iommu_attach(client, false);
+ if (err < 0) {
dev_err(vic->dev, "failed to attach to domain: %d\n", err);
return err;
}
@@ -224,7 +222,7 @@ free_syncpt:
free_channel:
host1x_channel_put(vic->channel);
detach:
- host1x_client_iommu_detach(client, vic->group);
+ host1x_client_iommu_detach(client);
return err;
}
@@ -246,7 +244,7 @@ static int vic_exit(struct host1x_client *client)
host1x_syncpt_free(client->syncpts[0]);
host1x_channel_put(vic->channel);
- host1x_client_iommu_detach(client, vic->group);
+ host1x_client_iommu_detach(client);
return 0;
}