[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 06/11] hw/arm/aspeed: Introduce TYPE_ASPEED2600_SOC
From: |
Philippe Mathieu-Daudé |
Subject: |
[PATCH 06/11] hw/arm/aspeed: Introduce TYPE_ASPEED2600_SOC |
Date: |
Tue, 24 Oct 2023 18:24:17 +0200 |
TYPE_ASPEED2600_SOC inherits from TYPE_ASPEED_SOC.
In few commits we'll add more fields, but to keep
review process simple, don't add any yet.
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
---
include/hw/arm/aspeed_soc.h | 7 +++++++
hw/arm/aspeed_ast2600.c | 26 +++++++++++++-------------
2 files changed, 20 insertions(+), 13 deletions(-)
diff --git a/include/hw/arm/aspeed_soc.h b/include/hw/arm/aspeed_soc.h
index dcb43a4ecd..103b1598f6 100644
--- a/include/hw/arm/aspeed_soc.h
+++ b/include/hw/arm/aspeed_soc.h
@@ -101,6 +101,13 @@ struct AspeedSoCState {
#define TYPE_ASPEED_SOC "aspeed-soc"
OBJECT_DECLARE_TYPE(AspeedSoCState, AspeedSoCClass, ASPEED_SOC)
+struct Aspeed2600SoCState {
+ AspeedSoCState parent;
+};
+
+#define TYPE_ASPEED2600_SOC "aspeed2600-soc"
+OBJECT_DECLARE_SIMPLE_TYPE(Aspeed2600SoCState, ASPEED2600_SOC)
+
struct Aspeed10x0SoCState {
AspeedSoCState parent;
};
diff --git a/hw/arm/aspeed_ast2600.c b/hw/arm/aspeed_ast2600.c
index e122e1c32d..1ee460e56c 100644
--- a/hw/arm/aspeed_ast2600.c
+++ b/hw/arm/aspeed_ast2600.c
@@ -646,18 +646,18 @@ static void aspeed_soc_ast2600_class_init(ObjectClass
*oc, void *data)
sc->get_irq = aspeed_soc_ast2600_get_irq;
}
-static const TypeInfo aspeed_soc_ast2600_type_info = {
- .name = "ast2600-a3",
- .parent = TYPE_ASPEED_SOC,
- .instance_size = sizeof(AspeedSoCState),
- .instance_init = aspeed_soc_ast2600_init,
- .class_init = aspeed_soc_ast2600_class_init,
- .class_size = sizeof(AspeedSoCClass),
+static const TypeInfo aspeed_soc_ast2600_types[] = {
+ {
+ .name = TYPE_ASPEED2600_SOC,
+ .parent = TYPE_ASPEED_SOC,
+ .instance_size = sizeof(Aspeed2600SoCState),
+ .abstract = true,
+ }, {
+ .name = "ast2600-a3",
+ .parent = TYPE_ASPEED2600_SOC,
+ .instance_init = aspeed_soc_ast2600_init,
+ .class_init = aspeed_soc_ast2600_class_init,
+ },
};
-static void aspeed_soc_register_types(void)
-{
- type_register_static(&aspeed_soc_ast2600_type_info);
-};
-
-type_init(aspeed_soc_register_types)
+DEFINE_TYPES(aspeed_soc_ast2600_types)
--
2.41.0
- [PATCH 01/11] hw/arm/aspeed: Extract code common to all boards to a common file, (continued)
- [PATCH 01/11] hw/arm/aspeed: Extract code common to all boards to a common file, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 02/11] hw/arm/aspeed: Rename aspeed_soc_init() as AST2400/2500 specific, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 03/11] hw/arm/aspeed: Rename aspeed_soc_realize() as AST2400/2500 specific, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 04/11] hw/arm/aspeed: Dynamically allocate AspeedMachineState::soc field, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 05/11] hw/arm/aspeed: Introduce TYPE_ASPEED10X0_SOC, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 06/11] hw/arm/aspeed: Introduce TYPE_ASPEED2600_SOC,
Philippe Mathieu-Daudé <=
- [PATCH 08/11] hw/arm/aspeed: Check 'memory' link is set in common aspeed_soc_realize, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 10/11] hw/arm/aspeed: Move AspeedSoCState::a7mpcore to Aspeed2600SoCState, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 07/11] hw/arm/aspeed: Introduce TYPE_ASPEED2400_SOC, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 09/11] hw/arm/aspeed: Move AspeedSoCState::armv7m to Aspeed10x0SoCState, Philippe Mathieu-Daudé, 2023/10/24
- [PATCH 11/11] hw/arm/aspeed: Move AspeedSoCState::cpu/vic to Aspeed2400SoCState, Philippe Mathieu-Daudé, 2023/10/24