[PATCH] imx25: Feed the unique id to machine_id_set_hashable()
Uwe Kleine-König
u.kleine-koenig at pengutronix.de
Tue Mar 12 08:48:27 PDT 2024
This enables barebox on i.MX25 to generate a per-machine eth address.
Signed-off-by: Uwe Kleine-König <u.kleine-koenig at pengutronix.de>
---
arch/arm/mach-imx/iim.c | 20 ++++++++++++++++++++
1 file changed, 20 insertions(+)
diff --git a/arch/arm/mach-imx/iim.c b/arch/arm/mach-imx/iim.c
index 90ca644c2e62..f4581396b1a5 100644
--- a/arch/arm/mach-imx/iim.c
+++ b/arch/arm/mach-imx/iim.c
@@ -22,6 +22,7 @@
#include <linux/regmap.h>
#include <regulator.h>
#include <linux/err.h>
+#include <machine_id.h>
#include <mach/imx/iim.h>
#include <mach/imx/imx51-regs.h>
@@ -504,6 +505,25 @@ static int imx_iim_probe(struct device *dev)
dev_add_param_bool(&iim->dev, "explicit_sense_enable",
NULL, NULL, &iim->sense_enable, NULL);
+ /* Maybe this is too strict? This might also work on i.MX31 and i.MX35 */
+ if (IS_ENABLED(CONFIG_MACHINE_ID) &&
+ of_device_is_compatible(dev->of_node, "fsl,imx25-iim")) {
+ char uid[8];
+
+ for (i = 0; i < 8; ++i) {
+ unsigned int value;
+
+ ret = imx_iim_read_field(IMX25_IIM_UID(i), &value);
+ if (ret)
+ break;
+
+ uid[i] = value;
+ }
+
+ if (!ret)
+ machine_id_set_hashable(uid, 8);
+ }
+
return 0;
}
base-commit: d27c50c131e7393f4640c20c711e2aad83543066
--
2.43.0
More information about the barebox
mailing list