[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 06/12] aspeed/soc: Support Timer for AST2700
From: |
Cédric Le Goater |
Subject: |
[PULL 06/12] aspeed/soc: Support Timer for AST2700 |
Date: |
Mon, 27 Jan 2025 10:42:33 +0100 |
From: Jamin Lin <jamin_lin@aspeedtech.com>
Add Timer model for AST2700 Timer support. The Timer controller include 8 sets
of 32-bit decrement counters.
The base address of TIMER0 to TIMER7 as following.
Base Address of Timer 0 = 0x12C1_0000
Base Address of Timer 1 = 0x12C1_0040
Base Address of Timer 2 = 0x12C1_0080
Base Address of Timer 3 = 0x12C1_00C0
Base Address of Timer 4 = 0x12C1_0100
Base Address of Timer 5 = 0x12C1_0140
Base Address of Timer 6 = 0x12C1_0180
Base Address of Timer 7 = 0x12C1_01C0
The interrupt of TIMER0 to TIMER7 as following.
GICINT16 = TIMER 0 interrupt
GICINT17 = TIMER 1 interrupt
GICINT18 = TIMER 2 interrupt
GICINT19 = TIMER 3 interrupt
GICINT20 = TIMER 4 interrupt
GICINT21 = TIMER 5 interrupt
GICINT22 = TIMER 6 interrupt
GICINT23 = TIMER 7 interrupt
Signed-off-by: Jamin Lin <jamin_lin@aspeedtech.com>
Reviewed-by: Cédric Le Goater <clg@redhat.com>
Link:
20250113064455.1660564-4-jamin_lin@aspeedtech.com">https://lore.kernel.org/r/20250113064455.1660564-4-jamin_lin@aspeedtech.com
Signed-off-by: Cédric Le Goater <clg@redhat.com>
---
hw/arm/aspeed_ast27x0.c | 17 +++++++++++++++++
1 file changed, 17 insertions(+)
diff --git a/hw/arm/aspeed_ast27x0.c b/hw/arm/aspeed_ast27x0.c
index fee37558372a..4114e15dddf4 100644
--- a/hw/arm/aspeed_ast27x0.c
+++ b/hw/arm/aspeed_ast27x0.c
@@ -66,6 +66,7 @@ static const hwaddr aspeed_soc_ast2700_memmap[] = {
[ASPEED_DEV_GPIO] = 0x14C0B000,
[ASPEED_DEV_RTC] = 0x12C0F000,
[ASPEED_DEV_SDHCI] = 0x14080000,
+ [ASPEED_DEV_TIMER1] = 0x12C10000,
};
#define AST2700_MAX_IRQ 256
@@ -397,6 +398,9 @@ static void aspeed_soc_ast2700_init(Object *obj)
object_initialize_child(obj, "emmc-controller.sdhci", &s->emmc.slots[0],
TYPE_SYSBUS_SDHCI);
+
+ snprintf(typename, sizeof(typename), "aspeed.timer-%s", socname);
+ object_initialize_child(obj, "timerctrl", &s->timerctrl, typename);
}
/*
@@ -716,6 +720,19 @@ static void aspeed_soc_ast2700_realize(DeviceState *dev,
Error **errp)
sysbus_connect_irq(SYS_BUS_DEVICE(&s->emmc), 0,
aspeed_soc_get_irq(s, ASPEED_DEV_EMMC));
+ /* Timer */
+ object_property_set_link(OBJECT(&s->timerctrl), "scu", OBJECT(&s->scu),
+ &error_abort);
+ if (!sysbus_realize(SYS_BUS_DEVICE(&s->timerctrl), errp)) {
+ return;
+ }
+ aspeed_mmio_map(s, SYS_BUS_DEVICE(&s->timerctrl), 0,
+ sc->memmap[ASPEED_DEV_TIMER1]);
+ for (i = 0; i < ASPEED_TIMER_NR_TIMERS; i++) {
+ irq = aspeed_soc_get_irq(s, ASPEED_DEV_TIMER1 + i);
+ sysbus_connect_irq(SYS_BUS_DEVICE(&s->timerctrl), i, irq);
+ }
+
create_unimplemented_device("ast2700.dpmcu", 0x11000000, 0x40000);
create_unimplemented_device("ast2700.iomem0", 0x12000000, 0x01000000);
create_unimplemented_device("ast2700.iomem1", 0x14000000, 0x01000000);
--
2.48.1
- [PULL 00/12] aspeed queue, Cédric Le Goater, 2025/01/27
- [PULL 01/12] hw/arm/aspeed: fix connect_serial_hds_to_uarts, Cédric Le Goater, 2025/01/27
- [PULL 02/12] hw/sd/sdhci: Introduce a new Write Protected pin inverted property, Cédric Le Goater, 2025/01/27
- [PULL 03/12] hw/arm/aspeed: Invert sdhci write protected pin for AST2600 EVB, Cédric Le Goater, 2025/01/27
- [PULL 04/12] hw/timer/aspeed: Refactor Timer Callbacks for SoC-Specific Implementations, Cédric Le Goater, 2025/01/27
- [PULL 06/12] aspeed/soc: Support Timer for AST2700,
Cédric Le Goater <=
- [PULL 07/12] test/functional: Update the Aspeed aarch64 test, Cédric Le Goater, 2025/01/27
- [PULL 05/12] hw/timer/aspeed: Add AST2700 Support, Cédric Le Goater, 2025/01/27
- [PULL 10/12] aspeed/wdt: Fix coding style, Cédric Le Goater, 2025/01/27
- [PULL 08/12] test/functional: Update buildroot images to 2024.11, Cédric Le Goater, 2025/01/27
- [PULL 11/12] aspeed/wdt: Support software reset mode for AST2600, Cédric Le Goater, 2025/01/27
- [PULL 09/12] aspeed: Create sd devices only when defaults are enabled, Cédric Le Goater, 2025/01/27
- [PULL 12/12] docs/system/arm/aspeed: Remove tacoma-bmc from the documentation, Cédric Le Goater, 2025/01/27
- Re: [PULL 00/12] aspeed queue, Stefan Hajnoczi, 2025/01/27