blob: 758e6f4a0bf65cc1d97287bcbcec2d82e9be841a [file] [log] [blame]
Nobuhiro Iwamatsu3e590432008-08-22 17:39:09 +09001/*
2 * Copyright (C) 2008 Renesas Solutions Corp.
3 * Copyright (C) 2008 Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com>
4 *
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public License as
7 * published by the Free Software Foundation; either version 2 of
8 * the License, or (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,
18 * MA 02111-1307 USA
19 */
20
21#include <common.h>
Ben Warrenfbfdd3a2009-07-20 22:01:11 -070022#include <netdev.h>
Nobuhiro Iwamatsu3e590432008-08-22 17:39:09 +090023#include <asm/io.h>
24#include <asm/processor.h>
25
John Rigby0d21ed02010-12-20 18:27:51 -070026DECLARE_GLOBAL_DATA_PTR;
27
Nobuhiro Iwamatsu3e590432008-08-22 17:39:09 +090028/* PRI control register */
29#define PRPRICR5 0xFF800048 /* LMB */
30#define PRPRICR5_D 0x2a
31
32/* FPGA control */
33#define FPGA_NAND_CTL 0xB410020C
34#define FPGA_NAND_RST 0x0008
35#define FPGA_NAND_INIT 0x0000
36#define FPGA_NAND_RST_WAIT 10000
37
38/* I/O port data */
39#define PACR_D 0x0000
40#define PBCR_D 0x0000
41#define PCCR_D 0x1000
42#define PDCR_D 0x0000
43#define PECR_D 0x0410
44#define PFCR_D 0xffff
45#define PGCR_D 0x0000
46#define PHCR_D 0x5011
47#define PJCR_D 0x4400
48#define PKCR_D 0x7c00
49#define PLCR_D 0x0000
50#define PMCR_D 0x0000
51#define PNCR_D 0x0000
52#define PQCR_D 0x0000
53#define PRCR_D 0x0000
54#define PSCR_D 0x0000
55#define PTCR_D 0x0010
56#define PUCR_D 0x0fff
57#define PVCR_D 0xffff
58#define PWCR_D 0x0000
59#define PXCR_D 0x7500
60#define PYCR_D 0x0000
61#define PZCR_D 0x5540
62
63/* Pin Function Controler data */
64#define PSELA_D 0x1410
65#define PSELB_D 0x0140
66#define PSELC_D 0x0000
67#define PSELD_D 0x0400
68
69/* I/O Buffer Hi-Z data */
70#define HIZCRA_D 0x0000
71#define HIZCRB_D 0x1000
72#define HIZCRC_D 0x0000
73#define HIZCRD_D 0x0000
74
75/* Module select reg data */
76#define MSELCRA_D 0x0014
77#define MSELCRB_D 0x0018
78
79/* Module Stop reg Data */
80#define MSTPCR2_D 0xFFD9F280
81
82/* CPLD loader */
83extern void init_cpld(void);
84
85int checkboard(void)
86{
87 puts("BOARD: AP325RXA\n");
88 return 0;
89}
90
91int board_init(void)
92{
93 /* Pin Function Controler Init */
94 outw(PSELA_D, PSELA);
95 outw(PSELB_D, PSELB);
96 outw(PSELC_D, PSELC);
97 outw(PSELD_D, PSELD);
98
99 /* I/O Buffer Hi-Z Init */
100 outw(HIZCRA_D, HIZCRA);
101 outw(HIZCRB_D, HIZCRB);
102 outw(HIZCRC_D, HIZCRC);
103 outw(HIZCRD_D, HIZCRD);
104
105 /* Module select reg Init */
106 outw(MSELCRA_D, MSELCRA);
107 outw(MSELCRB_D, MSELCRB);
108
109 /* Module Stop reg Init */
110 outl(MSTPCR2_D, MSTPCR2);
111
112 /* I/O ports */
113 outw(PACR_D, PACR);
114 outw(PBCR_D, PBCR);
115 outw(PCCR_D, PCCR);
116 outw(PDCR_D, PDCR);
117 outw(PECR_D, PECR);
118 outw(PFCR_D, PFCR);
119 outw(PGCR_D, PGCR);
120 outw(PHCR_D, PHCR);
121 outw(PJCR_D, PJCR);
122 outw(PKCR_D, PKCR);
123 outw(PLCR_D, PLCR);
124 outw(PMCR_D, PMCR);
125 outw(PNCR_D, PNCR);
126 outw(PQCR_D, PQCR);
127 outw(PRCR_D, PRCR);
128 outw(PSCR_D, PSCR);
129 outw(PTCR_D, PTCR);
130 outw(PUCR_D, PUCR);
131 outw(PVCR_D, PVCR);
132 outw(PWCR_D, PWCR);
133 outw(PXCR_D, PXCR);
134 outw(PYCR_D, PYCR);
135 outw(PZCR_D, PZCR);
136
137 /* PRI control register Init */
138 outl(PRPRICR5_D, PRPRICR5);
139
140 /* cpld init */
141 init_cpld();
142
143 return 0;
144}
145
146int dram_init(void)
147{
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200148 gd->bd->bi_memstart = CONFIG_SYS_SDRAM_BASE;
149 gd->bd->bi_memsize = CONFIG_SYS_SDRAM_SIZE;
150 printf("DRAM: %dMB\n", CONFIG_SYS_SDRAM_SIZE / (1024 * 1024));
Nobuhiro Iwamatsu3e590432008-08-22 17:39:09 +0900151 return 0;
152}
153
154void led_set_state(unsigned short value)
155{
156}
157
158void ide_set_reset(int idereset)
159{
160 outw(FPGA_NAND_RST, FPGA_NAND_CTL); /* NAND RESET */
161 udelay(FPGA_NAND_RST_WAIT);
162 outw(FPGA_NAND_INIT, FPGA_NAND_CTL);
163}
Ben Warrenfbfdd3a2009-07-20 22:01:11 -0700164
165int board_eth_init(bd_t *bis)
166{
167 int rc = 0;
168#ifdef CONFIG_SMC911X
169 rc = smc911x_initialize(0, CONFIG_SMC911X_BASE);
170#endif
171 return rc;
172}