mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
7db791476e
Signed-off-by: Jean Pierre Dudey <me@jeandudey.tech>
207 lines
9.1 KiB
C
207 lines
9.1 KiB
C
/******************************************************************************
|
|
* Filename: hw_vims_h
|
|
* Revised: 2017-01-31 09:37:48 +0100 (Tue, 31 Jan 2017)
|
|
* Revision: 48345
|
|
*
|
|
* Copyright (c) 2015 - 2017, Texas Instruments Incorporated
|
|
* All rights reserved.
|
|
*
|
|
* 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.
|
|
*
|
|
* 3) Neither the name of the ORGANIZATION nor the names of its contributors may
|
|
* be used to endorse or promote products derived from this software without
|
|
* specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 COPYRIGHT HOLDER OR CONTRIBUTORS 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 __HW_VIMS_H__
|
|
#define __HW_VIMS_H__
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// This section defines the register offsets of
|
|
// VIMS component
|
|
//
|
|
//*****************************************************************************
|
|
// Status
|
|
#define VIMS_O_STAT 0x00000000
|
|
|
|
// Control
|
|
#define VIMS_O_CTL 0x00000004
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: VIMS_O_STAT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [5] IDCODE_LB_DIS
|
|
//
|
|
// Icode/Dcode flash line buffer status
|
|
//
|
|
// 0: Enabled or in transition to disabled
|
|
// 1: Disabled and flushed
|
|
#define VIMS_STAT_IDCODE_LB_DIS 0x00000020
|
|
#define VIMS_STAT_IDCODE_LB_DIS_BITN 5
|
|
#define VIMS_STAT_IDCODE_LB_DIS_M 0x00000020
|
|
#define VIMS_STAT_IDCODE_LB_DIS_S 5
|
|
|
|
// Field: [4] SYSBUS_LB_DIS
|
|
//
|
|
// Sysbus flash line buffer control
|
|
//
|
|
// 0: Enabled or in transition to disabled
|
|
// 1: Disabled and flushed
|
|
#define VIMS_STAT_SYSBUS_LB_DIS 0x00000010
|
|
#define VIMS_STAT_SYSBUS_LB_DIS_BITN 4
|
|
#define VIMS_STAT_SYSBUS_LB_DIS_M 0x00000010
|
|
#define VIMS_STAT_SYSBUS_LB_DIS_S 4
|
|
|
|
// Field: [3] MODE_CHANGING
|
|
//
|
|
// VIMS mode change status
|
|
//
|
|
// 0: VIMS is in the mode defined by MODE
|
|
// 1: VIMS is in the process of changing to the mode given in CTL.MODE
|
|
#define VIMS_STAT_MODE_CHANGING 0x00000008
|
|
#define VIMS_STAT_MODE_CHANGING_BITN 3
|
|
#define VIMS_STAT_MODE_CHANGING_M 0x00000008
|
|
#define VIMS_STAT_MODE_CHANGING_S 3
|
|
|
|
// Field: [2] INV
|
|
//
|
|
// This bit is set when invalidation of the cache memory is active / ongoing
|
|
#define VIMS_STAT_INV 0x00000004
|
|
#define VIMS_STAT_INV_BITN 2
|
|
#define VIMS_STAT_INV_M 0x00000004
|
|
#define VIMS_STAT_INV_S 2
|
|
|
|
// Field: [1:0] MODE
|
|
//
|
|
// Current VIMS mode
|
|
// ENUMs:
|
|
// OFF VIMS Off mode
|
|
// CACHE VIMS Cache mode
|
|
// GPRAM VIMS GPRAM mode
|
|
#define VIMS_STAT_MODE_W 2
|
|
#define VIMS_STAT_MODE_M 0x00000003
|
|
#define VIMS_STAT_MODE_S 0
|
|
#define VIMS_STAT_MODE_OFF 0x00000003
|
|
#define VIMS_STAT_MODE_CACHE 0x00000001
|
|
#define VIMS_STAT_MODE_GPRAM 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: VIMS_O_CTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31] STATS_CLR
|
|
//
|
|
// Set this bit to clear statistic counters.
|
|
#define VIMS_CTL_STATS_CLR 0x80000000
|
|
#define VIMS_CTL_STATS_CLR_BITN 31
|
|
#define VIMS_CTL_STATS_CLR_M 0x80000000
|
|
#define VIMS_CTL_STATS_CLR_S 31
|
|
|
|
// Field: [30] STATS_EN
|
|
//
|
|
// Set this bit to enable statistic counters.
|
|
#define VIMS_CTL_STATS_EN 0x40000000
|
|
#define VIMS_CTL_STATS_EN_BITN 30
|
|
#define VIMS_CTL_STATS_EN_M 0x40000000
|
|
#define VIMS_CTL_STATS_EN_S 30
|
|
|
|
// Field: [29] DYN_CG_EN
|
|
//
|
|
// 0: The in-built clock gate functionality is bypassed.
|
|
// 1: The in-built clock gate functionality is enabled, automatically gating
|
|
// the clock when not needed.
|
|
#define VIMS_CTL_DYN_CG_EN 0x20000000
|
|
#define VIMS_CTL_DYN_CG_EN_BITN 29
|
|
#define VIMS_CTL_DYN_CG_EN_M 0x20000000
|
|
#define VIMS_CTL_DYN_CG_EN_S 29
|
|
|
|
// Field: [5] IDCODE_LB_DIS
|
|
//
|
|
// Icode/Dcode flash line buffer control
|
|
//
|
|
// 0: Enable
|
|
// 1: Disable
|
|
#define VIMS_CTL_IDCODE_LB_DIS 0x00000020
|
|
#define VIMS_CTL_IDCODE_LB_DIS_BITN 5
|
|
#define VIMS_CTL_IDCODE_LB_DIS_M 0x00000020
|
|
#define VIMS_CTL_IDCODE_LB_DIS_S 5
|
|
|
|
// Field: [4] SYSBUS_LB_DIS
|
|
//
|
|
// Sysbus flash line buffer control
|
|
//
|
|
// 0: Enable
|
|
// 1: Disable
|
|
#define VIMS_CTL_SYSBUS_LB_DIS 0x00000010
|
|
#define VIMS_CTL_SYSBUS_LB_DIS_BITN 4
|
|
#define VIMS_CTL_SYSBUS_LB_DIS_M 0x00000010
|
|
#define VIMS_CTL_SYSBUS_LB_DIS_S 4
|
|
|
|
// Field: [3] ARB_CFG
|
|
//
|
|
// Icode/Dcode and sysbus arbitation scheme
|
|
//
|
|
// 0: Static arbitration (icode/docde > sysbus)
|
|
// 1: Round-robin arbitration
|
|
#define VIMS_CTL_ARB_CFG 0x00000008
|
|
#define VIMS_CTL_ARB_CFG_BITN 3
|
|
#define VIMS_CTL_ARB_CFG_M 0x00000008
|
|
#define VIMS_CTL_ARB_CFG_S 3
|
|
|
|
// Field: [2] PREF_EN
|
|
//
|
|
// Tag prefetch control
|
|
//
|
|
// 0: Disabled
|
|
// 1: Enabled
|
|
#define VIMS_CTL_PREF_EN 0x00000004
|
|
#define VIMS_CTL_PREF_EN_BITN 2
|
|
#define VIMS_CTL_PREF_EN_M 0x00000004
|
|
#define VIMS_CTL_PREF_EN_S 2
|
|
|
|
// Field: [1:0] MODE
|
|
//
|
|
// VIMS mode request.
|
|
// Write accesses to this field will be blocked while STAT.MODE_CHANGING is set
|
|
// to 1.
|
|
// Note: Transaction from CACHE mode to GPRAM mode should be done through OFF
|
|
// mode to minimize flash block delay.
|
|
// ENUMs:
|
|
// OFF VIMS Off mode
|
|
// CACHE VIMS Cache mode
|
|
// GPRAM VIMS GPRAM mode
|
|
#define VIMS_CTL_MODE_W 2
|
|
#define VIMS_CTL_MODE_M 0x00000003
|
|
#define VIMS_CTL_MODE_S 0
|
|
#define VIMS_CTL_MODE_OFF 0x00000003
|
|
#define VIMS_CTL_MODE_CACHE 0x00000001
|
|
#define VIMS_CTL_MODE_GPRAM 0x00000000
|
|
|
|
|
|
#endif // __VIMS__
|