hc
2024-10-12 a5969cabbb4660eab42b6ef0412cbbd1200cf14d
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
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Copyright (C) 2014 Renesas Electronics Corporation
 *
 * Initialization of CNTVOFF register from secure mode
 *
 */
 
#include <linux/linkage.h>
#include <asm/assembler.h>
 
ENTRY(secure_cntvoff_init)
   .arch    armv7-a
   /*
    * CNTVOFF has to be initialized either from non-secure Hypervisor
    * mode or secure Monitor mode with SCR.NS==1. If TrustZone is enabled
    * then it should be handled by the secure code. The CPU must implement
    * the virtualization extensions.
    */
   cps    #MON_MODE
   mrc    p15, 0, r1, c1, c1, 0        /* Get Secure Config */
   orr    r0, r1, #1
   mcr    p15, 0, r0, c1, c1, 0        /* Set Non Secure bit */
   isb
   mov    r0, #0
   mcrr    p15, 4, r0, r0, c14        /* CNTVOFF = 0 */
   isb
   mcr    p15, 0, r1, c1, c1, 0        /* Set Secure bit */
   isb
   cps    #SVC_MODE
   ret    lr
ENDPROC(secure_cntvoff_init)