mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-08-16 01:17:01 +02:00
To use cirq drivers more easier, we place mtk_cirq.c and mtk_cirq.h to common/drivers/cirq. We also rename mtk_cirq.c/h to mt_cirq.c/h for consistency with other driver folders. TEST=build pass for mt8192/mt8195/mt8186 BUG=b:236331724 Signed-off-by: Bo-Chen Chen <rex-bc.chen@mediatek.com> Change-Id: I71bc442f00b16fb4031260937982c0496fcaaea0
151 lines
3.2 KiB
C
151 lines
3.2 KiB
C
/*
|
|
* Copyright (c) 2020-2022, MediaTek Inc. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#include <mt_cirq.h>
|
|
#include <mt_lp_irqremain.h>
|
|
#include <mt_lp_rm.h>
|
|
#include <plat_mtk_lpm.h>
|
|
|
|
#define EDMA0_IRQ_ID U(448)
|
|
#define MDLA_IRQ_ID U(446)
|
|
#define MALI4_IRQ_ID U(399)
|
|
#define MALI3_IRQ_ID U(398)
|
|
#define MALI2_IRQ_ID U(397)
|
|
#define MALI1_IRQ_ID U(396)
|
|
#define MALI0_IRQ_ID U(395)
|
|
#define VPU_CORE1_IRQ_ID U(453)
|
|
#define VPU_CORE0_IRQ_ID U(452)
|
|
#define MD_WDT_IRQ_ID U(110)
|
|
#define KEYPAD_IRQ_ID U(106)
|
|
|
|
#define MD_WDT_WAKESRC 0x2000000
|
|
#define KEYPAD_WAKESRC 0x4
|
|
|
|
static struct mt_irqremain remain_irqs;
|
|
|
|
int mt_lp_irqremain_submit(void)
|
|
{
|
|
if (remain_irqs.count == 0) {
|
|
return -1;
|
|
}
|
|
|
|
set_wakeup_sources(remain_irqs.irqs, remain_irqs.count);
|
|
mt_lp_rm_do_update(-1, PLAT_RC_UPDATE_REMAIN_IRQS, &remain_irqs);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int mt_lp_irqremain_aquire(void)
|
|
{
|
|
if (remain_irqs.count == 0) {
|
|
return -1;
|
|
}
|
|
|
|
mt_cirq_sw_reset();
|
|
mt_cirq_clone_gic();
|
|
mt_cirq_enable();
|
|
|
|
return 0;
|
|
}
|
|
|
|
int mt_lp_irqremain_release(void)
|
|
{
|
|
if (remain_irqs.count == 0) {
|
|
return -1;
|
|
}
|
|
|
|
mt_cirq_flush();
|
|
mt_cirq_disable();
|
|
|
|
return 0;
|
|
}
|
|
|
|
void mt_lp_irqremain_init(void)
|
|
{
|
|
uint32_t idx;
|
|
|
|
remain_irqs.count = 0;
|
|
|
|
/* level edma0 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = EDMA0_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level mdla */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = MDLA_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level mali4 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = MALI4_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level mali3 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = MALI3_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level mali2 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = MALI2_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level mali1 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = MALI1_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level mali0 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = MALI0_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level vpu core1 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = VPU_CORE1_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* level vpu core0 */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = VPU_CORE0_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = 0;
|
|
remain_irqs.count++;
|
|
|
|
/* edge mdwdt */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = MD_WDT_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = MD_WDT_WAKESRC;
|
|
remain_irqs.count++;
|
|
|
|
/* edge keypad */
|
|
idx = remain_irqs.count;
|
|
remain_irqs.irqs[idx] = KEYPAD_IRQ_ID;
|
|
remain_irqs.wakeupsrc_cat[idx] = 0;
|
|
remain_irqs.wakeupsrc[idx] = KEYPAD_WAKESRC;
|
|
remain_irqs.count++;
|
|
|
|
mt_lp_irqremain_submit();
|
|
}
|