Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/fdt Add support for NXP i.MX 8M Dual/8M QuadLite/8M ...
details: https://anonhg.NetBSD.org/src/rev/988de6dc6fa2
branches: trunk
changeset: 1006428:988de6dc6fa2
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Wed Jan 15 01:09:56 2020 +0000
description:
Add support for NXP i.MX 8M Dual/8M QuadLite/8M Quad family SoCs.
diffstat:
sys/arch/arm/imx/fdt/files.imx6 | 26 ++-
sys/arch/arm/imx/fdt/if_enet_imx.c | 92 ++++++-
sys/arch/arm/imx/fdt/imx6_com.c | 23 +-
sys/arch/arm/imx/fdt/imx6_gpio.c | 10 +-
sys/arch/arm/imx/fdt/imx6_iomux.c | 22 +-
sys/arch/arm/imx/fdt/imx6_sdhc.c | 70 ++++-
sys/arch/arm/imx/fdt/imx7_gpc.c | 264 +++++++++++++++++++++++
sys/arch/arm/imx/fdt/imx8mq_ccm.c | 194 ++++++++++++++++
sys/arch/arm/imx/fdt/imx8mq_ccm.h | 321 ++++++++++++++++++++++++++++
sys/arch/arm/imx/fdt/imx8mq_usbphy.c | 184 ++++++++++++++++
sys/arch/arm/imx/fdt/imx_ccm.c | 306 ++++++++++++++++++++++++++
sys/arch/arm/imx/fdt/imx_ccm.h | 234 ++++++++++++++++++++
sys/arch/arm/imx/fdt/imx_ccm_composite.c | 201 +++++++++++++++++
sys/arch/arm/imx/fdt/imx_ccm_extclk.c | 99 ++++++++
sys/arch/arm/imx/fdt/imx_ccm_fixed.c | 48 ++++
sys/arch/arm/imx/fdt/imx_ccm_fixed_factor.c | 103 ++++++++
sys/arch/arm/imx/fdt/imx_ccm_gate.c | 67 +++++
sys/arch/arm/imx/if_enet.c | 6 +-
sys/arch/arm/imx/if_enet_imx6.c | 5 +-
sys/arch/arm/imx/if_enet_imx7.c | 5 +-
sys/arch/arm/imx/if_enetvar.h | 3 +-
sys/arch/arm/imx/imx6_board.c | 6 +-
sys/arch/arm/imx/imx6_pcie.c | 8 +-
sys/arch/arm/imx/imx6_usdhc.c | 6 +-
sys/arch/arm/imx/imx7_usdhc.c | 8 +-
sys/arch/arm/imx/imxgpio.c | 29 +-
sys/arch/arm/imx/imxgpiovar.h | 12 +-
sys/arch/arm/imx/imxuart.c | 12 +-
sys/arch/evbarm/conf/GENERIC64 | 21 +-
sys/arch/evbarm/conf/files.generic64 | 3 +-
sys/dev/fdt/dwc3_fdt.c | 15 +-
31 files changed, 2293 insertions(+), 110 deletions(-)
diffs (truncated from 3153 to 300 lines):
diff -r b3bc7a3ca6fb -r 988de6dc6fa2 sys/arch/arm/imx/fdt/files.imx6
--- a/sys/arch/arm/imx/fdt/files.imx6 Tue Jan 14 23:13:36 2020 +0000
+++ b/sys/arch/arm/imx/fdt/files.imx6 Wed Jan 15 01:09:56 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: files.imx6,v 1.7 2019/10/12 06:46:13 skrll Exp $
+# $NetBSD: files.imx6,v 1.8 2020/01/15 01:09:56 jmcneill Exp $
#
# Configuration info for the Freescale i.MX6
#
@@ -15,11 +15,30 @@
file arch/arm/imx/imx6_ccm.c imxccm
file arch/arm/imx/fdt/imx6_clk.c imxccm
+
+# Common FDT clock framework
+define imx_ccm
+file arch/arm/imx/fdt/imx_ccm.c imx_ccm
+file arch/arm/imx/fdt/imx_ccm_extclk.c imx_ccm
+file arch/arm/imx/fdt/imx_ccm_gate.c imx_ccm
+file arch/arm/imx/fdt/imx_ccm_composite.c imx_ccm
+file arch/arm/imx/fdt/imx_ccm_fixed.c imx_ccm
+file arch/arm/imx/fdt/imx_ccm_fixed_factor.c imx_ccm
+
+# CCM (iMX8MQ)
+device imx8mqccm: imx_ccm
+attach imx8mqccm at fdt with imx8mq_ccm
+file arch/arm/imx/fdt/imx8mq_ccm.c imx8mq_ccm
+
# GPC
device imxgpc
attach imxgpc at fdt
file arch/arm/imx/fdt/imx6_gpc.c imxgpc
+device imx7gpc
+attach imx7gpc at fdt
+file arch/arm/imx/fdt/imx7_gpc.c imx7gpc
+
# IOMUX
device imxiomux
attach imxiomux at fdt
@@ -61,6 +80,11 @@
attach imxusbphy at fdt
file arch/arm/imx/fdt/imx6_usbphy.c imxusbphy
+device imx8mqusbphy
+attach imx8mqusbphy at fdt
+file arch/arm/imx/fdt/imx8mq_usbphy.c imx8mqusbphy
+
+
# SDMMC
attach sdhc at fdt with imx6_sdhc
file arch/arm/imx/fdt/imx6_sdhc.c imx6_sdhc
diff -r b3bc7a3ca6fb -r 988de6dc6fa2 sys/arch/arm/imx/fdt/if_enet_imx.c
--- a/sys/arch/arm/imx/fdt/if_enet_imx.c Tue Jan 14 23:13:36 2020 +0000
+++ b/sys/arch/arm/imx/fdt/if_enet_imx.c Wed Jan 15 01:09:56 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_enet_imx.c,v 1.8 2019/11/14 06:00:16 hkenken Exp $ */
+/* $NetBSD: if_enet_imx.c,v 1.9 2020/01/15 01:09:56 jmcneill Exp $ */
/*-
* Copyright (c) 2019 Genetec Corporation. All rights reserved.
* Written by Hashimoto Kenichi for Genetec Corporation.
@@ -25,7 +25,7 @@
* SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_enet_imx.c,v 1.8 2019/11/14 06:00:16 hkenken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_enet_imx.c,v 1.9 2020/01/15 01:09:56 jmcneill Exp $");
#include "opt_fdt.h"
@@ -49,20 +49,24 @@
CFATTACH_DECL_NEW(enet_fdt, sizeof(struct enet_fdt_softc),
enet_match, enet_attach, NULL, NULL);
-static const char * const compatible[] = {
- "fsl,imx6q-fec",
- NULL
+static const struct of_compat_data compat_data[] = {
+ /* compatible imxtype */
+ { "fsl,imx6q-fec", 6 },
+ { "fsl,imx6sx-fec", 7 },
+ { NULL }
};
static int enet_init_clocks(struct enet_softc *);
static void enet_phy_reset(struct enet_fdt_softc *, const int);
+static int enet_phy_id(struct enet_softc *, const int);
+static void *enet_intr_establish(struct enet_softc *, int, u_int);
int
enet_match(device_t parent, cfdata_t cf, void *aux)
{
struct fdt_attach_args * const faa = aux;
- return of_match_compatible(faa->faa_phandle, compatible);
+ return of_match_compat_data(faa->faa_phandle, compat_data);
}
void
@@ -100,12 +104,21 @@
aprint_error(": couldn't get clock ahb\n");
goto failure;
}
- sc->sc_clk_enet_ref= fdtbus_clock_get(phandle, "ptp");
+ sc->sc_clk_enet_ref = fdtbus_clock_get(phandle, "ptp");
if (sc->sc_clk_enet_ref == NULL) {
aprint_error(": couldn't get clock ptp\n");
goto failure;
}
+ if (fdtbus_clock_enable(phandle, "enet_clk_ref", false) != 0) {
+ aprint_error(": couldn't enable clock enet_clk_ref\n");
+ goto failure;
+ }
+ if (fdtbus_clock_enable(phandle, "enet_out", false) != 0) {
+ aprint_error(": couldn't enable clock enet_out\n");
+ goto failure;
+ }
+
aprint_naive("\n");
aprint_normal(": Gigabit Ethernet Controller\n");
@@ -114,8 +127,9 @@
sc->sc_ioh = bsh;
sc->sc_dmat = faa->faa_dmat;
- sc->sc_imxtype = 6; /* i.MX6 */
+ sc->sc_imxtype = of_search_compatible(phandle, compat_data)->data;
sc->sc_unit = 0;
+ sc->sc_phyid = enet_phy_id(sc, phandle);
const char *phy_mode = fdtbus_get_string(phandle, "phy-mode");
if (phy_mode == NULL) {
@@ -139,19 +153,16 @@
sc->sc_rgmii = 0;
}
- char intrstr[128];
- if (!fdtbus_intr_str(phandle, 0, intrstr, sizeof(intrstr))) {
- aprint_error_dev(self, "failed to decode interrupt\n");
+ sc->sc_ih = enet_intr_establish(sc, phandle, 0);
+ if (sc->sc_ih == NULL)
goto failure;
+
+ if (sc->sc_imxtype == 7) {
+ sc->sc_ih2 = enet_intr_establish(sc, phandle, 1);
+ sc->sc_ih3 = enet_intr_establish(sc, phandle, 2);
+ if (sc->sc_ih2 == NULL || sc->sc_ih3 == NULL)
+ goto failure;
}
- sc->sc_ih = fdtbus_intr_establish(phandle, 0, IPL_NET,
- FDT_INTR_MPSAFE, enet_intr, sc);
- if (sc->sc_ih == NULL) {
- aprint_error_dev(self, "failed to establish interrupt on %s\n",
- intrstr);
- goto failure;
- }
- aprint_normal_dev(self, "interrupting on %s\n", intrstr);
enet_init_clocks(sc);
sc->sc_clock = clk_get_rate(sc->sc_clk_ipg);
@@ -168,6 +179,29 @@
return;
}
+static void *
+enet_intr_establish(struct enet_softc *sc, int phandle, u_int index)
+{
+ char intrstr[128];
+ void *ih;
+
+ if (!fdtbus_intr_str(phandle, index, intrstr, sizeof(intrstr))) {
+ aprint_error_dev(sc->sc_dev, "failed to decode interrupt %d\n",
+ index);
+ return NULL;
+ }
+
+ ih = fdtbus_intr_establish(phandle, index, IPL_NET, 0, enet_intr, sc);
+ if (ih == NULL) {
+ aprint_error_dev(sc->sc_dev, "failed to establish interrupt on %s\n",
+ intrstr);
+ return NULL;
+ }
+ aprint_normal_dev(sc->sc_dev, "interrupting on %s\n", intrstr);
+
+ return ih;
+}
+
static int
enet_init_clocks(struct enet_softc *sc)
{
@@ -198,8 +232,10 @@
u_int msec;
sc->sc_pin_reset = fdtbus_gpio_acquire(phandle, "phy-reset-gpios", GPIO_PIN_OUTPUT);
- if (sc->sc_pin_reset == NULL)
+ if (sc->sc_pin_reset == NULL) {
+ aprint_error_dev(sc->sc_enet.sc_dev, "couldn't find phy reset gpios\n");
return;
+ }
if (of_getprop_uint32(phandle, "phy-reset-duration", &msec))
msec = 1;
@@ -215,3 +251,19 @@
delay(msec * 1000);
}
+
+static int
+enet_phy_id(struct enet_softc *sc, const int phandle)
+{
+ int phy_phandle;
+ bus_addr_t addr;
+
+ phy_phandle = fdtbus_get_phandle(phandle, "phy-handle");
+ if (phy_phandle == -1)
+ return MII_PHY_ANY;
+
+ if (fdtbus_get_reg(phy_phandle, 0, &addr, NULL) != 0)
+ return MII_PHY_ANY;
+
+ return (int)addr;
+}
diff -r b3bc7a3ca6fb -r 988de6dc6fa2 sys/arch/arm/imx/fdt/imx6_com.c
--- a/sys/arch/arm/imx/fdt/imx6_com.c Tue Jan 14 23:13:36 2020 +0000
+++ b/sys/arch/arm/imx/fdt/imx6_com.c Wed Jan 15 01:09:56 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: imx6_com.c,v 1.2 2019/11/28 14:13:37 hkenken Exp $ */
+/* $NetBSD: imx6_com.c,v 1.3 2020/01/15 01:09:56 jmcneill Exp $ */
/*-
* Copyright (c) 2019 Genetec Corporation. All rights reserved.
* Written by Hashimoto Kenichi for Genetec Corporation.
@@ -25,7 +25,7 @@
* SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: imx6_com.c,v 1.2 2019/11/28 14:13:37 hkenken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: imx6_com.c,v 1.3 2020/01/15 01:09:56 jmcneill Exp $");
#include "opt_fdt.h"
#include "opt_imxuart.h"
@@ -70,6 +70,7 @@
bus_space_tag_t bst = faa->faa_bst;
bus_space_handle_t bsh;
char intrstr[128];
+ struct clk *per;
bus_addr_t addr;
bus_size_t size;
@@ -83,11 +84,28 @@
return;
}
+ if (fdtbus_clock_enable(phandle, "ipg", false) != 0) {
+ aprint_error(": couldn't enable ipg clock\n");
+ return;
+ }
+
+ per = fdtbus_clock_get(phandle, "per");
+ if (per != NULL && clk_enable(per) != 0) {
+ aprint_error(": couldn't enable per clock\n");
+ return;
+ }
+
sc->sc_dev = self;
regsp->ur_iot = bst;
regsp->ur_iobase = addr;
regsp->ur_ioh = bsh;
+ if (per != NULL) {
+ aprint_normal(", %u Hz", clk_get_rate(per));
+ /* XXX */
+ imxuart_set_frequency(clk_get_rate(per), 2);
+ }
+
if (imxuart_is_console(regsp->ur_iot, regsp->ur_iobase, ®sp->ur_ioh))
aprint_normal(" (console)");
@@ -108,7 +126,6 @@
aprint_normal_dev(self, "interrupting on %s\n", intrstr);
imxuart_attach_subr(sc);
-
}
/*
diff -r b3bc7a3ca6fb -r 988de6dc6fa2 sys/arch/arm/imx/fdt/imx6_gpio.c
--- a/sys/arch/arm/imx/fdt/imx6_gpio.c Tue Jan 14 23:13:36 2020 +0000
+++ b/sys/arch/arm/imx/fdt/imx6_gpio.c Wed Jan 15 01:09:56 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: imx6_gpio.c,v 1.4 2019/11/27 07:26:08 hkenken Exp $ */
+/* $NetBSD: imx6_gpio.c,v 1.5 2020/01/15 01:09:56 jmcneill Exp $ */
/*-
* Copyright (c) 2019 Genetec Corporation. All rights reserved.
* Written by Hashimoto Kenichi for Genetec Corporation.
@@ -25,7 +25,7 @@
* SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: imx6_gpio.c,v 1.4 2019/11/27 07:26:08 hkenken Exp $");
Home |
Main Index |
Thread Index |
Old Index