Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 29 Mar 2007 14:46:28 GMT
From:      Oleksandr Tymoshenko <gonzo@FreeBSD.org>
To:        Perforce Change Reviews <perforce@FreeBSD.org>
Subject:   PERFORCE change 116835 for review
Message-ID:  <200703291446.l2TEkS4Q040190@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=116835

Change 116835 by gonzo@gonzo_jeeves on 2007/03/29 14:45:45

	o Fill out cache ops structure with mipsNN routines.
	o Perform presence check for every type of cache ops.

Affected files ...

.. //depot/projects/mips2/src/sys/mips/mips/cache.c#2 edit

Differences ...

==== //depot/projects/mips2/src/sys/mips/mips/cache.c#2 (text+ko) ====

@@ -26,16 +26,166 @@
  */
 
 #include <sys/types.h>
+#include <sys/systm.h>
 
+#include <machine/cpuinfo.h>
 #include <machine/cache.h>
 
 struct mips_cache_ops mips_cache_ops;
 
-/*
- *  XXXMIPS: Implement mips_cache_ops initialization
- */
 void
-mips_config_cache()
+mips_config_cache(struct mips_cpuinfo * cpuinfo)
 {
+	switch (cpuinfo->l1.ic_linesize) {
+	case 16:
+		mips_cache_ops.mco_icache_sync_all = mipsNN_icache_sync_all_16;
+		mips_cache_ops.mco_icache_sync_range =
+		    mipsNN_icache_sync_range_16;
+		mips_cache_ops.mco_icache_sync_range_index =
+		    mipsNN_icache_sync_range_index_16;
+		break;
+	case 32:
+		mips_cache_ops.mco_icache_sync_all = mipsNN_icache_sync_all_32;
+		mips_cache_ops.mco_icache_sync_range =
+		    mipsNN_icache_sync_range_32;
+		mips_cache_ops.mco_icache_sync_range_index =
+		    mipsNN_icache_sync_range_index_32;
+		break;
+#ifdef MIPS_DISABLE_L1_CACHE
+	case 0:
+		mips_cache_ops.mco_icache_sync_all = cache_noop;
+		mips_cache_ops.mco_icache_sync_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_icache_sync_range_index =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		break;
+#endif
+	default:
+		panic("no Icache ops for %d byte lines",
+		    cpuinfo->l1.ic_linesize);
+	}
+
+	switch (cpuinfo->l1.dc_linesize) {
+	case 16:
+		mips_cache_ops.mco_pdcache_wbinv_all =
+		    mips_cache_ops.mco_intern_pdcache_wbinv_all =
+		    mipsNN_pdcache_wbinv_all_16;
+		mips_cache_ops.mco_pdcache_wbinv_range =
+		    mipsNN_pdcache_wbinv_range_16;
+		mips_cache_ops.mco_pdcache_wbinv_range_index =
+		    mips_cache_ops.mco_intern_pdcache_wbinv_range_index =
+		    mipsNN_pdcache_wbinv_range_index_16;
+		mips_cache_ops.mco_pdcache_inv_range =
+		    mipsNN_pdcache_inv_range_16;
+		mips_cache_ops.mco_pdcache_wb_range =
+		    mips_cache_ops.mco_intern_pdcache_wb_range =
+		    mipsNN_pdcache_wb_range_16;
+		break;
+	case 32:
+		mips_cache_ops.mco_pdcache_wbinv_all =
+		    mips_cache_ops.mco_intern_pdcache_wbinv_all =
+		    mipsNN_pdcache_wbinv_all_32;
+		mips_cache_ops.mco_pdcache_wbinv_range =
+		    mipsNN_pdcache_wbinv_range_32;
+		mips_cache_ops.mco_pdcache_wbinv_range_index =
+		    mips_cache_ops.mco_intern_pdcache_wbinv_range_index =
+		    mipsNN_pdcache_wbinv_range_index_32;
+		mips_cache_ops.mco_pdcache_inv_range =
+		    mipsNN_pdcache_inv_range_32;
+		mips_cache_ops.mco_pdcache_wb_range =
+		    mips_cache_ops.mco_intern_pdcache_wb_range =
+		    mipsNN_pdcache_wb_range_32;
+		break;
+#ifdef MIPS_DISABLE_L1_CACHE
+	case 0:
+		mips_cache_ops.mco_pdcache_wbinv_all = cache_noop;
+		mips_cache_ops.mco_intern_pdcache_wbinv_all = cache_noop;
+		mips_cache_ops.mco_pdcache_wbinv_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_pdcache_wbinv_range_index =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_intern_pdcache_wbinv_range_index =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_pdcache_inv_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_pdcache_wb_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_intern_pdcache_wb_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		break;
+#endif
+	default:
+		panic("no Dcache ops for %d byte lines",
+		    cpuinfo->l1.dc_linesize);
+	}
+
+	mipsNN_cache_init(cpuinfo);
+	printf("mips_cache_ops.mco_pdcache_wbinv_all  == %p\n", mips_cache_ops.mco_pdcache_wbinv_all );
+
+#if 0
+	if (mips_cpu_flags &
+	    (CPU_MIPS_D_CACHE_COHERENT | CPU_MIPS_I_D_CACHE_COHERENT)) {
+#ifdef CACHE_DEBUG
+		printf("  Dcache is coherent\n");
+#endif
+		mips_cache_ops.mco_pdcache_wbinv_all = cache_noop;
+		mips_cache_ops.mco_pdcache_wbinv_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_pdcache_wbinv_range_index =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_pdcache_inv_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_pdcache_wb_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+	}
+	if (mips_cpu_flags & CPU_MIPS_I_D_CACHE_COHERENT) {
+#ifdef CACHE_DEBUG
+		printf("  Icache is coherent against Dcache\n");
+#endif
+		mips_cache_ops.mco_intern_pdcache_wbinv_all =
+		    cache_noop;
+		mips_cache_ops.mco_intern_pdcache_wbinv_range_index =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+		mips_cache_ops.mco_intern_pdcache_wb_range =
+		    (void (*)(vaddr_t, vsize_t))cache_noop;
+	}
+#endif
+
+	/* Check that all cache ops are set up. */
+	if (mips_picache_size || 1) {   /* XXX- must have primary Icache */
+		if (!mips_cache_ops.mco_icache_sync_all)
+			panic("no icache_sync_all cache op");
+		if (!mips_cache_ops.mco_icache_sync_range)
+			panic("no icache_sync_range cache op");
+		if (!mips_cache_ops.mco_icache_sync_range_index)
+			panic("no icache_sync_range_index cache op");
+	}
+	if (mips_pdcache_size || 1) {   /* XXX- must have primary Icache */
+		if (!mips_cache_ops.mco_pdcache_wbinv_all)
+			panic("no pdcache_wbinv_all");
+		if (!mips_cache_ops.mco_pdcache_wbinv_range)
+			panic("no pdcache_wbinv_range");
+		if (!mips_cache_ops.mco_pdcache_wbinv_range_index)
+			panic("no pdcache_wbinv_range_index");
+		if (!mips_cache_ops.mco_pdcache_inv_range)
+			panic("no pdcache_inv_range");
+		if (!mips_cache_ops.mco_pdcache_wb_range)
+			panic("no pdcache_wb_range");
+	}
+
+	/* XXXMIPS: No secondary cache handlers yet */
+#ifdef notyet
+	if (mips_sdcache_size) {
+		if (!mips_cache_ops.mco_sdcache_wbinv_all)
+			panic("no sdcache_wbinv_all");
+		if (!mips_cache_ops.mco_sdcache_wbinv_range)
+			panic("no sdcache_wbinv_range");
+		if (!mips_cache_ops.mco_sdcache_wbinv_range_index)
+			panic("no sdcache_wbinv_range_index");
+		if (!mips_cache_ops.mco_sdcache_inv_range)
+			panic("no sdcache_inv_range");
+		if (!mips_cache_ops.mco_sdcache_wb_range)
+			panic("no sdcache_wb_range");
+	}
+#endif
 }
-



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200703291446.l2TEkS4Q040190>