blob: 28be74e8273c23fa34c3269ead7e311298ec09bd [file] [log] [blame]
Christian Daudt8ac49e02012-11-19 09:46:10 -08001/*
2 * Copyright (C) 2012 Broadcom Corporation
3 *
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License as
6 * published by the Free Software Foundation version 2.
7 *
8 * This program is distributed "as is" WITHOUT ANY WARRANTY of any
9 * kind, whether express or implied; without even the implied warranty
10 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 */
13
Christian Daudt8ac49e02012-11-19 09:46:10 -080014#include <linux/of_platform.h>
15#include <linux/init.h>
16#include <linux/device.h>
17#include <linux/platform_device.h>
Rob Herring0529e3152012-11-05 16:18:28 -060018#include <linux/irqchip.h>
Christian Daudt8ac49e02012-11-19 09:46:10 -080019
20#include <asm/mach/arch.h>
Christian Daudt8ac49e02012-11-19 09:46:10 -080021#include <asm/mach/time.h>
Christian Daudtb8eb35f2013-02-26 21:48:49 -080022#include <asm/hardware/cache-l2x0.h>
Christian Daudt8ac49e02012-11-19 09:46:10 -080023
Christian Daudt8ac49e02012-11-19 09:46:10 -080024static void timer_init(void)
25{
26}
27
Christian Daudt8ac49e02012-11-19 09:46:10 -080028
Christian Daudtb8eb35f2013-02-26 21:48:49 -080029#include "bcm_kona_smc.h"
30
31static int __init kona_l2_cache_init(void)
32{
33 if (!IS_ENABLED(CONFIG_CACHE_L2X0))
34 return 0;
35
36 bcm_kona_smc(SSAPI_ENABLE_L2_CACHE, 0, 0, 0, 0);
37
38 /*
39 * The aux_val and aux_mask have no effect since L2 cache is already
40 * enabled. Pass 0s for aux_val and 1s for aux_mask for default value.
41 */
42 l2x0_of_init(0, ~0);
43
44 return 0;
45}
46
Christian Daudt8ac49e02012-11-19 09:46:10 -080047static void __init board_init(void)
48{
49 of_platform_populate(NULL, of_default_bus_match_table, NULL,
50 &platform_bus);
Christian Daudtb8eb35f2013-02-26 21:48:49 -080051
52 bcm_kona_smc_init();
53
54 kona_l2_cache_init();
Christian Daudt8ac49e02012-11-19 09:46:10 -080055}
56
57static const char * const bcm11351_dt_compat[] = { "bcm,bcm11351", NULL, };
58
59DT_MACHINE_START(BCM11351_DT, "Broadcom Application Processor")
Rob Herring0529e3152012-11-05 16:18:28 -060060 .init_irq = irqchip_init,
Stephen Warren6bb27d72012-11-08 12:40:59 -070061 .init_time = timer_init,
Christian Daudt8ac49e02012-11-19 09:46:10 -080062 .init_machine = board_init,
63 .dt_compat = bcm11351_dt_compat,
Christian Daudt8ac49e02012-11-19 09:46:10 -080064MACHINE_END