Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2012 Pavel Machek <pavel@denx.de> |
Alan Tull | 44fd8c7 | 2015-06-05 08:24:52 -0500 | [diff] [blame] | 3 | * Copyright (C) 2012-2015 Altera Corporation |
Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 4 | * |
| 5 | * This program is free software; you can redistribute it and/or modify |
| 6 | * it under the terms of the GNU General Public License as published by |
| 7 | * the Free Software Foundation; either version 2 of the License, or |
| 8 | * (at your option) any later version. |
| 9 | * |
| 10 | * This program is distributed in the hope that it will be useful, |
| 11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 13 | * GNU General Public License for more details. |
| 14 | * |
| 15 | * You should have received a copy of the GNU General Public License |
| 16 | * along with this program; if not, write to the Free Software |
| 17 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| 18 | */ |
| 19 | |
| 20 | #ifndef __MACH_CORE_H |
| 21 | #define __MACH_CORE_H |
| 22 | |
Dinh Nguyen | 5c04b57 | 2013-04-11 10:55:24 -0500 | [diff] [blame] | 23 | #define SOCFPGA_RSTMGR_CTRL 0x04 |
Alan Tull | d686ce4 | 2014-10-14 19:33:38 +0000 | [diff] [blame] | 24 | #define SOCFPGA_RSTMGR_MODMPURST 0x10 |
Dinh Nguyen | 5c04b57 | 2013-04-11 10:55:24 -0500 | [diff] [blame] | 25 | #define SOCFPGA_RSTMGR_MODPERRST 0x14 |
| 26 | #define SOCFPGA_RSTMGR_BRGMODRST 0x1c |
| 27 | |
Dinh Nguyen | cd871d5 | 2015-07-20 11:23:13 -0500 | [diff] [blame] | 28 | #define SOCFPGA_A10_RSTMGR_CTRL 0xC |
Dinh Nguyen | 45be0cd | 2015-06-02 21:14:02 -0500 | [diff] [blame] | 29 | #define SOCFPGA_A10_RSTMGR_MODMPURST 0x20 |
| 30 | |
Dinh Nguyen | 5c04b57 | 2013-04-11 10:55:24 -0500 | [diff] [blame] | 31 | /* System Manager bits */ |
| 32 | #define RSTMGR_CTRL_SWCOLDRSTREQ 0x1 /* Cold Reset */ |
| 33 | #define RSTMGR_CTRL_SWWARMRSTREQ 0x2 /* Warm Reset */ |
| 34 | |
Alan Tull | d686ce4 | 2014-10-14 19:33:38 +0000 | [diff] [blame] | 35 | #define RSTMGR_MPUMODRST_CPU1 0x2 /* CPU1 Reset */ |
| 36 | |
Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 37 | extern void socfpga_init_clocks(void); |
| 38 | extern void socfpga_sysmgr_init(void); |
Thor Thayer | 4d11383 | 2016-02-10 13:26:23 -0600 | [diff] [blame] | 39 | void socfpga_init_l2_ecc(void); |
Thor Thayer | 7cc5a5d | 2016-02-10 13:26:24 -0600 | [diff] [blame] | 40 | void socfpga_init_ocram_ecc(void); |
Thor Thayer | ff6fd14 | 2016-03-21 11:01:45 -0500 | [diff] [blame] | 41 | void socfpga_init_arria10_l2_ecc(void); |
Thor Thayer | c5fb04c | 2016-04-11 12:01:34 -0500 | [diff] [blame] | 42 | void socfpga_init_arria10_ocram_ecc(void); |
Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 43 | |
Dinh Nguyen | 5c04b57 | 2013-04-11 10:55:24 -0500 | [diff] [blame] | 44 | extern void __iomem *sys_manager_base_addr; |
| 45 | extern void __iomem *rst_manager_base_addr; |
Alan Tull | 44fd8c7 | 2015-06-05 08:24:52 -0500 | [diff] [blame] | 46 | extern void __iomem *sdr_ctl_base_addr; |
Dinh Nguyen | 5c04b57 | 2013-04-11 10:55:24 -0500 | [diff] [blame] | 47 | |
Alan Tull | 44fd8c7 | 2015-06-05 08:24:52 -0500 | [diff] [blame] | 48 | u32 socfpga_sdram_self_refresh(u32 sdr_base); |
| 49 | extern unsigned int socfpga_sdram_self_refresh_sz; |
Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 50 | |
Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 51 | extern char secondary_trampoline, secondary_trampoline_end; |
| 52 | |
Dinh Nguyen | 3a4356c | 2014-10-01 05:44:48 -0500 | [diff] [blame] | 53 | extern unsigned long socfpga_cpu1start_addr; |
Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 54 | |
Vince Bridgers | de04261 | 2015-02-11 18:34:25 +0000 | [diff] [blame] | 55 | #define SOCFPGA_SCU_VIRT_BASE 0xfee00000 |
Dinh Nguyen | 9c4566a | 2012-10-25 10:41:39 -0600 | [diff] [blame] | 56 | |
| 57 | #endif |