mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-14 16:36:55 +07:00
soc/tegra: fuse: Restrict legacy code to 32-bit ARM
For backwards-compatibility with old device trees, if no APBMISC node exists this driver hard-codes the I/O memory region. All 64-bit ARM device tree files are recent enough that they can be required to have this node, and therefore the legacy code path is not required. Based on work done by Paul Walmsley <pwalmsley@nvidia.com>. Cc: Paul Walmsley <pwalmsley@nvidia.com> Signed-off-by: Thierry Reding <treding@nvidia.com>
This commit is contained in:
parent
c2fe4694d8
commit
297c4f3dcb
@ -21,11 +21,10 @@
|
||||
#include <linux/io.h>
|
||||
|
||||
#include <soc/tegra/fuse.h>
|
||||
#include <soc/tegra/common.h>
|
||||
|
||||
#include "fuse.h"
|
||||
|
||||
#define APBMISC_BASE 0x70000800
|
||||
#define APBMISC_SIZE 0x64
|
||||
#define FUSE_SKU_INFO 0x10
|
||||
|
||||
#define PMC_STRAPPING_OPT_A_RAM_CODE_SHIFT 4
|
||||
@ -118,19 +117,69 @@ void __init tegra_init_revision(void)
|
||||
|
||||
void __init tegra_init_apbmisc(void)
|
||||
{
|
||||
struct resource apbmisc, straps;
|
||||
struct device_node *np;
|
||||
|
||||
np = of_find_matching_node(NULL, apbmisc_match);
|
||||
apbmisc_base = of_iomap(np, 0);
|
||||
if (!apbmisc_base) {
|
||||
pr_warn("ioremap tegra apbmisc failed. using %08x instead\n",
|
||||
APBMISC_BASE);
|
||||
apbmisc_base = ioremap(APBMISC_BASE, APBMISC_SIZE);
|
||||
if (!np) {
|
||||
/*
|
||||
* Fall back to legacy initialization for 32-bit ARM only. All
|
||||
* 64-bit ARM device tree files for Tegra are required to have
|
||||
* an APBMISC node.
|
||||
*
|
||||
* This is for backwards-compatibility with old device trees
|
||||
* that didn't contain an APBMISC node.
|
||||
*/
|
||||
if (IS_ENABLED(CONFIG_ARM) && soc_is_tegra()) {
|
||||
/* APBMISC registers (chip revision, ...) */
|
||||
apbmisc.start = 0x70000800;
|
||||
apbmisc.end = 0x70000863;
|
||||
apbmisc.flags = IORESOURCE_MEM;
|
||||
|
||||
/* strapping options */
|
||||
if (tegra_get_chip_id() == TEGRA124) {
|
||||
straps.start = 0x7000e864;
|
||||
straps.end = 0x7000e867;
|
||||
} else {
|
||||
straps.start = 0x70000008;
|
||||
straps.end = 0x7000000b;
|
||||
}
|
||||
|
||||
straps.flags = IORESOURCE_MEM;
|
||||
|
||||
pr_warn("Using APBMISC region %pR\n", &apbmisc);
|
||||
pr_warn("Using strapping options registers %pR\n",
|
||||
&straps);
|
||||
} else {
|
||||
/*
|
||||
* At this point we're not running on Tegra, so play
|
||||
* nice with multi-platform kernels.
|
||||
*/
|
||||
return;
|
||||
}
|
||||
} else {
|
||||
/*
|
||||
* Extract information from the device tree if we've found a
|
||||
* matching node.
|
||||
*/
|
||||
if (of_address_to_resource(np, 0, &apbmisc) < 0) {
|
||||
pr_err("failed to get APBMISC registers\n");
|
||||
return;
|
||||
}
|
||||
|
||||
if (of_address_to_resource(np, 1, &straps) < 0) {
|
||||
pr_err("failed to get strapping options registers\n");
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
strapping_base = of_iomap(np, 1);
|
||||
apbmisc_base = ioremap_nocache(apbmisc.start, resource_size(&apbmisc));
|
||||
if (!apbmisc_base)
|
||||
pr_err("failed to map APBMISC registers\n");
|
||||
|
||||
strapping_base = ioremap_nocache(straps.start, resource_size(&straps));
|
||||
if (!strapping_base)
|
||||
pr_err("ioremap tegra strapping_base failed\n");
|
||||
pr_err("failed to map strapping options registers\n");
|
||||
|
||||
long_ram_code = of_property_read_bool(np, "nvidia,long-ram-code");
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user