1 /******************************************************************************
2  *
3  * Copyright (C) 2022-2023 Maxim Integrated Products, Inc. (now owned by
4  * Analog Devices, Inc.),
5  * Copyright (C) 2023-2024 Analog Devices, Inc.
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *     http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  ******************************************************************************/
20 
21 #include "emcc_reva.h"
22 
23 #if TARGET_NUM != 32650
24 #include "emcc.h"
MXC_EMCC_RevA_ID(mxc_emcc_reva_regs_t * emcc,mxc_emcc_info_t id)25 uint32_t MXC_EMCC_RevA_ID(mxc_emcc_reva_regs_t *emcc, mxc_emcc_info_t id)
26 {
27     switch (id) {
28     case EMCC_INFO_RELNUM:
29         return (((emcc->info) & MXC_F_EMCC_REVA_INFO_RELNUM)) >> MXC_F_EMCC_REVA_INFO_RELNUM_POS;
30 
31     case EMCC_INFO_PARTNUM:
32         return (((emcc->info) & MXC_F_EMCC_REVA_INFO_PARTNUM)) >> MXC_F_EMCC_REVA_INFO_PARTNUM_POS;
33 
34     case EMCC_INFO_ID:
35     default:
36         return (((emcc->info) & MXC_F_EMCC_REVA_INFO_ID)) >> MXC_F_EMCC_REVA_INFO_ID_POS;
37     }
38 }
39 #endif
40 
MXC_EMCC_RevA_CacheSize(mxc_emcc_reva_regs_t * emcc)41 uint32_t MXC_EMCC_RevA_CacheSize(mxc_emcc_reva_regs_t *emcc)
42 {
43     return (((emcc->sz) & MXC_F_EMCC_REVA_SZ_CCH)) >> MXC_F_EMCC_REVA_SZ_CCH_POS;
44 }
45 
MXC_EMCC_RevA_MemSize(mxc_emcc_reva_regs_t * emcc)46 uint32_t MXC_EMCC_RevA_MemSize(mxc_emcc_reva_regs_t *emcc)
47 {
48     return (emcc->sz & MXC_F_EMCC_REVA_SZ_MEM) >> MXC_F_EMCC_REVA_SZ_MEM_POS;
49 }
50 
MXC_EMCC_RevA_Enable(mxc_emcc_reva_regs_t * emcc)51 void MXC_EMCC_RevA_Enable(mxc_emcc_reva_regs_t *emcc)
52 {
53     emcc->ctrl |= MXC_F_EMCC_REVA_CTRL_EN;
54 }
55 
MXC_EMCC_RevA_Disable(mxc_emcc_reva_regs_t * emcc)56 void MXC_EMCC_RevA_Disable(mxc_emcc_reva_regs_t *emcc)
57 {
58     emcc->ctrl &= ~MXC_F_EMCC_REVA_CTRL_EN;
59 }
60 
MXC_EMCC_RevA_WriteAllocateEnable(mxc_emcc_reva_regs_t * emcc)61 void MXC_EMCC_RevA_WriteAllocateEnable(mxc_emcc_reva_regs_t *emcc)
62 {
63     emcc->ctrl |= MXC_F_EMCC_REVA_CTRL_WRITE_ALLOC;
64 }
65 
MXC_EMCC_RevA_WriteAllocateDisable(mxc_emcc_reva_regs_t * emcc)66 void MXC_EMCC_RevA_WriteAllocateDisable(mxc_emcc_reva_regs_t *emcc)
67 {
68     emcc->ctrl &= ~MXC_F_EMCC_REVA_CTRL_WRITE_ALLOC;
69 }
70 
MXC_EMCC_RevA_CriticalWordFirstEnable(mxc_emcc_reva_regs_t * emcc)71 void MXC_EMCC_RevA_CriticalWordFirstEnable(mxc_emcc_reva_regs_t *emcc) //cwfst_dis
72 {
73     emcc->ctrl |= MXC_F_EMCC_REVA_CTRL_CWFST_DIS;
74 }
75 
MXC_EMCC_RevA_CriticalWordFirstDisable(mxc_emcc_reva_regs_t * emcc)76 void MXC_EMCC_RevA_CriticalWordFirstDisable(mxc_emcc_reva_regs_t *emcc) //cwfst_dis
77 {
78     emcc->ctrl &= ~MXC_F_EMCC_REVA_CTRL_CWFST_DIS;
79 }
80 
MXC_EMCC_RevA_Ready(mxc_emcc_reva_regs_t * emcc)81 uint32_t MXC_EMCC_RevA_Ready(mxc_emcc_reva_regs_t *emcc)
82 {
83     return (emcc->ctrl & MXC_F_EMCC_REVA_CTRL_RDY) >> MXC_F_EMCC_REVA_CTRL_RDY_POS;
84 }
85