Add machine entry for the S500 variant of the Actions Semi Owl SoCs
family.
For the moment the only purpose is to provide the system serial
information which will be used by the Owl Ethernet MAC driver to
generate a stable MAC address.
Signed-off-by: Cristian Ciocaltea <[email protected]>
---
arch/arm/mach-actions/Makefile | 1 +
arch/arm/mach-actions/actions.c | 44 +++++++++++++++++++++++++++++++++
2 files changed, 45 insertions(+)
create mode 100644 arch/arm/mach-actions/actions.c
diff --git a/arch/arm/mach-actions/Makefile b/arch/arm/mach-actions/Makefile
index 8eae9587fe82..31865c958d92 100644
--- a/arch/arm/mach-actions/Makefile
+++ b/arch/arm/mach-actions/Makefile
@@ -1,2 +1,3 @@
# SPDX-License-Identifier: GPL-2.0-only
+obj-${CONFIG_ARCH_ACTIONS} += actions.o
obj-${CONFIG_SMP} += platsmp.o
diff --git a/arch/arm/mach-actions/actions.c b/arch/arm/mach-actions/actions.c
new file mode 100644
index 000000000000..306c6bb178fe
--- /dev/null
+++ b/arch/arm/mach-actions/actions.c
@@ -0,0 +1,44 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+/*
+ * Actions Semi Owl SoCs
+ *
+ * Copyright (c) 2012 Actions Semi Inc.
+ * Copyright (c) 2021 Cristian Ciocaltea <[email protected]>
+ */
+
+#include <linux/highmem.h>
+#include <linux/of_platform.h>
+
+#include <asm/mach/arch.h>
+#include <asm/system_info.h>
+
+#define OWL_S500_SERIAL_LOW_PAGE_OFF 0x800
+#define OWL_S500_SERIAL_HIGH_PAGE_OFF 0x804
+
+static const char *const owl_s500_dt_compat[] __initconst = {
+ "actions,s500",
+ NULL,
+};
+
+static void __init owl_s500_get_system_serial(void)
+{
+ char *vddr = kmap_local_page(pfn_to_page(PFN_DOWN(0)));
+
+ memcpy(&system_serial_low, vddr + OWL_S500_SERIAL_LOW_PAGE_OFF,
+ sizeof(system_serial_low));
+ memcpy(&system_serial_high, vddr + OWL_S500_SERIAL_HIGH_PAGE_OFF,
+ sizeof(system_serial_high));
+
+ kunmap_local(vddr);
+}
+
+static void __init owl_s500_init_early(void)
+
+{
+ owl_s500_get_system_serial();
+}
+
+DT_MACHINE_START(ACTIONS, "Actions Semi Owl S500 SoC")
+ .dt_compat = owl_s500_dt_compat,
+ .init_early = owl_s500_init_early,
+MACHINE_END
--
2.30.2
Hi Cristian,
On 11.03.21 20:19, Cristian Ciocaltea wrote:
> Add machine entry for the S500 variant of the Actions Semi Owl SoCs
> family.
>
> For the moment the only purpose is to provide the system serial
> information which will be used by the Owl Ethernet MAC driver to
> generate a stable MAC address.
Can't that be done in either a sys_soc driver or U-Boot?
Regards,
Andreas
--
SUSE Software Solutions Germany GmbH
Maxfeldstr. 5, 90409 Nürnberg, Germany
GF: Felix Imendörffer
HRB 36809 (AG Nürnberg)
Hi Andreas,
On Fri, Mar 12, 2021 at 09:39:31AM +0100, Andreas F?rber wrote:
> Hi Cristian,
>
> On 11.03.21 20:19, Cristian Ciocaltea wrote:
> > Add machine entry for the S500 variant of the Actions Semi Owl SoCs
> > family.
> >
> > For the moment the only purpose is to provide the system serial
> > information which will be used by the Owl Ethernet MAC driver to
> > generate a stable MAC address.
>
> Can't that be done in either a sys_soc driver or U-Boot?
I will look first at the sys_soc driver approach.
I haven't started working on the U-Boot side yet, but I'm planning to do
so as soon as possible. Last time when I checked, there was some initial
support only for the S700 and S900 SoCs, but I will do my best to add
also the S500 to the list.
Thanks,
Cristi
> Regards,
> Andreas
>
> --
> SUSE Software Solutions Germany GmbH
> Maxfeldstr. 5, 90409 N?rnberg, Germany
> GF: Felix Imend?rffer
> HRB 36809 (AG N?rnberg)
On Fri, Mar 12, 2021 at 11:28:53AM +0200, Cristian Ciocaltea wrote:
> Hi Andreas,
>
> On Fri, Mar 12, 2021 at 09:39:31AM +0100, Andreas F?rber wrote:
> > Hi Cristian,
> >
> > On 11.03.21 20:19, Cristian Ciocaltea wrote:
> > > Add machine entry for the S500 variant of the Actions Semi Owl SoCs
> > > family.
> > >
> > > For the moment the only purpose is to provide the system serial
> > > information which will be used by the Owl Ethernet MAC driver to
> > > generate a stable MAC address.
> >
> > Can't that be done in either a sys_soc driver or U-Boot?
>
> I will look first at the sys_soc driver approach.
I have just submitted a socinfo driver:
https://lore.kernel.org/lkml/[email protected]/
Thanks,
Cristi