Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/evbarm/marvell initialize ARMADA XP's Mbus address ...
details: https://anonhg.NetBSD.org/src/rev/276bebf0bde6
branches: trunk
changeset: 338653:276bebf0bde6
user: hsuenaga <hsuenaga%NetBSD.org@localhost>
date: Wed Jun 03 03:25:51 2015 +0000
description:
initialize ARMADA XP's Mbus address decoder and code clean up
probably we need more sophisticated Mbus driver or KPI...
diffstat:
sys/arch/evbarm/marvell/marvell_machdep.c | 115 +++++++++++++++++++----------
1 files changed, 74 insertions(+), 41 deletions(-)
diffs (211 lines):
diff -r f61dfcc2c464 -r 276bebf0bde6 sys/arch/evbarm/marvell/marvell_machdep.c
--- a/sys/arch/evbarm/marvell/marvell_machdep.c Wed Jun 03 03:04:21 2015 +0000
+++ b/sys/arch/evbarm/marvell/marvell_machdep.c Wed Jun 03 03:25:51 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: marvell_machdep.c,v 1.31 2015/05/14 05:39:32 hsuenaga Exp $ */
+/* $NetBSD: marvell_machdep.c,v 1.32 2015/06/03 03:25:51 hsuenaga Exp $ */
/*
* Copyright (c) 2007, 2008, 2010 KIYOHARA Takashi
* All rights reserved.
@@ -25,7 +25,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: marvell_machdep.c,v 1.31 2015/05/14 05:39:32 hsuenaga Exp $");
+__KERNEL_RCSID(0, "$NetBSD: marvell_machdep.c,v 1.32 2015/06/03 03:25:51 hsuenaga Exp $");
#include "opt_evbarm_boardtype.h"
#include "opt_ddb.h"
@@ -130,6 +130,45 @@
static void marvell_startend_by_tag(int, uint64_t *, uint64_t *);
#endif
+static void
+marvell_fixup_mbus_pex(int memtag, int iotag)
+{
+ uint32_t target, attr;
+ int window;
+
+ /* Reset PCI-Express space to window register. */
+ window = mvsoc_target(memtag, &target, &attr, NULL, NULL);
+ write_mlmbreg(MVSOC_MLMB_WCR(window),
+ MVSOC_MLMB_WCR_WINEN |
+ MVSOC_MLMB_WCR_TARGET(target) |
+ MVSOC_MLMB_WCR_ATTR(attr) |
+ MVSOC_MLMB_WCR_SIZE(MARVELL_PEXMEM_SIZE));
+ write_mlmbreg(MVSOC_MLMB_WBR(window),
+ MARVELL_PEXMEM_PBASE & MVSOC_MLMB_WBR_BASE_MASK);
+#ifdef PCI_NETBSD_CONFIGURE
+ if (window < nremap) {
+ write_mlmbreg(MVSOC_MLMB_WRLR(window),
+ MARVELL_PEXMEM_PBASE & MVSOC_MLMB_WRLR_REMAP_MASK);
+ write_mlmbreg(MVSOC_MLMB_WRHR(window), 0);
+ }
+#endif
+ window = mvsoc_target(iotag, &target, &attr, NULL, NULL);
+ write_mlmbreg(MVSOC_MLMB_WCR(window),
+ MVSOC_MLMB_WCR_WINEN |
+ MVSOC_MLMB_WCR_TARGET(target) |
+ MVSOC_MLMB_WCR_ATTR(attr) |
+ MVSOC_MLMB_WCR_SIZE(MARVELL_PEXIO_SIZE));
+ write_mlmbreg(MVSOC_MLMB_WBR(window),
+ MARVELL_PEXIO_PBASE & MVSOC_MLMB_WBR_BASE_MASK);
+#ifdef PCI_NETBSD_CONFIGURE
+ if (window < nremap) {
+ write_mlmbreg(MVSOC_MLMB_WRLR(window),
+ MARVELL_PEXIO_PBASE & MVSOC_MLMB_WRLR_REMAP_MASK);
+ write_mlmbreg(MVSOC_MLMB_WRHR(window), 0);
+ }
+#endif
+}
+
#if defined(ORION) || defined(KIRKWOOD) || defined(MV78XX0)
static void
marvell_system_reset(void)
@@ -146,8 +185,20 @@
cpu_reset();
/*NOTREACHED*/
}
+
+static void
+marvell_fixup_mbus(int memtag, int iotag)
+{
+ /* assume u-boot initializes mbus registers correctly */
+
+ /* set marvell common PEX params */
+ marvell_fixup_mbus_pex(memtag, iotag);
+
+ /* other configurations? */
+}
#endif
+
#if defined(ARMADAXP)
static void
armadaxp_system_reset(void)
@@ -166,6 +217,18 @@
/*NOTREACHED*/
}
+
+static void
+armadaxp_fixup_mbus(int memtag, int iotag)
+{
+ /* force set SoC default parameters */
+ armadaxp_init_mbus();
+
+ /* set marvell common PEX params */
+ marvell_fixup_mbus_pex(memtag, iotag);
+
+ /* other configurations? */
+}
#endif
@@ -223,8 +286,7 @@
u_int
initarm(void *arg)
{
- uint32_t target, attr, base, size;
- int cs, cs_end, memtag = 0, iotag = 0, window;
+ int cs, cs_end, memtag = 0, iotag = 0;
mvsoc_bootstrap(MARVELL_INTERREGS_VBASE);
@@ -277,6 +339,7 @@
cs_end = MARVELL_TAG_SDRAM_CS3;
orion_getclks(MARVELL_INTERREGS_VBASE);
+ marvell_fixup_mbus(memtag, iotag);
break;
#endif /* ORION */
@@ -299,6 +362,7 @@
kirkwood_getclks(MARVELL_INTERREGS_VBASE);
mvsoc_clkgating = kirkwood_clkgating;
+ marvell_fixup_mbus(memtag, iotag);
break;
#endif /* KIRKWOOD */
@@ -318,6 +382,7 @@
cs_end = MARVELL_TAG_SDRAM_CS3;
mv78xx0_getclks(MARVELL_INTERREGS_VBASE);
+ marvell_fixup_mbus(memtag, iotag);
break;
#endif /* MV78XX0 */
@@ -343,6 +408,7 @@
misc_base = MARVELL_INTERREGS_VBASE + ARMADAXP_MISC_BASE;
armadaxp_getclks();
mvsoc_clkgating = armadaxp_clkgating;
+ armadaxp_fixup_mbus(memtag, iotag);
#ifdef L2CACHE_ENABLE
/* Initialize L2 Cache */
@@ -374,14 +440,11 @@
misc_base = MARVELL_INTERREGS_VBASE + ARMADAXP_MISC_BASE;
armada370_getclks();
mvsoc_clkgating = armadaxp_clkgating;
+ armadaxp_fixup_mbus(memtag, iotag);
#ifdef L2CACHE_ENABLE
/* Initialize L2 Cache */
- {
- extern int armadaxp_l2_init(bus_addr_t);
-
- (void)armadaxp_l2_init(MARVELL_INTERREGS_PBASE);
- }
+ (void)armadaxp_l2_init(MARVELL_INTERREGS_PBASE);
#endif
#ifdef AURORA_IO_CACHE_COHERENCY
@@ -408,38 +471,6 @@
#define _BDSTR(s) #s
printf("\nNetBSD/evbarm (" BDSTR(EVBARM_BOARDTYPE) ") booting ...\n");
- /* Reset PCI-Express space to window register. */
- window = mvsoc_target(memtag, &target, &attr, NULL, NULL);
- write_mlmbreg(MVSOC_MLMB_WCR(window),
- MVSOC_MLMB_WCR_WINEN |
- MVSOC_MLMB_WCR_TARGET(target) |
- MVSOC_MLMB_WCR_ATTR(attr) |
- MVSOC_MLMB_WCR_SIZE(MARVELL_PEXMEM_SIZE));
- write_mlmbreg(MVSOC_MLMB_WBR(window),
- MARVELL_PEXMEM_PBASE & MVSOC_MLMB_WBR_BASE_MASK);
-#ifdef PCI_NETBSD_CONFIGURE
- if (window < nremap) {
- write_mlmbreg(MVSOC_MLMB_WRLR(window),
- MARVELL_PEXMEM_PBASE & MVSOC_MLMB_WRLR_REMAP_MASK);
- write_mlmbreg(MVSOC_MLMB_WRHR(window), 0);
- }
-#endif
- window = mvsoc_target(iotag, &target, &attr, NULL, NULL);
- write_mlmbreg(MVSOC_MLMB_WCR(window),
- MVSOC_MLMB_WCR_WINEN |
- MVSOC_MLMB_WCR_TARGET(target) |
- MVSOC_MLMB_WCR_ATTR(attr) |
- MVSOC_MLMB_WCR_SIZE(MARVELL_PEXIO_SIZE));
- write_mlmbreg(MVSOC_MLMB_WBR(window),
- MARVELL_PEXIO_PBASE & MVSOC_MLMB_WBR_BASE_MASK);
-#ifdef PCI_NETBSD_CONFIGURE
- if (window < nremap) {
- write_mlmbreg(MVSOC_MLMB_WRLR(window),
- MARVELL_PEXIO_PBASE & MVSOC_MLMB_WRLR_REMAP_MASK);
- write_mlmbreg(MVSOC_MLMB_WRHR(window), 0);
- }
-#endif
-
/* copy command line U-Boot gave us, if args is valid. */
if (u_boot_args[3] != 0) /* XXXXX: need more check?? */
strncpy(bootargs, (char *)u_boot_args[3], sizeof(bootargs));
@@ -452,6 +483,8 @@
paddr_t segment_end;
segment_end = physmem = 0;
for ( ; cs <= cs_end; cs++) {
+ uint32_t target, attr, base, size;
+
mvsoc_target(cs, &target, &attr, &base, &size);
if (size == 0)
continue;
Home |
Main Index |
Thread Index |
Old Index