OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [branches/] [stable_0_2_x/] [or1ksim/] [peripheral/] [mc.h] - Diff between revs 261 and 398

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 261 Rev 398
Line 1... Line 1...
/* mc.c -- Simulation of Memory Controller
/* mc.h -- Simulation of Memory Controller
         Copyright (C) 2001 by Marko Mlinar, markom@opencores.org
         Copyright (C) 2001 by Marko Mlinar, markom@opencores.org
 
 
         This file is part of OpenRISC 1000 Architectural Simulator.
         This file is part of OpenRISC 1000 Architectural Simulator.
 
 
         This program is free software; you can redistribute it and/or modify
         This program is free software; you can redistribute it and/or modify
Line 17... Line 17...
         along with this program; if not, write to the Free Software
         along with this program; if not, write to the Free Software
         Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
         Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
*/
 
 
/* Prototypes */
/* Prototypes */
 
#ifndef __MC_H
 
#define __MC_H
 
 
void mc_reset();
void mc_reset();
inline void mc_clock();
inline void mc_clock();
 
 
#define N_CE        (8)
#define N_CE        (8)
 
 
#define MC_CSR      (0x00)
#define MC_CSR      (0x00)
#define MC_POC      (0x04)
#define MC_POC      (0x04)
#define MC_BA_MASK  (0x08)
#define MC_BA_MASK  (0x08)
#define MC_CSC(i)   (0x10 + (i) * 4)
#define MC_CSC(i)   (0x10 + (i) * 8)
#define MC_TMS(i)   (0x14 + (i) * 4)
#define MC_TMS(i)   (0x14 + (i) * 8)
 
 
#define MC_ADDR_SPACE (MC_CSC(N_CE))
#define MC_ADDR_SPACE (MC_CSC(N_CE))
 
 
 
/* CSC register field definition */
 
#define MC_CSC_EN_OFFSET        0
 
#define MC_CSC_MEMTYPE_OFFSET   1
 
#define MC_CSC_MEMTYPE_WIDTH    2
 
#define MC_CSC_BW_OFFSET        4
 
#define MC_CSC_BW_WIDTH         2
 
#define MC_CSC_MS_OFFSET        6
 
#define MC_CSC_MS_WIDTH         2
 
#define MC_CSC_WP_OFFSET        8
 
#define MC_CSC_BAS_OFFSET       9
 
#define MC_CSC_KRO_OFFSET       10
 
#define MC_CSC_PEN_OFFSET       11
 
#define MC_CSC_SEL_OFFSET       16
 
#define MC_CSC_SEL_WIDTH        8
 
 
 
#define MC_CSR_VALID            0xFF000703LU
 
#define MC_POC_VALID            0x000000FFLU
 
#define MC_BA_MASK_VALID        0x000000FFLU
 
#define MC_CSC_VALID            0x00FF0FFFLU
 
#define MC_TMS_SDRAM_VALID      0x0FFF83FFLU
 
#define MC_TMS_SSRAM_VALID      0x00000000LU
 
#define MC_TMS_ASYNC_VALID      0x03FFFFFFLU
 
#define MC_TMS_SYNC_VALID       0x01FFFFFFLU
 
#define MC_TMS_VALID            0xFFFFFFFFLU /* reg test compat. */
 
 
 
/* TMS register field definition SDRAM */
 
#define MC_TMS_SDRAM_TRFC_OFFSET        24
 
#define MC_TMS_SDRAM_TRFC_WIDTH         4
 
#define MC_TMS_SDRAM_TRP_OFFSET         20
 
#define MC_TMS_SDRAM_TRP_WIDTH          4
 
#define MC_TMS_SDRAM_TRCD_OFFSET        17
 
#define MC_TMS_SDRAM_TRCD_WIDTH         4
 
#define MC_TMS_SDRAM_TWR_OFFSET         15
 
#define MC_TMS_SDRAM_TWR_WIDTH          2
 
#define MC_TMS_SDRAM_WBL_OFFSET         9
 
#define MC_TMS_SDRAM_OM_OFFSET          7
 
#define MC_TMS_SDRAM_OM_WIDTH           2
 
#define MC_TMS_SDRAM_CL_OFFSET          4
 
#define MC_TMS_SDRAM_CL_WIDTH           3
 
#define MC_TMS_SDRAM_BT_OFFSET          3
 
#define MC_TMS_SDRAM_BL_OFFSET          0
 
#define MC_TMS_SDRAM_BL_WIDTH           3
 
 
 
/* TMS register field definition ASYNC */
 
#define MC_TMS_ASYNC_TWWD_OFFSET        20
 
#define MC_TMS_ASYNC_TWWD_WIDTH         6
 
#define MC_TMS_ASYNC_TWD_OFFSET         16
 
#define MC_TMS_ASYNC_TWD_WIDTH          4
 
#define MC_TMS_ASYNC_TWPW_OFFSET        12
 
#define MC_TMS_ASYNC_TWPW_WIDTH         4
 
#define MC_TMS_ASYNC_TRDZ_OFFSET        8
 
#define MC_TMS_ASYNC_TRDZ_WIDTH         4
 
#define MC_TMS_ASYNC_TRDV_OFFSET        0
 
#define MC_TMS_ASYNC_TRDV_WIDTH         8
 
 
 
/* TMS register field definition SYNC  */
 
#define MC_TMS_SYNC_TTO_OFFSET          16
 
#define MC_TMS_SYNC_TTO_WIDTH           9
 
#define MC_TMS_SYNC_TWR_OFFSET          12
 
#define MC_TMS_SYNC_TWR_WIDTH           4
 
#define MC_TMS_SYNC_TRDZ_OFFSET         8
 
#define MC_TMS_SYNC_TRDZ_WIDTH          4
 
#define MC_TMS_SYNC_TRDV_OFFSET         0
 
#define MC_TMS_SYNC_TRDV_WIDTH          8
 
 
struct mc {
struct mc {
  unsigned long csr;
  unsigned long csr;
  unsigned long poc;
  unsigned long poc;
  unsigned long ba_mask;
  unsigned long ba_mask;
  unsigned long csc[N_CE];
  unsigned long csc[N_CE];
  unsigned long tms[N_CE];
  unsigned long tms[N_CE];
};
};
 
 
 No newline at end of file
 No newline at end of file
 
#endif
 
 
 No newline at end of file
 No newline at end of file

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.