xref: /openbmc/qemu/include/hw/misc/stm32_rcc.h (revision d1613f2a)
1*d1613f2aSRomán Cárdenas Rodríguez /*
2*d1613f2aSRomán Cárdenas Rodríguez  * STM32 RCC (only reset and enable registers are implemented)
3*d1613f2aSRomán Cárdenas Rodríguez  *
4*d1613f2aSRomán Cárdenas Rodríguez  * Copyright (c) 2024 Román Cárdenas <rcardenas.rod@gmail.com>
5*d1613f2aSRomán Cárdenas Rodríguez  *
6*d1613f2aSRomán Cárdenas Rodríguez  * Permission is hereby granted, free of charge, to any person obtaining a copy
7*d1613f2aSRomán Cárdenas Rodríguez  * of this software and associated documentation files (the "Software"), to deal
8*d1613f2aSRomán Cárdenas Rodríguez  * in the Software without restriction, including without limitation the rights
9*d1613f2aSRomán Cárdenas Rodríguez  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10*d1613f2aSRomán Cárdenas Rodríguez  * copies of the Software, and to permit persons to whom the Software is
11*d1613f2aSRomán Cárdenas Rodríguez  * furnished to do so, subject to the following conditions:
12*d1613f2aSRomán Cárdenas Rodríguez  *
13*d1613f2aSRomán Cárdenas Rodríguez  * The above copyright notice and this permission notice shall be included in
14*d1613f2aSRomán Cárdenas Rodríguez  * all copies or substantial portions of the Software.
15*d1613f2aSRomán Cárdenas Rodríguez  *
16*d1613f2aSRomán Cárdenas Rodríguez  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*d1613f2aSRomán Cárdenas Rodríguez  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*d1613f2aSRomán Cárdenas Rodríguez  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19*d1613f2aSRomán Cárdenas Rodríguez  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*d1613f2aSRomán Cárdenas Rodríguez  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21*d1613f2aSRomán Cárdenas Rodríguez  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22*d1613f2aSRomán Cárdenas Rodríguez  * THE SOFTWARE.
23*d1613f2aSRomán Cárdenas Rodríguez  */
24*d1613f2aSRomán Cárdenas Rodríguez 
25*d1613f2aSRomán Cárdenas Rodríguez #ifndef HW_STM32_RCC_H
26*d1613f2aSRomán Cárdenas Rodríguez #define HW_STM32_RCC_H
27*d1613f2aSRomán Cárdenas Rodríguez 
28*d1613f2aSRomán Cárdenas Rodríguez #include "hw/sysbus.h"
29*d1613f2aSRomán Cárdenas Rodríguez #include "qom/object.h"
30*d1613f2aSRomán Cárdenas Rodríguez 
31*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_CR 0x00
32*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_PLL_CFGR 0x04
33*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_CFGR 0x08
34*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_CIR 0x0C
35*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB1_RSTR 0x10
36*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB2_RSTR 0x14
37*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB3_RSTR 0x18
38*d1613f2aSRomán Cárdenas Rodríguez 
39*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_APB1_RSTR 0x20
40*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_APB2_RSTR 0x24
41*d1613f2aSRomán Cárdenas Rodríguez 
42*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB1_ENR 0x30
43*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB2_ENR 0x34
44*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB3_ENR 0x38
45*d1613f2aSRomán Cárdenas Rodríguez 
46*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_APB1_ENR 0x40
47*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_APB2_ENR 0x44
48*d1613f2aSRomán Cárdenas Rodríguez 
49*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB1_LPENR 0x50
50*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB2_LPENR 0x54
51*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_AHB3_LPENR 0x58
52*d1613f2aSRomán Cárdenas Rodríguez 
53*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_APB1_LPENR 0x60
54*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_APB2_LPENR 0x64
55*d1613f2aSRomán Cárdenas Rodríguez 
56*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_BDCR 0x70
57*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_CSR 0x74
58*d1613f2aSRomán Cárdenas Rodríguez 
59*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_SSCGR 0x80
60*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_PLLI2SCFGR 0x84
61*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_PLLSAI_CFGR 0x88
62*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_DCKCFGR 0x8C
63*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_CKGATENR 0x90
64*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_DCKCFGR2 0x94
65*d1613f2aSRomán Cárdenas Rodríguez 
66*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_NREGS ((STM32_RCC_DCKCFGR2 >> 2) + 1)
67*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_PERIPHERAL_SIZE 0x400
68*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_NIRQS (32 * 5) /* 32 bits per reg, 5 en/rst regs */
69*d1613f2aSRomán Cárdenas Rodríguez 
70*d1613f2aSRomán Cárdenas Rodríguez #define STM32_RCC_GPIO_IRQ_OFFSET 0
71*d1613f2aSRomán Cárdenas Rodríguez 
72*d1613f2aSRomán Cárdenas Rodríguez #define TYPE_STM32_RCC "stm32.rcc"
73*d1613f2aSRomán Cárdenas Rodríguez 
74*d1613f2aSRomán Cárdenas Rodríguez typedef struct STM32RccState STM32RccState;
75*d1613f2aSRomán Cárdenas Rodríguez 
76*d1613f2aSRomán Cárdenas Rodríguez DECLARE_INSTANCE_CHECKER(STM32RccState, STM32_RCC, TYPE_STM32_RCC)
77*d1613f2aSRomán Cárdenas Rodríguez 
78*d1613f2aSRomán Cárdenas Rodríguez #define NUM_GPIO_EVENT_IN_LINES 16
79*d1613f2aSRomán Cárdenas Rodríguez 
80*d1613f2aSRomán Cárdenas Rodríguez struct STM32RccState {
81*d1613f2aSRomán Cárdenas Rodríguez     SysBusDevice parent_obj;
82*d1613f2aSRomán Cárdenas Rodríguez 
83*d1613f2aSRomán Cárdenas Rodríguez     MemoryRegion mmio;
84*d1613f2aSRomán Cárdenas Rodríguez 
85*d1613f2aSRomán Cárdenas Rodríguez     uint32_t regs[STM32_RCC_NREGS];
86*d1613f2aSRomán Cárdenas Rodríguez 
87*d1613f2aSRomán Cárdenas Rodríguez     qemu_irq enable_irq[STM32_RCC_NIRQS];
88*d1613f2aSRomán Cárdenas Rodríguez     qemu_irq reset_irq[STM32_RCC_NIRQS];
89*d1613f2aSRomán Cárdenas Rodríguez };
90*d1613f2aSRomán Cárdenas Rodríguez 
91*d1613f2aSRomán Cárdenas Rodríguez #endif /* HW_STM32_RCC_H */
92