Commit acae8a9d authored by Thierry Reding's avatar Thierry Reding

drm/tegra: vic: Track interface version

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: default avatarDmitry Osipenko <digetx@gmail.com>
Signed-off-by: default avatarThierry Reding <treding@nvidia.com>
parent 33f150ea
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
struct vic_config { struct vic_config {
const char *firmware; const char *firmware;
unsigned int version;
}; };
struct vic { struct vic {
...@@ -264,18 +265,21 @@ static const struct tegra_drm_client_ops vic_ops = { ...@@ -264,18 +265,21 @@ static const struct tegra_drm_client_ops vic_ops = {
static const struct vic_config vic_t124_config = { static const struct vic_config vic_t124_config = {
.firmware = NVIDIA_TEGRA_124_VIC_FIRMWARE, .firmware = NVIDIA_TEGRA_124_VIC_FIRMWARE,
.version = 0x40,
}; };
#define NVIDIA_TEGRA_210_VIC_FIRMWARE "nvidia/tegra210/vic04_ucode.bin" #define NVIDIA_TEGRA_210_VIC_FIRMWARE "nvidia/tegra210/vic04_ucode.bin"
static const struct vic_config vic_t210_config = { static const struct vic_config vic_t210_config = {
.firmware = NVIDIA_TEGRA_210_VIC_FIRMWARE, .firmware = NVIDIA_TEGRA_210_VIC_FIRMWARE,
.version = 0x21,
}; };
#define NVIDIA_TEGRA_186_VIC_FIRMWARE "nvidia/tegra186/vic04_ucode.bin" #define NVIDIA_TEGRA_186_VIC_FIRMWARE "nvidia/tegra186/vic04_ucode.bin"
static const struct vic_config vic_t186_config = { static const struct vic_config vic_t186_config = {
.firmware = NVIDIA_TEGRA_186_VIC_FIRMWARE, .firmware = NVIDIA_TEGRA_186_VIC_FIRMWARE,
.version = 0x18,
}; };
static const struct of_device_id vic_match[] = { static const struct of_device_id vic_match[] = {
...@@ -342,6 +346,7 @@ static int vic_probe(struct platform_device *pdev) ...@@ -342,6 +346,7 @@ static int vic_probe(struct platform_device *pdev)
vic->dev = dev; vic->dev = dev;
INIT_LIST_HEAD(&vic->client.list); INIT_LIST_HEAD(&vic->client.list);
vic->client.version = vic->config->version;
vic->client.ops = &vic_ops; vic->client.ops = &vic_ops;
err = host1x_client_register(&vic->client.base); err = host1x_client_register(&vic->client.base);
......
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