/******************************************************************************/ 
/*                                                                            */ 
/* Copyright (c) 1999 Sun Microsystems, Inc. All rights reserved.             */ 
/*                                                                            */ 
/* The contents of this file are subject to the current version of the Sun    */ 
/* Community Source License, microSPARCII ("the License"). You may not use    */ 
/* this file except in compliance with the License.  You may obtain a copy    */ 
/* of the License by searching for "Sun Community Source License" on the      */ 
/* World Wide Web at http://www.sun.com. See the License for the rights,      */ 
/* obligations, and limitations governing use of the contents of this file.   */ 
/*                                                                            */ 
/* Sun Microsystems, Inc. has intellectual property rights relating to the    */ 
/* technology embodied in these files. In particular, and without limitation, */ 
/* these intellectual property rights may include one or more U.S. patents,   */ 
/* foreign patents, or pending applications.                                  */ 
/*                                                                            */ 
/* Sun, Sun Microsystems, the Sun logo, all Sun-based trademarks and logos,   */ 
/* Solaris, Java and all Java-based trademarks and logos are trademarks or    */ 
/* registered trademarks of Sun Microsystems, Inc. in the United States and   */ 
/* other countries. microSPARC is a trademark or registered trademark of      */ 
/* SPARC International, Inc. All SPARC trademarks are used under license and  */ 
/* are trademarks or registered trademarks of SPARC International, Inc. in    */ 
/* the United States and other countries. Products bearing SPARC trademarks   */ 
/* are based upon an architecture developed by Sun Microsystems, Inc.         */ 
/*                                                                            */ 
/******************************************************************************/ 
/* This file contains basic parameters required by the Singlesparc
   chip to define the cache & tag. Primary parameters are used 
   to derive secondary terms. 
*/ 
 
// Primary parameters (all in bytes unless indicated)
 
`define ifillcnt 4		/* Icache fill count in double-words */
`define ifillcntmsb 3		/* Icache fill count MSB */
`define dfillcnt 2		/* Dcache fill count in double-words */
`define log2_maxphysize 27      /* max 128Mbyte physical address */
`define mspa (`log2_maxphysize-1)  /* MSB of physical addresses */
`define log2_datasize 3         /* 8 bytes = data width (word - 32 bits) */
`define log2_pagesize 12		/* 4Kbytes is page size */
`define log2_pagesize_msb (`log2_pagesize-1)	/* MSB of page size */
// main memory stuff
//   log2_main_mem_size is a dynamic parameter, defined by the run script.
`define main_mem_size (1<<`log2_main_mem_size)  /* main_mem size in bytes */
// Secondary parameters
//	icache data
`define ic_msb (`log2_icachesize-1) 	/* msb of icache address bit */
`define ic_size (1<<`log2_icachesize) 	/* icache size in bytes */
`define ic_maxbyte (`ic_size-1)		/* icache size msb of no. of bytes */
`define ic_blksize (1<<`log2_iblksize)	/* icache blk size in bytes */
`define ic_iblkmsb (`log2_iblksize-1)   /* icache blk size MSB */
`define ic_msbwordaddr ((`log2_iblksize-`log2_datasize)-1) /* ic word addr */
//	dcache data
`define dc_msb (`log2_dcachesize-1) 	/* msb of dcache address bit */
// Dcache crtl gets all of these DVA bits, since VA bits within the page
//     index are used for PA in small caches.
`define dc_dva_msb ((`log2_dcachesize<`log2_pagesize)?`log2_pagesize_msb:`dc_msb)
`define dc_size (1<<`log2_dcachesize) 	/* dcache size in bytes */
`define dc_maxbyte (`dc_size-1)		/* dcache size msb of no. of bytes */
`define dc_blksize (1<<`log2_dblksize)	/* dcache blk size in bytes */
`define dc_msbwordaddr ((`log2_dblksize-`log2_datasize)-1) /* dc word addr */
`define dc_dblksize_msb  (`log2_dblksize-1)      /* dcache block size MSB */
//	tag array (note: assumes direct mapped caches & valid bit is separate)
//	itag array
`define it_lspa `log2_icachesize   // Vestigial - must remove
`define it_width (31-`log2_icachesize+1) /* width of itag VA field  */
`define it_msb (`it_width-1) 	/* msb of itag VA field */
`define it_blks (`ic_size/`ic_blksize)	/* no. of blks in icache */
`define it_maxblks (`it_blks-1)				/* msb of blks */
`define it_blkaddr (`log2_icachesize-`log2_iblksize) /*  blk addr for itag */
`define it_msbblks ((`log2_icachesize-`log2_iblksize)-1) /* msb of blk addr for itag */
//	dtag array
`define dt_lspa `log2_dcachesize   // Vestigial - must remove
`define dt_lspa_msb (`dt_lspa - 1) // Vestigial - must remove
`define dt_width (31-`log2_dcachesize+1) /* width of dtag data  */
`define dt_msb (`dt_width-1)
`define dt_blks (`dc_size/`dc_blksize)			/* no. of blks in dtag */
`define dt_maxblks (`dt_blks-1)				/* msb of blks */
`define dt_blkaddr (`log2_dcachesize-`log2_dblksize) /*  blk addr for dtag */
`define dt_msbblks ((`log2_dcachesize-`log2_dblksize)-1)  /* msb of blk addr for dtag */
 | This page: | Created: | Thu Aug 19 12:02:32 1999 | 
   | From: | ../../../sparc_v8/system/rtl/memdef.h |