mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-27 12:23:53 -06:00

The timer controller include 8 sets of 32-bit decrement counters, based on either PCLK or 1MHZ clock and the design of timer controller between AST2600 and AST2700 are almost the same. TIMER0 – TIMER7 has their own individual control and interrupt status register. In other words, users are able to set timer control in register TMC10 with different TIMER base address and clear timer control and interrupt status in register TMC14 with different TIMER base address. Introduce new "aspeed_2700_timer_read" and "aspeed_2700_timer_write" callback functions and a new ast2700 class to support AST2700. 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 register address space of each TIMER is "0x40" , and uses the following formula to get the index and register of each TIMER. timer_index = offset >> 6; timer_offset = offset & 0x3f; The TMC010 is a counter control set and interrupt status register. Write "1" to TMC10[3:0] will set the specific bits to "1". Introduce a new "aspeed_2700_timer_set_ctrl" function to handle this register behavior. The TMC014 is a counter control clear and interrupt status register, to clear the specific bits to "0", it should write "1" to TMC14[3:0] on the same bit position. Introduce a new "aspeed_2700_timer_clear_ctrl" function to handle this register behavior. TMC014 does not support read operation. Signed-off-by: Jamin Lin <jamin_lin@aspeedtech.com> Acked-by: Cédric Le Goater <clg@redhat.com> Link: https://lore.kernel.org/r/20250113064455.1660564-3-jamin_lin@aspeedtech.com Signed-off-by: Cédric Le Goater <clg@redhat.com>
79 lines
2.2 KiB
C
79 lines
2.2 KiB
C
/*
|
|
* ASPEED AST2400 Timer
|
|
*
|
|
* Andrew Jeffery <andrew@aj.id.au>
|
|
*
|
|
* Copyright (C) 2016 IBM Corp.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*/
|
|
#ifndef ASPEED_TIMER_H
|
|
#define ASPEED_TIMER_H
|
|
|
|
#include "qemu/timer.h"
|
|
#include "hw/misc/aspeed_scu.h"
|
|
#include "qom/object.h"
|
|
|
|
#define TYPE_ASPEED_TIMER "aspeed.timer"
|
|
OBJECT_DECLARE_TYPE(AspeedTimerCtrlState, AspeedTimerClass, ASPEED_TIMER)
|
|
#define TYPE_ASPEED_2400_TIMER TYPE_ASPEED_TIMER "-ast2400"
|
|
#define TYPE_ASPEED_2500_TIMER TYPE_ASPEED_TIMER "-ast2500"
|
|
#define TYPE_ASPEED_2600_TIMER TYPE_ASPEED_TIMER "-ast2600"
|
|
#define TYPE_ASPEED_1030_TIMER TYPE_ASPEED_TIMER "-ast1030"
|
|
#define TYPE_ASPEED_2700_TIMER TYPE_ASPEED_TIMER "-ast2700"
|
|
|
|
#define ASPEED_TIMER_NR_TIMERS 8
|
|
|
|
typedef struct AspeedTimer {
|
|
qemu_irq irq;
|
|
|
|
uint8_t id;
|
|
QEMUTimer timer;
|
|
|
|
/**
|
|
* Track the line level as the ASPEED timers implement edge triggered
|
|
* interrupts, signalling with both the rising and falling edge.
|
|
*/
|
|
int32_t level;
|
|
uint32_t reload;
|
|
uint32_t match[2];
|
|
uint64_t start;
|
|
} AspeedTimer;
|
|
|
|
struct AspeedTimerCtrlState {
|
|
/*< private >*/
|
|
SysBusDevice parent;
|
|
|
|
/*< public >*/
|
|
MemoryRegion iomem;
|
|
|
|
uint32_t ctrl;
|
|
uint32_t ctrl2;
|
|
uint32_t ctrl3;
|
|
uint32_t irq_sts;
|
|
AspeedTimer timers[ASPEED_TIMER_NR_TIMERS];
|
|
|
|
AspeedSCUState *scu;
|
|
};
|
|
|
|
|
|
struct AspeedTimerClass {
|
|
SysBusDeviceClass parent_class;
|
|
|
|
uint64_t (*read)(AspeedTimerCtrlState *s, hwaddr offset);
|
|
void (*write)(AspeedTimerCtrlState *s, hwaddr offset, uint64_t value);
|
|
};
|
|
|
|
#endif /* ASPEED_TIMER_H */
|