diff options
author | Santosh Shilimkar <santosh.shilimkar@ti.com> | 2011-06-06 08:26:49 -0400 |
---|---|---|
committer | Kevin Hilman <khilman@ti.com> | 2011-12-08 14:29:00 -0500 |
commit | ba9456ac9c72a7a5d4d59340aba4259351832521 (patch) | |
tree | 557647722688c75caef4de8d9fdf30665118cd0d /arch/arm/mach-omap2/omap-smc.S | |
parent | 3c50729b3fa1cd8ca1f347e6caf1081204cf1a7c (diff) |
ARM: OMAP: Add Secure HAL and monitor mode API infrastructure.
On OMAP secure/emulation devices, certain APIs are exported by secure
code. Add an infrastructure so that relevant operations on secure
devices can be implemented using it.
While at this, rename omap44xx-smc.S to omap-smc.S since the common APIs
can be used on other OMAP's too.
Signed-off-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
Acked-by: Jean Pihet <j-pihet@ti.com>
Reviewed-by: Kevin Hilman <khilman@ti.com>
Tested-by: Vishwanath BS <vishwanath.bs@ti.com>
Signed-off-by: Kevin Hilman <khilman@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2/omap-smc.S')
-rw-r--r-- | arch/arm/mach-omap2/omap-smc.S | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/omap-smc.S b/arch/arm/mach-omap2/omap-smc.S new file mode 100644 index 00000000000..f6441c13cd8 --- /dev/null +++ b/arch/arm/mach-omap2/omap-smc.S | |||
@@ -0,0 +1,80 @@ | |||
1 | /* | ||
2 | * OMAP44xx secure APIs file. | ||
3 | * | ||
4 | * Copyright (C) 2010 Texas Instruments, Inc. | ||
5 | * Written by Santosh Shilimkar <santosh.shilimkar@ti.com> | ||
6 | * | ||
7 | * | ||
8 | * This program is free software,you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License version 2 as | ||
10 | * published by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/linkage.h> | ||
14 | |||
15 | /* | ||
16 | * This is common routine to manage secure monitor API | ||
17 | * used to modify the PL310 secure registers. | ||
18 | * 'r0' contains the value to be modified and 'r12' contains | ||
19 | * the monitor API number. It uses few CPU registers | ||
20 | * internally and hence they need be backed up including | ||
21 | * link register "lr". | ||
22 | * Function signature : void omap_smc1(u32 fn, u32 arg) | ||
23 | */ | ||
24 | |||
25 | ENTRY(omap_smc1) | ||
26 | stmfd sp!, {r2-r12, lr} | ||
27 | mov r12, r0 | ||
28 | mov r0, r1 | ||
29 | dsb | ||
30 | smc #0 | ||
31 | ldmfd sp!, {r2-r12, pc} | ||
32 | ENDPROC(omap_smc1) | ||
33 | |||
34 | /** | ||
35 | * u32 omap_smc2(u32 id, u32 falg, u32 pargs) | ||
36 | * Low level common routine for secure HAL and PPA APIs. | ||
37 | * @id: Application ID of HAL APIs | ||
38 | * @flag: Flag to indicate the criticality of operation | ||
39 | * @pargs: Physical address of parameter list starting | ||
40 | * with number of parametrs | ||
41 | */ | ||
42 | ENTRY(omap_smc2) | ||
43 | stmfd sp!, {r4-r12, lr} | ||
44 | mov r3, r2 | ||
45 | mov r2, r1 | ||
46 | mov r1, #0x0 @ Process ID | ||
47 | mov r6, #0xff | ||
48 | mov r12, #0x00 @ Secure Service ID | ||
49 | mov r7, #0 | ||
50 | mcr p15, 0, r7, c7, c5, 6 | ||
51 | dsb | ||
52 | dmb | ||
53 | smc #0 | ||
54 | ldmfd sp!, {r4-r12, pc} | ||
55 | ENDPROC(omap_smc2) | ||
56 | |||
57 | ENTRY(omap_modify_auxcoreboot0) | ||
58 | stmfd sp!, {r1-r12, lr} | ||
59 | ldr r12, =0x104 | ||
60 | dsb | ||
61 | smc #0 | ||
62 | ldmfd sp!, {r1-r12, pc} | ||
63 | ENDPROC(omap_modify_auxcoreboot0) | ||
64 | |||
65 | ENTRY(omap_auxcoreboot_addr) | ||
66 | stmfd sp!, {r2-r12, lr} | ||
67 | ldr r12, =0x105 | ||
68 | dsb | ||
69 | smc #0 | ||
70 | ldmfd sp!, {r2-r12, pc} | ||
71 | ENDPROC(omap_auxcoreboot_addr) | ||
72 | |||
73 | ENTRY(omap_read_auxcoreboot0) | ||
74 | stmfd sp!, {r2-r12, lr} | ||
75 | ldr r12, =0x103 | ||
76 | dsb | ||
77 | smc #0 | ||
78 | mov r0, r0, lsr #9 | ||
79 | ldmfd sp!, {r2-r12, pc} | ||
80 | ENDPROC(omap_read_auxcoreboot0) | ||