OSDN Git Service

drm/tegra: vic: Track interface version
authorThierry Reding <treding@nvidia.com>
Wed, 16 May 2018 15:08:04 +0000 (17:08 +0200)
committerThierry Reding <treding@nvidia.com>
Fri, 18 May 2018 20:00:41 +0000 (22:00 +0200)
Set the interface version implemented by the VIC module. This allows
userspace to pass the correct command stream when programming the VIC
module.

Reviewed-by: Dmitry Osipenko <digetx@gmail.com>
Signed-off-by: Thierry Reding <treding@nvidia.com>
drivers/gpu/drm/tegra/vic.c

index f5794dd..9f657a6 100644 (file)
@@ -25,6 +25,7 @@
 
 struct vic_config {
        const char *firmware;
+       unsigned int version;
 };
 
 struct vic {
@@ -264,18 +265,21 @@ static const struct tegra_drm_client_ops vic_ops = {
 
 static const struct vic_config vic_t124_config = {
        .firmware = NVIDIA_TEGRA_124_VIC_FIRMWARE,
+       .version = 0x40,
 };
 
 #define NVIDIA_TEGRA_210_VIC_FIRMWARE "nvidia/tegra210/vic04_ucode.bin"
 
 static const struct vic_config vic_t210_config = {
        .firmware = NVIDIA_TEGRA_210_VIC_FIRMWARE,
+       .version = 0x21,
 };
 
 #define NVIDIA_TEGRA_186_VIC_FIRMWARE "nvidia/tegra186/vic04_ucode.bin"
 
 static const struct vic_config vic_t186_config = {
        .firmware = NVIDIA_TEGRA_186_VIC_FIRMWARE,
+       .version = 0x18,
 };
 
 static const struct of_device_id vic_match[] = {
@@ -342,6 +346,7 @@ static int vic_probe(struct platform_device *pdev)
        vic->dev = dev;
 
        INIT_LIST_HEAD(&vic->client.list);
+       vic->client.version = vic->config->version;
        vic->client.ops = &vic_ops;
 
        err = host1x_client_register(&vic->client.base);