blob: 22e8421b1df37dbe3985548d05f8ddf98bca806f [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 Daudt80116572013-03-13 14:27:27 -070019#include <linux/clocksource.h>
Christian Daudt8ac49e02012-11-19 09:46:10 -080020
21#include <asm/mach/arch.h>
Christian Daudt8ac49e02012-11-19 09:46:10 -080022#include <asm/mach/time.h>
Christian Daudtb8eb35f2013-02-26 21:48:49 -080023#include <asm/hardware/cache-l2x0.h>
Christian Daudt8ac49e02012-11-19 09:46:10 -080024
Christian Daudt8ac49e02012-11-19 09:46:10 -080025
Christian Daudtb8eb35f2013-02-26 21:48:49 -080026#include "bcm_kona_smc.h"
27
28static int __init kona_l2_cache_init(void)
29{
30 if (!IS_ENABLED(CONFIG_CACHE_L2X0))
31 return 0;
32
33 bcm_kona_smc(SSAPI_ENABLE_L2_CACHE, 0, 0, 0, 0);
34
35 /*
36 * The aux_val and aux_mask have no effect since L2 cache is already
37 * enabled. Pass 0s for aux_val and 1s for aux_mask for default value.
38 */
39 l2x0_of_init(0, ~0);
40
41 return 0;
42}
43
Christian Daudt8ac49e02012-11-19 09:46:10 -080044static void __init board_init(void)
45{
46 of_platform_populate(NULL, of_default_bus_match_table, NULL,
47 &platform_bus);
Christian Daudtb8eb35f2013-02-26 21:48:49 -080048
49 bcm_kona_smc_init();
50
51 kona_l2_cache_init();
Christian Daudt8ac49e02012-11-19 09:46:10 -080052}
53
54static const char * const bcm11351_dt_compat[] = { "bcm,bcm11351", NULL, };
55
56DT_MACHINE_START(BCM11351_DT, "Broadcom Application Processor")
Rob Herring0529e3152012-11-05 16:18:28 -060057 .init_irq = irqchip_init,
Christian Daudt80116572013-03-13 14:27:27 -070058 .init_time = clocksource_of_init,
Christian Daudt8ac49e02012-11-19 09:46:10 -080059 .init_machine = board_init,
60 .dt_compat = bcm11351_dt_compat,
Christian Daudt8ac49e02012-11-19 09:46:10 -080061MACHINE_END