Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/imx/fdt Use generic platform definition for i.MX7
details: https://anonhg.NetBSD.org/src/rev/908e92e017dc
branches: trunk
changeset: 1010859:908e92e017dc
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Wed Jun 10 19:30:23 2020 +0000
description:
Use generic platform definition for i.MX7
diffstat:
sys/arch/arm/imx/fdt/files.imx6 | 3 +-
sys/arch/arm/imx/fdt/imx7_platform.c | 195 -----------------------------------
sys/arch/arm/imx/fdt/imx7_platform.h | 35 ------
3 files changed, 1 insertions(+), 232 deletions(-)
diffs (253 lines):
diff -r 78ce3057200f -r 908e92e017dc sys/arch/arm/imx/fdt/files.imx6
--- a/sys/arch/arm/imx/fdt/files.imx6 Wed Jun 10 19:29:48 2020 +0000
+++ b/sys/arch/arm/imx/fdt/files.imx6 Wed Jun 10 19:30:23 2020 +0000
@@ -1,10 +1,9 @@
-# $NetBSD: files.imx6,v 1.13 2020/06/10 17:57:50 jmcneill Exp $
+# $NetBSD: files.imx6,v 1.14 2020/06/10 19:30:23 jmcneill Exp $
#
# Configuration info for the Freescale i.MX6
#
file arch/arm/imx/fdt/imx6_platform.c soc_imx
-file arch/arm/imx/fdt/imx7_platform.c soc_imx
# SOC parameters
defflag opt_soc.h SOC_IMX
diff -r 78ce3057200f -r 908e92e017dc sys/arch/arm/imx/fdt/imx7_platform.c
--- a/sys/arch/arm/imx/fdt/imx7_platform.c Wed Jun 10 19:29:48 2020 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,195 +0,0 @@
-/* $NetBSD: imx7_platform.c,v 1.1 2020/06/10 17:57:50 jmcneill Exp $ */
-/*-
- * Copyright (c) 2019 Genetec Corporation. All rights reserved.
- * Written by Hashimoto Kenichi for Genetec Corporation.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
- * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
- * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
- * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- */
-#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: imx7_platform.c,v 1.1 2020/06/10 17:57:50 jmcneill Exp $");
-
-#include "opt_console.h"
-#include "opt_fdt.h"
-#include "opt_multiprocessor.h"
-#include "opt_soc.h"
-
-#include <sys/param.h>
-#include <sys/bus.h>
-#include <sys/cpu.h>
-#include <sys/device.h>
-#include <sys/termios.h>
-
-#include <dev/fdt/fdtvar.h>
-#include <arm/fdt/arm_fdtvar.h>
-
-#include <uvm/uvm_extern.h>
-
-#include <arm/arm32/machdep.h>
-
-#include <machine/bootconfig.h>
-#include <arm/cpufunc.h>
-
-#include <arm/cortex/gtmr_var.h>
-#include <arm/cortex/gic_reg.h>
-
-#include <arm/imx/imx7reg.h>
-#include <arm/imx/imx7_srcreg.h>
-#include <arm/imx/imx7_ccmreg.h>
-#include <arm/imx/imxuartreg.h>
-#include <arm/imx/imxwdogreg.h>
-
-#include <arm/imx/fdt/imx7_platform.h>
-
-#include <libfdt.h>
-
-extern struct bus_space armv7_generic_bs_tag;
-extern struct bus_space armv7_generic_a4x_bs_tag;
-extern struct arm32_bus_dma_tag arm_generic_dma_tag;
-
-static const struct pmap_devmap *
-imx7_platform_devmap(void)
-{
- static const struct pmap_devmap devmap[] = {
- DEVMAP_ENTRY(KERNEL_IO_IOREG_VBASE, IMX7_IOREG_PBASE, IMX7_IOREG_SIZE),
- DEVMAP_ENTRY(KERNEL_IO_ARMCORE_VBASE, IMX7_ARMCORE_PBASE, IMX7_ARMCORE_SIZE),
- DEVMAP_ENTRY_END
- };
-
- return devmap;
-}
-
-static void
-imx7_platform_init_attach_args(struct fdt_attach_args *faa)
-{
- faa->faa_bst = &armv7_generic_bs_tag;
- faa->faa_a4x_bst = &armv7_generic_a4x_bs_tag;
- faa->faa_dmat = &arm_generic_dma_tag;
-}
-
-void imx7_platform_early_putchar(char);
-
-void
-imx7_platform_early_putchar(char c)
-{
-#ifdef CONSADDR
-#define CONSADDR_VA ((CONSADDR - IMX7_IOREG_PBASE) + KERNEL_IO_IOREG_VBASE)
-
- volatile uint32_t *uartaddr = cpu_earlydevice_va_p() ?
- (volatile uint32_t *)CONSADDR_VA :
- (volatile uint32_t *)CONSADDR;
-
- while ((le32toh(uartaddr[(IMX_USR2/4)]) & IMX_USR2_TXDC) == 0)
- ;
-
- uartaddr[(IMX_UTXD/4)] = htole32(c);
-#endif
-}
-
-static void
-imx7_platform_device_register(device_t self, void *aux)
-{
- prop_dictionary_t prop = device_properties(self);
-
- if (device_is_a(self, "atphy")) {
- const char * compat[] = {
- "fsl,imx7dl-sabresd",
- "fsl,imx7q-sabresd",
- "fsl,imx7qp-sabresd",
- NULL
- };
- if (of_match_compatible(OF_finddevice("/"), compat))
- prop_dictionary_set_uint32(prop, "clk_25m", 125000000);
- }
-}
-
-static u_int
-imx7_platform_uart_freq(void)
-{
- return IMX7_OSC_FREQ;
-}
-
-static int
-imx7_platform_mpstart(void)
-{
-#if defined(MULTIPROCESSOR)
- bus_space_tag_t bst = &armv7_generic_bs_tag;
- bus_space_handle_t bsh;
-
- if (bus_space_map(bst, IMX7_IOREG_PBASE + AIPS1_SRC_BASE, AIPS1_SRC_SIZE, 0, &bsh) != 0)
- panic("couldn't map aips1 src registers");
- const paddr_t mpstart = KERN_VTOPHYS((vaddr_t)cpu_mpstart);
-
- bus_space_write_4(bst, bsh, SRC_GPR3, mpstart);
-
- uint32_t rcr1 = bus_space_read_4(bst, bsh, SRC_A7RCR1);
- rcr1 |= SRC_A7RCR1_A7_CORE1_ENABLE;
- bus_space_write_4(bst, bsh, SRC_A7RCR1, rcr1);
-
- arm_dsb();
- __asm __volatile("sev" ::: "memory");
-
- /* Wait for AP to start */
- for (u_int i = 0x1000000; i > 0; i--) {
- if (cpu_hatched_p(1))
- break;
- }
- if (!cpu_hatched_p(1))
- printf("cpu1: WARNING: failed to start\n");
-
- bus_space_unmap(bst, bsh, AIPS1_SRC_SIZE);
-#endif
-
- return 0;
-}
-
-static void
-imx7_platform_reset(void)
-{
- bus_space_tag_t bst = &armv7_generic_bs_tag;
- bus_space_handle_t bsh;
-
- if (bus_space_map(bst, IMX7_IOREG_PBASE + AIPS1_WDOG1_BASE, AIPS1_WDOG_SIZE, 0, &bsh))
- panic("couldn't map wdog1 registers");
-
- delay(1000); /* wait for flushing FIFO of serial console */
-
- cpsid(I32_bit|F32_bit);
-
- /* software reset signal on wdog */
- bus_space_write_2(bst, bsh, IMX_WDOG_WCR, WCR_WDE);
-
- for (;;)
- __asm("wfi");
-}
-
-const struct arm_platform imx7_platform = {
- .ap_devmap = imx7_platform_devmap,
- .ap_bootstrap = arm_fdt_cpu_bootstrap,
- .ap_init_attach_args = imx7_platform_init_attach_args,
- .ap_device_register = imx7_platform_device_register,
- .ap_reset = imx7_platform_reset,
- .ap_delay = gtmr_delay,
- .ap_uart_freq = imx7_platform_uart_freq,
- .ap_mpstart = imx7_platform_mpstart,
-};
-
-ARM_PLATFORM(imx7d, "fsl,imx7d", &imx7_platform);
diff -r 78ce3057200f -r 908e92e017dc sys/arch/arm/imx/fdt/imx7_platform.h
--- a/sys/arch/arm/imx/fdt/imx7_platform.h Wed Jun 10 19:29:48 2020 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,35 +0,0 @@
-/* $NetBSD: imx7_platform.h,v 1.1 2020/06/10 17:57:50 jmcneill Exp $ */
-/*-
- * Copyright (c) 2019 Genetec Corporation. All rights reserved.
- * Written by Hashimoto Kenichi for Genetec Corporation.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
- * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
- * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
- * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- */
-#ifndef _ARM_IMX_FDT_IMX7_PLATFORM_H
-#define _ARM_IMX_FDT_IMX7_PLATFORM_H
-
-#include <arch/evbarm/fdt/platform.h>
-
-#define KERNEL_IO_IOREG_VBASE KERNEL_IO_VBASE
-#define KERNEL_IO_ARMCORE_VBASE (KERNEL_IO_IOREG_VBASE + IMX7_IOREG_SIZE)
-
-#endif /* _ARM_IMX_FDT_IMX7_PLATFORM_H */
Home |
Main Index |
Thread Index |
Old Index