diff options
author | Pali Rohár <pali.rohar@gmail.com> | 2013-09-08 03:43:29 -0400 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2013-10-08 14:55:32 -0400 |
commit | a33f1788192d13165594f8ec6975dbae34502ec9 (patch) | |
tree | 6894ffb5054b9fb8583d0a830758c6ee0b410a39 /arch/arm/mach-omap2/omap-smc.S | |
parent | d0e639c9e06d44e713170031fe05fb60ebe680af (diff) |
ARM: OMAP3: Add secure function omap_smc3() which calling instruction smc #1
Here is new version (v4) of omap secure part patch:
Other secure functions omap_smc1() and omap_smc2() calling instruction smc #0
but Nokia RX-51 board needs to call smc #1 for PPA access.
Signed-off-by: Ivaylo Dimitrov <freemangordon@abv.bg>
Signed-off-by: Pali Rohár <pali.rohar@gmail.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/mach-omap2/omap-smc.S')
-rw-r--r-- | arch/arm/mach-omap2/omap-smc.S | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/arch/arm/mach-omap2/omap-smc.S b/arch/arm/mach-omap2/omap-smc.S index f6441c13cd8c..fd90125bffc7 100644 --- a/arch/arm/mach-omap2/omap-smc.S +++ b/arch/arm/mach-omap2/omap-smc.S | |||
@@ -1,9 +1,11 @@ | |||
1 | /* | 1 | /* |
2 | * OMAP44xx secure APIs file. | 2 | * OMAP34xx and OMAP44xx secure APIs file. |
3 | * | 3 | * |
4 | * Copyright (C) 2010 Texas Instruments, Inc. | 4 | * Copyright (C) 2010 Texas Instruments, Inc. |
5 | * Written by Santosh Shilimkar <santosh.shilimkar@ti.com> | 5 | * Written by Santosh Shilimkar <santosh.shilimkar@ti.com> |
6 | * | 6 | * |
7 | * Copyright (C) 2012 Ivaylo Dimitrov <freemangordon@abv.bg> | ||
8 | * Copyright (C) 2013 Pali Rohár <pali.rohar@gmail.com> | ||
7 | * | 9 | * |
8 | * This program is free software,you can redistribute it and/or modify | 10 | * 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 | 11 | * it under the terms of the GNU General Public License version 2 as |
@@ -54,6 +56,23 @@ ENTRY(omap_smc2) | |||
54 | ldmfd sp!, {r4-r12, pc} | 56 | ldmfd sp!, {r4-r12, pc} |
55 | ENDPROC(omap_smc2) | 57 | ENDPROC(omap_smc2) |
56 | 58 | ||
59 | /** | ||
60 | * u32 omap_smc3(u32 service_id, u32 process_id, u32 flag, u32 pargs) | ||
61 | * Low level common routine for secure HAL and PPA APIs via smc #1 | ||
62 | * r0 - @service_id: Secure Service ID | ||
63 | * r1 - @process_id: Process ID | ||
64 | * r2 - @flag: Flag to indicate the criticality of operation | ||
65 | * r3 - @pargs: Physical address of parameter list | ||
66 | */ | ||
67 | ENTRY(omap_smc3) | ||
68 | stmfd sp!, {r4-r11, lr} | ||
69 | mov r12, r0 @ Copy the secure service ID | ||
70 | mov r6, #0xff @ Indicate new Task call | ||
71 | dsb @ Memory Barrier (not sure if needed, copied from omap_smc2) | ||
72 | smc #1 @ Call PPA service | ||
73 | ldmfd sp!, {r4-r11, pc} | ||
74 | ENDPROC(omap_smc3) | ||
75 | |||
57 | ENTRY(omap_modify_auxcoreboot0) | 76 | ENTRY(omap_modify_auxcoreboot0) |
58 | stmfd sp!, {r1-r12, lr} | 77 | stmfd sp!, {r1-r12, lr} |
59 | ldr r12, =0x104 | 78 | ldr r12, =0x104 |