Skip to content

Commit

Permalink
ARM: 8260/1: l2c: Add interface to ask hypervisor to configure L2C
Browse files Browse the repository at this point in the history
Because certain secure hypervisor do not allow writes to individual L2C
registers, but rather expect set of parameters to be passed as argument
to secure monitor calls, there is a need to provide an interface for the
L2C driver to ask the firmware to configure the hardware according to
specified parameters. This patch adds such.

Signed-off-by: Tomasz Figa <t.figa@samsung.com>
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
Tested-by: Nishanth Menon <nm@ti.com>
Acked-by: Nishanth Menon <nm@ti.com>
Acked-by: Tony Lindgren <tony@atomide.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
  • Loading branch information
Tomasz Figa authored and Russell King committed Jan 16, 2015
1 parent 6b49241 commit c6d1a2d
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 0 deletions.
3 changes: 3 additions & 0 deletions arch/arm/include/asm/outercache.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@

#include <linux/types.h>

struct l2x0_regs;

struct outer_cache_fns {
void (*inv_range)(unsigned long, unsigned long);
void (*clean_range)(unsigned long, unsigned long);
Expand All @@ -36,6 +38,7 @@ struct outer_cache_fns {

/* This is an ARM L2C thing */
void (*write_sec)(unsigned long, unsigned);
void (*configure)(const struct l2x0_regs *);
};

extern struct outer_cache_fns outer_cache;
Expand Down
6 changes: 6 additions & 0 deletions arch/arm/mm/cache-l2x0.c
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,11 @@ static inline void l2c_unlock(void __iomem *base, unsigned num)

static void l2c_configure(void __iomem *base)
{
if (outer_cache.configure) {
outer_cache.configure(&l2x0_saved_regs);
return;
}

if (l2x0_data->configure)
l2x0_data->configure(base);

Expand Down Expand Up @@ -910,6 +915,7 @@ static int __init __l2c_init(const struct l2c_init_data *data,

fns = data->outer_cache;
fns.write_sec = outer_cache.write_sec;
fns.configure = outer_cache.configure;
if (data->fixup)
data->fixup(l2x0_base, cache_id, &fns);

Expand Down

0 comments on commit c6d1a2d

Please sign in to comment.