summaryrefslogtreecommitdiffstats
path: root/drivers/soc/tegra/fuse
diff options
context:
space:
mode:
authorThierry Reding <treding@nvidia.com>2020-09-17 12:07:46 +0200
committerThierry Reding <treding@nvidia.com>2020-09-18 15:55:26 +0200
commit52e6d399a41da68125ec107f5f5f688a74ab7ac4 (patch)
treec4cb3e66270fc65b90d1fcd3dfa265aa268e4b78 /drivers/soc/tegra/fuse
parentsoc/tegra: fuse: Extract tegra_get_platform() (diff)
downloadlinux-52e6d399a41da68125ec107f5f5f688a74ab7ac4.tar.xz
linux-52e6d399a41da68125ec107f5f5f688a74ab7ac4.zip
soc/tegra: fuse: Implement tegra_is_silicon()
This function can be used by drivers to determine whether code is running on silicon or on a simulation platform. Reviewed-by: Jon Hunter <jonathanh@nvidia.com> Signed-off-by: Thierry Reding <treding@nvidia.com>
Diffstat (limited to 'drivers/soc/tegra/fuse')
-rw-r--r--drivers/soc/tegra/fuse/tegra-apbmisc.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/drivers/soc/tegra/fuse/tegra-apbmisc.c b/drivers/soc/tegra/fuse/tegra-apbmisc.c
index 92a2d646c183..946a2d9ad117 100644
--- a/drivers/soc/tegra/fuse/tegra-apbmisc.c
+++ b/drivers/soc/tegra/fuse/tegra-apbmisc.c
@@ -52,6 +52,25 @@ u8 tegra_get_platform(void)
return (tegra_read_chipid() >> 20) & 0xf;
}
+bool tegra_is_silicon(void)
+{
+ switch (tegra_get_chip_id()) {
+ case TEGRA194:
+ if (tegra_get_platform() == 0)
+ return true;
+
+ return false;
+ }
+
+ /*
+ * Chips prior to Tegra194 have a different way of determining whether
+ * they are silicon or not. Since we never supported simulation on the
+ * older Tegra chips, don't bother extracting the information and just
+ * report that we're running on silicon.
+ */
+ return true;
+}
+
u32 tegra_read_straps(void)
{
WARN(!chipid, "Tegra ABP MISC not yet available\n");