summaryrefslogtreecommitdiff
path: root/include/arch/rm46l8lp/halcogen/reg_vim.h
blob: 4922efb74d3a24adbd522b8ccaae38ceb5bcdc5c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/** @file reg_vim.h
*   @brief VIM Register Layer Header File
*   @date 11-Dec-2018
*   @version 04.07.01
*   
*   This file contains:
*   - Definitions
*   - Types
*   .
*   which are relevant for the System driver.
*/

/* 
* Copyright (C) 2009-2018 Texas Instruments Incorporated - www.ti.com  
* 
* 
*  Redistribution and use in source and binary forms, with or without 
*  modification, are permitted provided that the following conditions 
*  are met:
*
*    Redistributions of source code must retain the above copyright 
*    notice, this list of conditions and the following disclaimer.
*
*    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.
*
*    Neither the name of Texas Instruments Incorporated 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 
*  OWNER 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 __REG_VIM_H__
#define __REG_VIM_H__

#include "sys_common.h"

/* USER CODE BEGIN (0) */
/* USER CODE END */

/* Vim Register Frame Definition */
/** @struct vimBase
*   @brief Vim Register Frame Definition
*
*   This type is used to access the Vim Registers.
*/
/** @typedef vimBASE_t
*   @brief VIM Register Frame Type Definition
*
*   This type is used to access the VIM Registers.
*/
typedef volatile struct vimBase
{
    uint32      IRQINDEX;         /* 0x0000       */
    uint32      FIQINDEX;         /* 0x0004       */	
    uint32        rsvd1;          /* 0x0008       */
    uint32        rsvd2;          /* 0x000C       */
    uint32      FIRQPR0;          /* 0x0010       */
    uint32      FIRQPR1;          /* 0x0014       */
    uint32      FIRQPR2;          /* 0x0018       */
    uint32      FIRQPR3;          /* 0x001C       */
    uint32      INTREQ0;          /* 0x0020       */
    uint32      INTREQ1;          /* 0x0024       */
    uint32      INTREQ2;          /* 0x0028       */
    uint32      INTREQ3;          /* 0x002C       */
    uint32      REQMASKSET0;      /* 0x0030       */
    uint32      REQMASKSET1;      /* 0x0034       */
    uint32      REQMASKSET2;      /* 0x0038       */
    uint32      REQMASKSET3;      /* 0x003C       */
    uint32      REQMASKCLR0;      /* 0x0040       */
    uint32      REQMASKCLR1;      /* 0x0044       */
    uint32      REQMASKCLR2;      /* 0x0048       */
    uint32      REQMASKCLR3;      /* 0x004C       */
    uint32      WAKEMASKSET0;     /* 0x0050       */
    uint32      WAKEMASKSET1;     /* 0x0054       */
    uint32      WAKEMASKSET2;     /* 0x0058       */
    uint32      WAKEMASKSET3;     /* 0x005C       */
    uint32      WAKEMASKCLR0;     /* 0x0060       */
    uint32      WAKEMASKCLR1;     /* 0x0064       */
    uint32      WAKEMASKCLR2;     /* 0x0068       */
    uint32      WAKEMASKCLR3;     /* 0x006C       */
    uint32      IRQVECREG;        /* 0x0070       */
    uint32      FIQVECREG;        /* 0x0074       */
    uint32      CAPEVT;           /* 0x0078       */	
    uint32        rsvd3;          /* 0x007C       */
    uint32      CHANCTRL[32U];    /* 0x0080-0x0FC */
} vimBASE_t;

#define vimREG ((vimBASE_t *)0xFFFFFE00U)

/* USER CODE BEGIN (1) */
/* USER CODE END */


#endif