rt-thread-official/bsp/phytium/libraries/standalone/arch/armv8/aarch32/fpsci.c

76 lines
1.9 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* Copyright : (C) 2022 Phytium Information Technology, Inc.
* All Rights Reserved.
*
* This program is OPEN SOURCE software: you can redistribute it and/or modify it
* under the terms of the Phytium Public License as published by the Phytium Technology Co.,Ltd,
* either version 1.0 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 Phytium Public License for more details.
*
*
* FilePath: psci.c
* Date: 2022-02-10 14:53:41
* LastEditTime: 2022-02-17 17:30:35
* Description:  This files is for
*
* Modify History:
* Ver   Who        Date         Changes
* ----- ------     --------    --------------------------------------
*/
#include "fpsci.h"
#include "fsmc.h"
#include "fcpu_info.h"
#include "ferror_code.h"
#include "fparameters.h"
#include "ftypes.h"
#define PSCI_CPUON_NUM 0x84000003
#define PSCI_RESET_NUM 0x84000009
/**
* @name: FPsci_CpuOn
* @msg: Power up a core
* @in param cpu_id_mask: cpu id mask
* @in param bootaddr: a 32-bit entry point physical address (or IPA).
* @return FError
*/
FError PsciCpuOn(s32 cpu_id_mask, uintptr bootaddr)
{
FError ret ;
u64 cluster = 0;
FSmc_Data_t input = {0};
FSmc_Data_t output = {0};
input.function_identifier = PSCI_CPUON_NUM;
ret = GetCpuAffinityByMask(cpu_id_mask, &cluster);
if (ret != ERR_SUCCESS)
{
return ret;
}
input.a1 = cluster;
input.a2 = (u32)(bootaddr & 0xFFFFFFFF);
FSmcCall(&input, &output);
__asm__ volatile("NOP");
return ERR_SUCCESS;
}
void PsciCpuReset(void)
{
FSmc_Data_t input = {0};
FSmc_Data_t output = {0};
input.function_identifier = PSCI_RESET_NUM;
FSmcCall(&input, &output);
__asm__ volatile("NOP");
while (1)
;
}