1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
/*
* Copyright 2017 NXP
*
* SPDX-License-Identifier: BSD-3-Clause
*/
#include <debug.h>
#include <stdlib.h>
#include <stdint.h>
#include <smcc_helpers.h>
#include <std_svc.h>
#include <types.h>
#include <platform_def.h>
#include <fsl_sip.h>
#include <sci/sci.h>
extern sc_ipc_t ipc_handle;
static int imx_srtc_set_time(uint32_t year_mon, unsigned long day_hour, unsigned long min_sec)
{
return sc_timer_set_rtc_time(ipc_handle,
year_mon >> 16, year_mon & 0xffff,
day_hour >> 16, day_hour & 0xffff,
min_sec >> 16, min_sec & 0xffff);
}
static int imx_srtc_set_wdog_action(uint32_t x2)
{
sc_rm_pt_t secure_part;
sc_err_t err;
err = sc_rm_get_partition(ipc_handle, &secure_part);
if (err)
return err;
err = sc_timer_set_wdog_action(ipc_handle, secure_part, x2);
return err;
}
int imx_srtc_handler(uint32_t smc_fid,
void *handle,
u_register_t x1,
u_register_t x2,
u_register_t x3,
u_register_t x4)
{
int ret;
sc_timer_wdog_time_t timeout, max_timeout, remaining;
switch(x1) {
case FSL_SIP_SRTC_SET_TIME:
ret = imx_srtc_set_time(x2, x3, x4);
break;
case FSL_SIP_SRTC_START_WDOG:
ret = sc_timer_start_wdog(ipc_handle, !!x2);
break;
case FSL_SIP_SRTC_STOP_WDOG:
ret = sc_timer_stop_wdog(ipc_handle);
break;
case FSL_SIP_SRTC_SET_WDOG_ACT:
ret = imx_srtc_set_wdog_action(x2);
break;
case FSL_SIP_SRTC_PING_WDOG:
ret = sc_timer_ping_wdog(ipc_handle);
break;
case FSL_SIP_SRTC_SET_TIMEOUT_WDOG:
ret = sc_timer_set_wdog_timeout(ipc_handle, x2);
break;
case FSL_SIP_SRTC_SET_PRETIME_WDOG:
ret = sc_timer_set_wdog_pre_timeout(ipc_handle, x2);
break;
case FSL_SIP_SRTC_GET_WDOG_STAT:
ret = sc_timer_get_wdog_status(ipc_handle, &timeout,
&max_timeout, &remaining);
SMC_RET4(handle, ret, timeout, max_timeout, remaining);
default:
ret = SMC_UNK;
}
SMC_RET1(handle, ret);
}
|