diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-11 16:57:16 +0900 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-11 16:57:16 +0900 | 
| commit | d5aabbcaee6bb5fb57ea8c67714516af4d8238ce (patch) | |
| tree | e95119c7c2bd1249503e065f0b7751289c696fb9 /arch/arm/mach-omap2/omap-secure.c | |
| parent | aac59e3efce3dca787b11e34726001603ce3d161 (diff) | |
| parent | 60cd8b09f1e26dec0e866085f110d1d665d53cec (diff) | |
Merge tag 'boards-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc
Pull ARM SoC board updates from Olof Johansson:
 "Board-related updates.  This branch is getting smaller and smaller,
  which is the whole idea so that's reassuring.
  Right now by far most of the code is related to shmobile updates, and
  they are now switching over to removal of board code and migration to
  multiplatform, so we'll see their board code base shrink in the near
  future too, I hope.
  In addition to that is some defconfig updates, some display updates
  for OMAP and a bit of new board support for Rockchip boards"
* tag 'boards-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (56 commits)
  ARM: rockchip: add support for rk3188 and Radxa Rock board
  ARM: rockchip: add dts for bqcurie2 tablet
  ARM: rockchip: enable arm-global-timer
  ARM: rockchip: move shared dt properties to common source file
  ARM: OMAP2+: display: Create omap_vout device inside omap_display_init
  ARM: OMAP2+: display: Create omapvrfb and omapfb devices inside omap_display_init
  ARM: OMAP2+: display: Create omapdrm device inside omap_display_init
  ARM: OMAP2+: drm: Don't build device for DMM
  ARM: tegra: defconfig updates
  RX-51: Add support for OMAP3 ROM Random Number Generator
  ARM: OMAP3: RX-51: ARM errata 430973 workaround
  ARM: OMAP3: Add secure function omap_smc3() which calling instruction smc #1
  ARM: shmobile: marzen: enable INTC IRQ
  ARM: shmobile: bockw: add SMSC support on reference
  ARM: shmobile: Use SMP on Koelsch
  ARM: shmobile: Remove KZM9D reference DTS
  ARM: shmobile: Let KZM9D multiplatform boot with KZM9D DTB
  ARM: shmobile: Remove non-multiplatform KZM9D reference support
  ARM: shmobile: Use KZM9D without reference for multiplatform
  ARM: shmobile: Sync KZM9D DTS with KZM9D reference DTS
  ...
Diffstat (limited to 'arch/arm/mach-omap2/omap-secure.c')
| -rw-r--r-- | arch/arm/mach-omap2/omap-secure.c | 76 | 
1 files changed, 76 insertions, 0 deletions
| diff --git a/arch/arm/mach-omap2/omap-secure.c b/arch/arm/mach-omap2/omap-secure.c index b970440cffca..5ac122e88f67 100644 --- a/arch/arm/mach-omap2/omap-secure.c +++ b/arch/arm/mach-omap2/omap-secure.c @@ -3,6 +3,8 @@   *   * Copyright (C) 2011 Texas Instruments, Inc.   *	Santosh Shilimkar <santosh.shilimkar@ti.com> + * Copyright (C) 2012 Ivaylo Dimitrov <freemangordon@abv.bg> + * Copyright (C) 2013 Pali Rohár <pali.rohar@gmail.com>   *   *   * This program is free software,you can redistribute it and/or modify @@ -70,3 +72,77 @@ phys_addr_t omap_secure_ram_mempool_base(void)  {  	return omap_secure_memblock_base;  } + +/** + * rx51_secure_dispatcher: Routine to dispatch secure PPA API calls + * @idx: The PPA API index + * @process: Process ID + * @flag: The flag indicating criticality of operation + * @nargs: Number of valid arguments out of four. + * @arg1, arg2, arg3 args4: Parameters passed to secure API + * + * Return the non-zero error value on failure. + * + * NOTE: rx51_secure_dispatcher differs from omap_secure_dispatcher because + *       it calling omap_smc3() instead omap_smc2() and param[0] is nargs+1 + */ +u32 rx51_secure_dispatcher(u32 idx, u32 process, u32 flag, u32 nargs, +			   u32 arg1, u32 arg2, u32 arg3, u32 arg4) +{ +	u32 ret; +	u32 param[5]; + +	param[0] = nargs+1; /* RX-51 needs number of arguments + 1 */ +	param[1] = arg1; +	param[2] = arg2; +	param[3] = arg3; +	param[4] = arg4; + +	/* +	 * Secure API needs physical address +	 * pointer for the parameters +	 */ +	local_irq_disable(); +	local_fiq_disable(); +	flush_cache_all(); +	outer_clean_range(__pa(param), __pa(param + 5)); +	ret = omap_smc3(idx, process, flag, __pa(param)); +	flush_cache_all(); +	local_fiq_enable(); +	local_irq_enable(); + +	return ret; +} + +/** + * rx51_secure_update_aux_cr: Routine to modify the contents of Auxiliary Control Register + *  @set_bits: bits to set in ACR + *  @clr_bits: bits to clear in ACR + * + * Return the non-zero error value on failure. +*/ +u32 rx51_secure_update_aux_cr(u32 set_bits, u32 clear_bits) +{ +	u32 acr; + +	/* Read ACR */ +	asm volatile ("mrc p15, 0, %0, c1, c0, 1" : "=r" (acr)); +	acr &= ~clear_bits; +	acr |= set_bits; + +	return rx51_secure_dispatcher(RX51_PPA_WRITE_ACR, +				      0, +				      FLAG_START_CRITICAL, +				      1, acr, 0, 0, 0); +} + +/** + * rx51_secure_rng_call: Routine for HW random generator + */ +u32 rx51_secure_rng_call(u32 ptr, u32 count, u32 flag) +{ +	return rx51_secure_dispatcher(RX51_PPA_HWRNG, +				      0, +				      NO_FLAG, +				      3, ptr, count, flag, 0); +} | 
