xref: /qemu/include/hw/arm/exynos4210.h (revision caa75cc56e36b93553e19d74ab9e887cfd0ead20)
18e03cf1eSEvgeny Voevodin /*
28e03cf1eSEvgeny Voevodin  *  Samsung exynos4210 SoC emulation
38e03cf1eSEvgeny Voevodin  *
48e03cf1eSEvgeny Voevodin  *  Copyright (c) 2011 Samsung Electronics Co., Ltd. All rights reserved.
58e03cf1eSEvgeny Voevodin  *    Maksim Kozlov <m.kozlov@samsung.com>
68e03cf1eSEvgeny Voevodin  *    Evgeny Voevodin <e.voevodin@samsung.com>
78e03cf1eSEvgeny Voevodin  *    Igor Mitsyanko <i.mitsyanko@samsung.com>
88e03cf1eSEvgeny Voevodin  *
98e03cf1eSEvgeny Voevodin  *
108e03cf1eSEvgeny Voevodin  *  This program is free software; you can redistribute it and/or modify it
118e03cf1eSEvgeny Voevodin  *  under the terms of the GNU General Public License as published by the
128e03cf1eSEvgeny Voevodin  *  Free Software Foundation; either version 2 of the License, or
138e03cf1eSEvgeny Voevodin  *  (at your option) any later version.
148e03cf1eSEvgeny Voevodin  *
158e03cf1eSEvgeny Voevodin  *  This program is distributed in the hope that it will be useful, but WITHOUT
168e03cf1eSEvgeny Voevodin  *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
178e03cf1eSEvgeny Voevodin  *  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
188e03cf1eSEvgeny Voevodin  *  for more details.
198e03cf1eSEvgeny Voevodin  *
208e03cf1eSEvgeny Voevodin  *  You should have received a copy of the GNU General Public License along
218e03cf1eSEvgeny Voevodin  *  with this program; if not, see <http://www.gnu.org/licenses/>.
228e03cf1eSEvgeny Voevodin  */
238e03cf1eSEvgeny Voevodin 
242a6a4076SMarkus Armbruster #ifndef EXYNOS4210_H
252a6a4076SMarkus Armbruster #define EXYNOS4210_H
268e03cf1eSEvgeny Voevodin 
27dab15fbeSGuenter Roeck #include "hw/or-irq.h"
28ec150c7eSMarkus Armbruster #include "hw/sysbus.h"
295b241728SPeter Maydell #include "hw/cpu/a9mpcore.h"
3078cb12a9SPeter Maydell #include "hw/intc/exynos4210_gic.h"
31cebef07dSPeter Maydell #include "hw/intc/exynos4210_combiner.h"
327582d930SPeter Maydell #include "hw/core/split-irq.h"
33*85c90d45SPhilippe Mathieu-Daudé #include "hw/arm/boot.h"
34db1015e9SEduardo Habkost #include "qom/object.h"
358e03cf1eSEvgeny Voevodin 
368e03cf1eSEvgeny Voevodin #define EXYNOS4210_NCPUS                    2
378e03cf1eSEvgeny Voevodin 
380caa7113SEvgeny Voevodin #define EXYNOS4210_DRAM0_BASE_ADDR          0x40000000
390caa7113SEvgeny Voevodin #define EXYNOS4210_DRAM1_BASE_ADDR          0xa0000000
400caa7113SEvgeny Voevodin #define EXYNOS4210_DRAM_MAX_SIZE            0x60000000  /* 1.5 GB */
410caa7113SEvgeny Voevodin 
420caa7113SEvgeny Voevodin #define EXYNOS4210_IROM_BASE_ADDR           0x00000000
430caa7113SEvgeny Voevodin #define EXYNOS4210_IROM_SIZE                0x00010000  /* 64 KB */
440caa7113SEvgeny Voevodin #define EXYNOS4210_IROM_MIRROR_BASE_ADDR    0x02000000
450caa7113SEvgeny Voevodin #define EXYNOS4210_IROM_MIRROR_SIZE         0x00010000  /* 64 KB */
460caa7113SEvgeny Voevodin 
470caa7113SEvgeny Voevodin #define EXYNOS4210_IRAM_BASE_ADDR           0x02020000
480caa7113SEvgeny Voevodin #define EXYNOS4210_IRAM_SIZE                0x00020000  /* 128 KB */
490caa7113SEvgeny Voevodin 
500caa7113SEvgeny Voevodin /* Secondary CPU startup code is in IROM memory */
510caa7113SEvgeny Voevodin #define EXYNOS4210_SMP_BOOT_ADDR            EXYNOS4210_IROM_BASE_ADDR
520caa7113SEvgeny Voevodin #define EXYNOS4210_SMP_BOOT_SIZE            0x1000
530caa7113SEvgeny Voevodin #define EXYNOS4210_BASE_BOOT_ADDR           EXYNOS4210_DRAM0_BASE_ADDR
540caa7113SEvgeny Voevodin /* Secondary CPU polling address to get loader start from */
550caa7113SEvgeny Voevodin #define EXYNOS4210_SECOND_CPU_BOOTREG       0x10020814
560caa7113SEvgeny Voevodin 
570caa7113SEvgeny Voevodin #define EXYNOS4210_SMP_PRIVATE_BASE_ADDR    0x10500000
580caa7113SEvgeny Voevodin #define EXYNOS4210_L2X0_BASE_ADDR           0x10502000
590caa7113SEvgeny Voevodin 
608e03cf1eSEvgeny Voevodin /*
618e03cf1eSEvgeny Voevodin  * exynos4210 IRQ subsystem stub definitions.
628e03cf1eSEvgeny Voevodin  */
6361558e7aSEvgeny Voevodin #define EXYNOS4210_IRQ_GATE_NINPUTS 2 /* Internal and External GIC */
648e03cf1eSEvgeny Voevodin 
658e03cf1eSEvgeny Voevodin #define EXYNOS4210_MAX_INT_COMBINER_OUT_IRQ  64
668e03cf1eSEvgeny Voevodin #define EXYNOS4210_MAX_EXT_COMBINER_OUT_IRQ  16
678e03cf1eSEvgeny Voevodin #define EXYNOS4210_MAX_INT_COMBINER_IN_IRQ   \
688e03cf1eSEvgeny Voevodin     (EXYNOS4210_MAX_INT_COMBINER_OUT_IRQ * 8)
698e03cf1eSEvgeny Voevodin #define EXYNOS4210_MAX_EXT_COMBINER_IN_IRQ   \
708e03cf1eSEvgeny Voevodin     (EXYNOS4210_MAX_EXT_COMBINER_OUT_IRQ * 8)
718e03cf1eSEvgeny Voevodin 
72ffbbe7d0SMitsyanko Igor #define EXYNOS4210_I2C_NUMBER               9
73ffbbe7d0SMitsyanko Igor 
74dab15fbeSGuenter Roeck #define EXYNOS4210_NUM_DMA      3
75dab15fbeSGuenter Roeck 
767582d930SPeter Maydell /*
777582d930SPeter Maydell  * We need one splitter for every external combiner input, plus
7876621953SPeter Maydell  * one for every non-zero entry in combiner_grp_to_gic_id[],
7976621953SPeter Maydell  * minus one for every external combiner ID in second or later
8076621953SPeter Maydell  * places in a combinermap[] line.
817582d930SPeter Maydell  * We'll assert in exynos4210_init_board_irqs() if this is wrong.
827582d930SPeter Maydell  */
8376621953SPeter Maydell #define EXYNOS4210_NUM_SPLITTERS (EXYNOS4210_MAX_EXT_COMBINER_IN_IRQ + 38)
847582d930SPeter Maydell 
85db1015e9SEduardo Habkost struct Exynos4210State {
8698e4f4fdSPhilippe Mathieu-Daudé     /*< private >*/
8798e4f4fdSPhilippe Mathieu-Daudé     SysBusDevice parent_obj;
8898e4f4fdSPhilippe Mathieu-Daudé     /*< public >*/
89ef6cbcc5SAndreas Färber     ARMCPU *cpu[EXYNOS4210_NCPUS];
90771dee52SPeter Maydell     qemu_irq irq_table[EXYNOS4210_MAX_INT_COMBINER_IN_IRQ];
910caa7113SEvgeny Voevodin 
920caa7113SEvgeny Voevodin     MemoryRegion chipid_mem;
930caa7113SEvgeny Voevodin     MemoryRegion iram_mem;
940caa7113SEvgeny Voevodin     MemoryRegion irom_mem;
950caa7113SEvgeny Voevodin     MemoryRegion irom_alias_mem;
960caa7113SEvgeny Voevodin     MemoryRegion boot_secondary;
970caa7113SEvgeny Voevodin     MemoryRegion bootreg_mem;
98a5c82852SAndreas Färber     I2CBus *i2c_if[EXYNOS4210_I2C_NUMBER];
99e844f0c5SPhilippe Mathieu-Daudé     OrIRQState pl330_irq_orgate[EXYNOS4210_NUM_DMA];
100e844f0c5SPhilippe Mathieu-Daudé     OrIRQState cpu_irq_orgate[EXYNOS4210_NCPUS];
1015b241728SPeter Maydell     A9MPPrivState a9mpcore;
10278cb12a9SPeter Maydell     Exynos4210GicState ext_gic;
103cebef07dSPeter Maydell     Exynos4210CombinerState int_combiner;
104cebef07dSPeter Maydell     Exynos4210CombinerState ext_combiner;
1057582d930SPeter Maydell     SplitIRQ splitter[EXYNOS4210_NUM_SPLITTERS];
106db1015e9SEduardo Habkost };
1070caa7113SEvgeny Voevodin 
10898e4f4fdSPhilippe Mathieu-Daudé #define TYPE_EXYNOS4210_SOC "exynos4210"
1098063396bSEduardo Habkost OBJECT_DECLARE_SIMPLE_TYPE(Exynos4210State, EXYNOS4210_SOC)
11098e4f4fdSPhilippe Mathieu-Daudé 
1119543b0cdSAndreas Färber void exynos4210_write_secondary(ARMCPU *cpu,
1123f088e36SEvgeny Voevodin         const struct arm_boot_info *info);
1133f088e36SEvgeny Voevodin 
1148e03cf1eSEvgeny Voevodin /* Get IRQ number from exynos4210 IRQ subsystem stub.
1158e03cf1eSEvgeny Voevodin  * To identify IRQ source use internal combiner group and bit number
1168e03cf1eSEvgeny Voevodin  *  grp - group number
1178e03cf1eSEvgeny Voevodin  *  bit - bit number inside group */
1188e03cf1eSEvgeny Voevodin uint32_t exynos4210_get_irq(uint32_t grp, uint32_t bit);
1198e03cf1eSEvgeny Voevodin 
1208e03cf1eSEvgeny Voevodin /*
121e5a4914eSMaksim Kozlov  * exynos4210 UART
122e5a4914eSMaksim Kozlov  */
123a8170e5eSAvi Kivity DeviceState *exynos4210_uart_create(hwaddr addr,
124e5a4914eSMaksim Kozlov                                     int fifo_size,
125e5a4914eSMaksim Kozlov                                     int channel,
1260ec7b3e7SMarc-André Lureau                                     Chardev *chr,
127e5a4914eSMaksim Kozlov                                     qemu_irq irq);
128e5a4914eSMaksim Kozlov 
1292a6a4076SMarkus Armbruster #endif /* EXYNOS4210_H */
130