Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 36827edd authored by Russell King's avatar Russell King
Browse files

ARM: l2c: omap2: implement new write_sec method



With the write_sec method, we no longer need to override the default
L2C disable method, and we no longer need the L2C set_debug method.
Both of these can be handled via the write_sec method.

Acked-by: default avatarTony Lindgren <tony@atomide.com>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 8523f615
Loading
Loading
Loading
Loading
+26 −16
Original line number Original line Diff line number Diff line
@@ -167,17 +167,33 @@ void __iomem *omap4_get_l2cache_base(void)
	return l2cache_base;
	return l2cache_base;
}
}


static void omap4_l2x0_disable(void)
static void omap4_l2c310_write_sec(unsigned long val, unsigned reg)
{
{
	outer_flush_all();
	unsigned smc_op;
	/* Disable PL310 L2 Cache controller */

	omap_smc1(0x102, 0x0);
	switch (reg) {
	case L2X0_CTRL:
		smc_op = OMAP4_MON_L2X0_CTRL_INDEX;
		break;

	case L2X0_AUX_CTRL:
		smc_op = OMAP4_MON_L2X0_AUXCTRL_INDEX;
		break;

	case L2X0_DEBUG_CTRL:
		smc_op = OMAP4_MON_L2X0_DBG_CTRL_INDEX;
		break;

	case L310_PREFETCH_CTRL:
		smc_op = OMAP4_MON_L2X0_PREFETCH_INDEX;
		break;

	default:
		WARN_ONCE(1, "OMAP L2C310: ignoring write to reg 0x%x\n", reg);
		return;
	}
	}


static void omap4_l2x0_set_debug(unsigned long val)
	omap_smc1(smc_op, val);
{
	/* Program PL310 L2 Cache controller debug register */
	omap_smc1(0x100, val);
}
}


static int __init omap_l2_cache_init(void)
static int __init omap_l2_cache_init(void)
@@ -211,18 +227,12 @@ static int __init omap_l2_cache_init(void)
	/* Enable PL310 L2 Cache controller */
	/* Enable PL310 L2 Cache controller */
	omap_smc1(0x102, 0x1);
	omap_smc1(0x102, 0x1);


	outer_cache.write_sec = omap4_l2c310_write_sec;
	if (of_have_populated_dt())
	if (of_have_populated_dt())
		l2x0_of_init(aux_ctrl, L2X0_AUX_CTRL_MASK);
		l2x0_of_init(aux_ctrl, L2X0_AUX_CTRL_MASK);
	else
	else
		l2x0_init(l2cache_base, aux_ctrl, L2X0_AUX_CTRL_MASK);
		l2x0_init(l2cache_base, aux_ctrl, L2X0_AUX_CTRL_MASK);


	/*
	 * Override default outer_cache.disable with a OMAP4
	 * specific one
	*/
	outer_cache.disable = omap4_l2x0_disable;
	outer_cache.set_debug = omap4_l2x0_set_debug;

	return 0;
	return 0;
}
}
omap_early_initcall(omap_l2_cache_init);
omap_early_initcall(omap_l2_cache_init);