blob: 3a4e58bba6715239339e7afc5b7c1cdf656624a2 [file] [log] [blame]
Dave Gerlach3e1b59c2020-07-15 23:39:59 -05001// SPDX-License-Identifier: GPL-2.0+
2/*
Nishanth Menona94a4072023-11-01 15:56:03 -05003 * Copyright (C) 2020 Texas Instruments Incorporated - https://www.ti.com/
Dave Gerlach3e1b59c2020-07-15 23:39:59 -05004 * Dave Gerlach <d-gerlach@ti.com>
5 */
6
7#include <common.h>
8#include <dm.h>
9#include <soc.h>
10
Andrew Davis677a1e22023-04-06 11:38:12 -050011#include <asm/arch/hardware.h>
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050012#include <asm/io.h>
13
Simon Glass8a8d24b2020-12-03 16:55:23 -070014struct soc_ti_k3_plat {
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050015 const char *family;
16 const char *revision;
17};
18
19static const char *get_family_string(u32 idreg)
20{
21 const char *family;
22 u32 soc;
23
24 soc = (idreg & JTAG_ID_PARTNO_MASK) >> JTAG_ID_PARTNO_SHIFT;
25
26 switch (soc) {
Andrew Davis677a1e22023-04-06 11:38:12 -050027 case JTAG_ID_PARTNO_AM65X:
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050028 family = "AM65X";
29 break;
Andrew Davis677a1e22023-04-06 11:38:12 -050030 case JTAG_ID_PARTNO_J721E:
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050031 family = "J721E";
32 break;
Andrew Davis677a1e22023-04-06 11:38:12 -050033 case JTAG_ID_PARTNO_J7200:
Kishon Vijay Abraham I837933a2020-08-05 22:44:27 +053034 family = "J7200";
35 break;
Andrew Davis677a1e22023-04-06 11:38:12 -050036 case JTAG_ID_PARTNO_AM64X:
Lokesh Vutla776b79e2021-05-06 16:44:48 +053037 family = "AM64X";
38 break;
Andrew Davis677a1e22023-04-06 11:38:12 -050039 case JTAG_ID_PARTNO_J721S2:
David Huangf993adb2022-01-25 20:56:36 +053040 family = "J721S2";
41 break;
Andrew Davis677a1e22023-04-06 11:38:12 -050042 case JTAG_ID_PARTNO_AM62X:
Suman Anna4298ee72022-05-25 13:38:41 +053043 family = "AM62X";
44 break;
Andrew Davis677a1e22023-04-06 11:38:12 -050045 case JTAG_ID_PARTNO_AM62AX:
Bryan Brattlofe38025c2022-11-03 19:13:54 -050046 family = "AM62AX";
47 break;
Apurva Nandan4e3b94d2024-02-24 01:51:43 +053048 case JTAG_ID_PARTNO_J784S4:
49 family = "J784S4";
50 break;
Bryan Brattlof026c9722024-03-12 15:20:19 -050051 case JTAG_ID_PARTNO_AM62PX:
52 family = "AM62PX";
53 break;
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050054 default:
55 family = "Unknown Silicon";
56 };
57
58 return family;
59}
60
Bryan Brattlof708f54f2022-01-26 16:07:33 -060061static char *j721e_rev_string_map[] = {
62 "1.0", "1.1",
63};
64
Bryan Brattlof10c8baf2022-06-21 16:36:03 -050065static char *typical_rev_string_map[] = {
66 "1.0", "2.0", "3.0",
Bryan Brattlof708f54f2022-01-26 16:07:33 -060067};
68
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050069static const char *get_rev_string(u32 idreg)
70{
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050071 u32 rev;
Bryan Brattlof708f54f2022-01-26 16:07:33 -060072 u32 soc;
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050073
74 rev = (idreg & JTAG_ID_VARIANT_MASK) >> JTAG_ID_VARIANT_SHIFT;
Bryan Brattlof708f54f2022-01-26 16:07:33 -060075 soc = (idreg & JTAG_ID_PARTNO_MASK) >> JTAG_ID_PARTNO_SHIFT;
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050076
Bryan Brattlof708f54f2022-01-26 16:07:33 -060077 switch (soc) {
Andrew Davis677a1e22023-04-06 11:38:12 -050078 case JTAG_ID_PARTNO_J721E:
Rasmus Villemoes45981a92023-03-24 08:44:29 +010079 if (rev >= ARRAY_SIZE(j721e_rev_string_map))
Bryan Brattlof708f54f2022-01-26 16:07:33 -060080 goto bail;
81 return j721e_rev_string_map[rev];
82
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050083 default:
Rasmus Villemoes45981a92023-03-24 08:44:29 +010084 if (rev >= ARRAY_SIZE(typical_rev_string_map))
Bryan Brattlof10c8baf2022-06-21 16:36:03 -050085 goto bail;
86 return typical_rev_string_map[rev];
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050087 };
88
Bryan Brattlof708f54f2022-01-26 16:07:33 -060089bail:
90 return "Unknown Revision";
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050091}
92
93static int soc_ti_k3_get_family(struct udevice *dev, char *buf, int size)
94{
Simon Glass8a8d24b2020-12-03 16:55:23 -070095 struct soc_ti_k3_plat *plat = dev_get_plat(dev);
Dave Gerlach3e1b59c2020-07-15 23:39:59 -050096
97 snprintf(buf, size, "%s", plat->family);
98
99 return 0;
100}
101
102static int soc_ti_k3_get_revision(struct udevice *dev, char *buf, int size)
103{
Simon Glass8a8d24b2020-12-03 16:55:23 -0700104 struct soc_ti_k3_plat *plat = dev_get_plat(dev);
Dave Gerlach3e1b59c2020-07-15 23:39:59 -0500105
106 snprintf(buf, size, "SR%s", plat->revision);
107
108 return 0;
109}
110
111static const struct soc_ops soc_ti_k3_ops = {
112 .get_family = soc_ti_k3_get_family,
113 .get_revision = soc_ti_k3_get_revision,
114};
115
116int soc_ti_k3_probe(struct udevice *dev)
117{
Simon Glass8a8d24b2020-12-03 16:55:23 -0700118 struct soc_ti_k3_plat *plat = dev_get_plat(dev);
Dave Gerlach3e1b59c2020-07-15 23:39:59 -0500119 u32 idreg;
120 void *idreg_addr;
121
122 idreg_addr = dev_read_addr_ptr(dev);
123 if (!idreg_addr)
124 return -EINVAL;
125
126 idreg = readl(idreg_addr);
127
128 plat->family = get_family_string(idreg);
129 plat->revision = get_rev_string(idreg);
130
131 return 0;
132}
133
134static const struct udevice_id soc_ti_k3_ids[] = {
135 { .compatible = "ti,am654-chipid" },
136 { }
137};
138
139U_BOOT_DRIVER(soc_ti_k3) = {
140 .name = "soc_ti_k3",
141 .id = UCLASS_SOC,
142 .ops = &soc_ti_k3_ops,
143 .of_match = soc_ti_k3_ids,
144 .probe = soc_ti_k3_probe,
Simon Glass8a8d24b2020-12-03 16:55:23 -0700145 .plat_auto = sizeof(struct soc_ti_k3_plat),
Dave Gerlach3e1b59c2020-07-15 23:39:59 -0500146};