Files
linux-nv-oot/include/soc/tegra/fuse-helper.h
Kartik 1244fb5669 soc/tegra: fuse-helper: add tegra_fuse_control_read()
Various downstream drivers require reading fuse offsets < 0x100.

Add tegra_fuse_control_read(), which uses upstream tegra_fuse_readl()
to allow reading fuse offsets < 0x100.

Bug 3777983

Change-Id: I71c9a726eb748665923ed9547dd495073b89a9dc
Signed-off-by: Kartik <kkartik@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/c/linux-nvidia/+/2795612
Reviewed-by: Laxman Dewangan <ldewangan@nvidia.com>
Reviewed-by: Jonathan Hunter <jonathanh@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/c/linux-nv-oot/+/2894846
GVS: Gerrit_Virtual_Submit <buildbot_gerritrpt@nvidia.com>
Tested-by: Laxman Dewangan <ldewangan@nvidia.com>
2023-04-27 02:56:49 -07:00

66 lines
1.6 KiB
C

/* SPDX-License-Identifier: GPL-2.0-only */
/*
* Copyright (c) 2022-2023, NVIDIA CORPORATION. All rights reserved.
*/
#include <linux/version.h>
#include <soc/tegra/fuse.h>
#define FUSE_SKU_INFO 0x10
#define FUSE_BEGIN 0x100
static inline u32 tegra_get_sku_id(void)
{
if (!tegra_sku_info.sku_id)
tegra_fuse_readl(FUSE_SKU_INFO, &tegra_sku_info.sku_id);
return tegra_sku_info.sku_id;
}
#ifdef CONFIG_TEGRA_FUSE_UPSTREAM
/*
* For upstream the following functions to determine if the
* platform is silicon and simulator are not supported and
* so for now, always assume that we are silicon.
*/
static inline bool tegra_platform_is_silicon(void)
{
return true;
}
static inline bool tegra_platform_is_sim(void)
{
return false;
}
/*
* tegra_fuse_control_read() - allows reading fuse offsets < 0x100.
* @offset: Offset to be read.
* @value: Pointer to an unsigned integer where the value is stored.
*
* Function tegra_fuse_control_read() allows reading fuse_offsets < 0x100
* by using the already upstreamed tegra_fuse_readl() function.
*
* Return: Returns a negative integer in case of error, 0 in case
* of success.
*/
static inline int tegra_fuse_control_read(unsigned long offset, u32 *value)
{
/*
* Allow reading offsets between 0x0 - 0xff.
* For offsets > 0xff, use tegra_fuse_readl instead.
*/
if (WARN_ON(offset > 0xff))
return -EINVAL;
/*
* This will overflow the offset value, which is safe as
* tegra_fuse_readl() would again add 0x100 to it.
*/
offset -= FUSE_BEGIN;
return tegra_fuse_readl(offset, value);
}
#endif /* CONFIG_TEGRA_FUSE_UPSTREAM */