soc/mediatek/mt8195: Add timer support
TEST=emerge-{oak, kukui, asurada, cherry} coreboot; verified on Asurada and Cherry P0 Signed-off-by: Yidi Lin <yidi.lin@mediatek.com> Change-Id: Ic6a87e7d5983bf14ad123de82ed670a22a7be1aa Reviewed-on: https://review.coreboot.org/c/coreboot/+/52541 Reviewed-by: Hung-Te Lin <hungte@chromium.org> Reviewed-by: Yu-Ping Wu <yupingso@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
49b47eab81
commit
03e002f64d
12 changed files with 158 additions and 48 deletions
|
@ -1,40 +0,0 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_COMMON_TIMER_H
|
||||
#define SOC_MEDIATEK_COMMON_TIMER_H
|
||||
|
||||
#include <soc/addressmap.h>
|
||||
#include <types.h>
|
||||
|
||||
#define GPT_MHZ 13
|
||||
|
||||
struct mtk_gpt_regs {
|
||||
u32 reserved1[24];
|
||||
u32 gpt6_con;
|
||||
u32 gpt6_clk;
|
||||
u32 gpt6_cnt_l;
|
||||
u32 reserved2[3];
|
||||
u32 gpt6_cnt_h;
|
||||
};
|
||||
|
||||
check_member(mtk_gpt_regs, gpt6_con, 0x0060);
|
||||
check_member(mtk_gpt_regs, gpt6_clk, 0x0064);
|
||||
check_member(mtk_gpt_regs, gpt6_cnt_l, 0x0068);
|
||||
check_member(mtk_gpt_regs, gpt6_cnt_h, 0x0078);
|
||||
|
||||
enum {
|
||||
GPT_CON_EN = 0x01,
|
||||
GPT_CON_CLR = 0x02,
|
||||
GPT_MODE_FREERUN = 0x30,
|
||||
GPT_SYS_CLK = 0x00,
|
||||
GPT_CLK_DIV1 = 0x00,
|
||||
};
|
||||
|
||||
/*
|
||||
* This is defined as weak no-ops that can be overridden by legacy SOCs. Some
|
||||
* legacy SOCs need specific settings before init timer. And we expect future
|
||||
* SOCs will not need it.
|
||||
*/
|
||||
void timer_prepare(void);
|
||||
|
||||
#endif
|
23
src/soc/mediatek/common/include/soc/timer_common.h
Normal file
23
src/soc/mediatek/common/include/soc/timer_common.h
Normal file
|
@ -0,0 +1,23 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_COMMON_TIMER_COMMON_H
|
||||
#define SOC_MEDIATEK_COMMON_TIMER_COMMON_H
|
||||
|
||||
#include <types.h>
|
||||
|
||||
enum {
|
||||
GPT6_CON_EN = BIT(0),
|
||||
GPT6_CON_CLR = BIT(1),
|
||||
GPT6_MODE_FREERUN = 3,
|
||||
GPT6_CLK_CLK6_SYS = 0,
|
||||
GPT6_CLK_CLKDIV_DIV1 = 0,
|
||||
};
|
||||
|
||||
/*
|
||||
* This is defined as weak no-ops that can be overridden by legacy SOCs. Some
|
||||
* legacy SOCs need specific settings before init timer. And we expect future
|
||||
* SOCs will not need it.
|
||||
*/
|
||||
void timer_prepare(void);
|
||||
|
||||
#endif
|
34
src/soc/mediatek/common/include/soc/timer_v1.h
Normal file
34
src/soc/mediatek/common/include/soc/timer_v1.h
Normal file
|
@ -0,0 +1,34 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_COMMON_TIMER_V1_H
|
||||
#define SOC_MEDIATEK_COMMON_TIMER_V1_H
|
||||
|
||||
#include <device/mmio.h>
|
||||
#include <soc/timer_common.h>
|
||||
#include <types.h>
|
||||
|
||||
#define GPT_MHZ 13
|
||||
|
||||
struct mtk_gpt_regs {
|
||||
u32 reserved1[24];
|
||||
u32 gpt6_con;
|
||||
u32 gpt6_clk;
|
||||
u32 gpt6_cnt_l;
|
||||
u32 reserved2[3];
|
||||
u32 gpt6_cnt_h;
|
||||
};
|
||||
|
||||
check_member(mtk_gpt_regs, gpt6_con, 0x0060);
|
||||
check_member(mtk_gpt_regs, gpt6_clk, 0x0064);
|
||||
check_member(mtk_gpt_regs, gpt6_cnt_l, 0x0068);
|
||||
check_member(mtk_gpt_regs, gpt6_cnt_h, 0x0078);
|
||||
|
||||
DEFINE_BIT(GPT6_CON_EN6, 0)
|
||||
DEFINE_BIT(GPT6_CON_CLR6, 1)
|
||||
DEFINE_BITFIELD(GPT6_CON_MODE6, 5, 4)
|
||||
|
||||
#define GPT6_CLOCK_REG(x) x->gpt6_clk
|
||||
DEFINE_BITFIELD(GPT6_CLK_CLKDIV6, 3, 0)
|
||||
DEFINE_BIT(GPT6_CLK_CLK6, 4)
|
||||
|
||||
#endif
|
33
src/soc/mediatek/common/include/soc/timer_v2.h
Normal file
33
src/soc/mediatek/common/include/soc/timer_v2.h
Normal file
|
@ -0,0 +1,33 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_COMMON_TIMER_V2_H
|
||||
#define SOC_MEDIATEK_COMMON_TIMER_V2_H
|
||||
|
||||
#include <device/mmio.h>
|
||||
#include <soc/timer_common.h>
|
||||
#include <types.h>
|
||||
|
||||
#define GPT_MHZ 13
|
||||
|
||||
struct mtk_gpt_regs {
|
||||
u32 reserved1[40];
|
||||
u32 gpt6_con;
|
||||
u32 reserved2;
|
||||
u32 gpt6_cnt_l;
|
||||
u32 reserved3;
|
||||
u32 gpt6_cnt_h;
|
||||
};
|
||||
|
||||
check_member(mtk_gpt_regs, gpt6_con, 0x00A0);
|
||||
check_member(mtk_gpt_regs, gpt6_cnt_l, 0x00A8);
|
||||
check_member(mtk_gpt_regs, gpt6_cnt_h, 0x00B0);
|
||||
|
||||
DEFINE_BIT(GPT6_CON_EN6, 0)
|
||||
DEFINE_BIT(GPT6_CON_CLR6, 1)
|
||||
DEFINE_BITFIELD(GPT6_CON_MODE6, 6, 5)
|
||||
|
||||
#define GPT6_CLOCK_REG(x) x->gpt6_con
|
||||
DEFINE_BITFIELD(GPT6_CLK_CLKDIV6, 3, 0)
|
||||
DEFINE_BITFIELD(GPT6_CLK_CLK6, 13, 10)
|
||||
|
||||
#endif
|
|
@ -35,11 +35,15 @@ void init_timer(void)
|
|||
timer_prepare();
|
||||
|
||||
/* Disable timer and clear the counter */
|
||||
clrbits32(&mtk_gpt->gpt6_con, GPT_CON_EN);
|
||||
setbits32(&mtk_gpt->gpt6_con, GPT_CON_CLR);
|
||||
clrbits32(&mtk_gpt->gpt6_con, GPT6_CON_EN);
|
||||
setbits32(&mtk_gpt->gpt6_con, GPT6_CON_CLR);
|
||||
|
||||
/* Set clock source to system clock and set clock divider to 1 */
|
||||
write32(&mtk_gpt->gpt6_clk, GPT_SYS_CLK | GPT_CLK_DIV1);
|
||||
SET32_BITFIELDS(&GPT6_CLOCK_REG(mtk_gpt),
|
||||
GPT6_CLK_CLK6, GPT6_CLK_CLK6_SYS,
|
||||
GPT6_CLK_CLKDIV6, GPT6_CLK_CLKDIV_DIV1);
|
||||
/* Set operation mode to FREERUN mode and enable timer */
|
||||
write32(&mtk_gpt->gpt6_con, GPT_CON_EN | GPT_MODE_FREERUN);
|
||||
SET32_BITFIELDS(&mtk_gpt->gpt6_con,
|
||||
GPT6_CON_MODE6, GPT6_MODE_FREERUN,
|
||||
GPT6_CON_EN6, GPT6_CON_EN);
|
||||
}
|
||||
|
|
8
src/soc/mediatek/mt8173/include/soc/timer.h
Normal file
8
src/soc/mediatek/mt8173/include/soc/timer.h
Normal file
|
@ -0,0 +1,8 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_MT8173_TIMER_H
|
||||
#define SOC_MEDIATEK_MT8173_TIMER_H
|
||||
|
||||
#include <soc/timer_v1.h>
|
||||
|
||||
#endif
|
8
src/soc/mediatek/mt8183/include/soc/timer.h
Normal file
8
src/soc/mediatek/mt8183/include/soc/timer.h
Normal file
|
@ -0,0 +1,8 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_MT8183_TIMER_H
|
||||
#define SOC_MEDIATEK_MT8183_TIMER_H
|
||||
|
||||
#include <soc/timer_v1.h>
|
||||
|
||||
#endif
|
8
src/soc/mediatek/mt8192/include/soc/timer.h
Normal file
8
src/soc/mediatek/mt8192/include/soc/timer.h
Normal file
|
@ -0,0 +1,8 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_MT8192_TIMER_H
|
||||
#define SOC_MEDIATEK_MT8192_TIMER_H
|
||||
|
||||
#include <soc/timer_v1.h>
|
||||
|
||||
#endif
|
|
@ -3,26 +3,26 @@ ifeq ($(CONFIG_SOC_MEDIATEK_MT8195),y)
|
|||
bootblock-y += bootblock.c
|
||||
bootblock-y += ../common/mmu_operations.c
|
||||
bootblock-$(CONFIG_SPI_FLASH) += spi.c
|
||||
bootblock-y += ../common/timer.c
|
||||
bootblock-y += ../common/timer.c timer.c
|
||||
bootblock-y += ../common/uart.c
|
||||
bootblock-y += ../common/wdt.c
|
||||
|
||||
verstage-$(CONFIG_SPI_FLASH) += spi.c
|
||||
verstage-y += ../common/timer.c
|
||||
verstage-y += ../common/timer.c timer.c
|
||||
verstage-y += ../common/uart.c
|
||||
verstage-y += ../common/wdt.c
|
||||
|
||||
romstage-y += ../common/cbmem.c
|
||||
romstage-y += emi.c
|
||||
romstage-$(CONFIG_SPI_FLASH) += spi.c
|
||||
romstage-y += ../common/timer.c
|
||||
romstage-y += ../common/timer.c timer.c
|
||||
romstage-y += ../common/uart.c
|
||||
romstage-y += ../common/wdt.c
|
||||
|
||||
ramstage-y += emi.c
|
||||
ramstage-$(CONFIG_SPI_FLASH) += spi.c
|
||||
ramstage-y += soc.c
|
||||
ramstage-y += ../common/timer.c
|
||||
ramstage-y += ../common/timer.c timer.c
|
||||
ramstage-y += ../common/uart.c
|
||||
ramstage-y += ../common/wdt.c
|
||||
|
||||
|
|
|
@ -22,6 +22,7 @@ enum {
|
|||
GPT_BASE = IO_PHYS + 0x00008000,
|
||||
EINT_BASE = IO_PHYS + 0x0000B000,
|
||||
APMIXED_BASE = IO_PHYS + 0x0000C000,
|
||||
SYSTIMER_BASE = IO_PHYS + 0x00017000,
|
||||
PMIF_SPI_BASE = IO_PHYS + 0x00024000,
|
||||
PMICSPI_MST_BASE = IO_PHYS + 0x00025000,
|
||||
PMIF_SPMI_BASE = IO_PHYS + 0x00027000,
|
||||
|
|
20
src/soc/mediatek/mt8195/include/soc/timer.h
Normal file
20
src/soc/mediatek/mt8195/include/soc/timer.h
Normal file
|
@ -0,0 +1,20 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#ifndef SOC_MEDIATEK_MT8195_TIMER_H
|
||||
#define SOC_MEDIATEK_MT8195_TIMER_H
|
||||
|
||||
#include <soc/timer_v2.h>
|
||||
|
||||
enum {
|
||||
TIE_0_EN = 1 << 3,
|
||||
COMP_15_EN = 1 << 10,
|
||||
COMP_20_EN = 1 << 11,
|
||||
COMP_25_EN = 1 << 12,
|
||||
|
||||
COMP_FEATURE_MASK = COMP_15_EN | COMP_20_EN | COMP_25_EN | TIE_0_EN,
|
||||
|
||||
COMP_15_MASK = COMP_15_EN,
|
||||
COMP_20_MASK = COMP_20_EN | TIE_0_EN,
|
||||
COMP_25_MASK = COMP_20_EN | COMP_25_EN,
|
||||
};
|
||||
#endif
|
11
src/soc/mediatek/mt8195/timer.c
Normal file
11
src/soc/mediatek/mt8195/timer.c
Normal file
|
@ -0,0 +1,11 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#include <device/mmio.h>
|
||||
#include <soc/addressmap.h>
|
||||
#include <soc/timer.h>
|
||||
|
||||
void timer_prepare(void)
|
||||
{
|
||||
clrbits32((void *)SYSTIMER_BASE, COMP_FEATURE_MASK);
|
||||
setbits32((void *)SYSTIMER_BASE, COMP_25_MASK);
|
||||
}
|
Loading…
Reference in a new issue