2018-05-06 21:58:06 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
2018-01-10 05:20:23 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2017 NXP
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <common.h>
|
|
|
|
#include <asm/arch/sys_proto.h>
|
2020-05-10 17:39:56 +00:00
|
|
|
#include <asm/cache.h>
|
2020-05-10 17:40:06 +00:00
|
|
|
#include <asm/ptrace.h>
|
2018-01-10 05:20:23 +00:00
|
|
|
|
|
|
|
unsigned long call_imx_sip(unsigned long id, unsigned long reg0,
|
2019-10-26 14:24:03 +00:00
|
|
|
unsigned long reg1, unsigned long reg2,
|
|
|
|
unsigned long reg3)
|
2018-01-10 05:20:23 +00:00
|
|
|
{
|
|
|
|
struct pt_regs regs;
|
|
|
|
|
|
|
|
regs.regs[0] = id;
|
|
|
|
regs.regs[1] = reg0;
|
|
|
|
regs.regs[2] = reg1;
|
|
|
|
regs.regs[3] = reg2;
|
2019-10-26 14:24:03 +00:00
|
|
|
regs.regs[4] = reg3;
|
2018-01-10 05:20:23 +00:00
|
|
|
|
|
|
|
smc_call(®s);
|
|
|
|
|
|
|
|
return regs.regs[0];
|
|
|
|
}
|
2019-04-12 07:54:50 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Do an SMC call to return 2 registers by having reg1 passed in by reference
|
|
|
|
*/
|
|
|
|
unsigned long call_imx_sip_ret2(unsigned long id, unsigned long reg0,
|
|
|
|
unsigned long *reg1, unsigned long reg2,
|
|
|
|
unsigned long reg3)
|
|
|
|
{
|
|
|
|
struct pt_regs regs;
|
|
|
|
|
|
|
|
regs.regs[0] = id;
|
|
|
|
regs.regs[1] = reg0;
|
|
|
|
regs.regs[2] = *reg1;
|
|
|
|
regs.regs[3] = reg2;
|
|
|
|
regs.regs[4] = reg3;
|
|
|
|
|
|
|
|
smc_call(®s);
|
|
|
|
|
|
|
|
*reg1 = regs.regs[1];
|
|
|
|
|
|
|
|
return regs.regs[0];
|
|
|
|
}
|