blob: 218d479c6b29d86dd3acf032837db99ed6157f51 [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 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
Nobuhiro Iwamatsu3e590432008-08-22 17:39:09 +09006 */
7
8#include <common.h>
Ben Warrenfbfdd3a2009-07-20 22:01:11 -07009#include <netdev.h>
Nobuhiro Iwamatsu3e590432008-08-22 17:39:09 +090010#include <asm/io.h>
11#include <asm/processor.h>
12
13/* PRI control register */
14#define PRPRICR5 0xFF800048 /* LMB */
15#define PRPRICR5_D 0x2a
16
17/* FPGA control */
18#define FPGA_NAND_CTL 0xB410020C
19#define FPGA_NAND_RST 0x0008
20#define FPGA_NAND_INIT 0x0000
21#define FPGA_NAND_RST_WAIT 10000
22
23/* I/O port data */
24#define PACR_D 0x0000
25#define PBCR_D 0x0000
26#define PCCR_D 0x1000
27#define PDCR_D 0x0000
28#define PECR_D 0x0410
29#define PFCR_D 0xffff
30#define PGCR_D 0x0000
31#define PHCR_D 0x5011
32#define PJCR_D 0x4400
33#define PKCR_D 0x7c00
34#define PLCR_D 0x0000
35#define PMCR_D 0x0000
36#define PNCR_D 0x0000
37#define PQCR_D 0x0000
38#define PRCR_D 0x0000
39#define PSCR_D 0x0000
40#define PTCR_D 0x0010
41#define PUCR_D 0x0fff
42#define PVCR_D 0xffff
43#define PWCR_D 0x0000
44#define PXCR_D 0x7500
45#define PYCR_D 0x0000
46#define PZCR_D 0x5540
47
48/* Pin Function Controler data */
49#define PSELA_D 0x1410
50#define PSELB_D 0x0140
51#define PSELC_D 0x0000
52#define PSELD_D 0x0400
53
54/* I/O Buffer Hi-Z data */
55#define HIZCRA_D 0x0000
56#define HIZCRB_D 0x1000
57#define HIZCRC_D 0x0000
58#define HIZCRD_D 0x0000
59
60/* Module select reg data */
61#define MSELCRA_D 0x0014
62#define MSELCRB_D 0x0018
63
64/* Module Stop reg Data */
65#define MSTPCR2_D 0xFFD9F280
66
67/* CPLD loader */
68extern void init_cpld(void);
69
70int checkboard(void)
71{
72 puts("BOARD: AP325RXA\n");
73 return 0;
74}
75
76int board_init(void)
77{
78 /* Pin Function Controler Init */
79 outw(PSELA_D, PSELA);
80 outw(PSELB_D, PSELB);
81 outw(PSELC_D, PSELC);
82 outw(PSELD_D, PSELD);
83
84 /* I/O Buffer Hi-Z Init */
85 outw(HIZCRA_D, HIZCRA);
86 outw(HIZCRB_D, HIZCRB);
87 outw(HIZCRC_D, HIZCRC);
88 outw(HIZCRD_D, HIZCRD);
89
90 /* Module select reg Init */
91 outw(MSELCRA_D, MSELCRA);
92 outw(MSELCRB_D, MSELCRB);
93
94 /* Module Stop reg Init */
95 outl(MSTPCR2_D, MSTPCR2);
96
97 /* I/O ports */
98 outw(PACR_D, PACR);
99 outw(PBCR_D, PBCR);
100 outw(PCCR_D, PCCR);
101 outw(PDCR_D, PDCR);
102 outw(PECR_D, PECR);
103 outw(PFCR_D, PFCR);
104 outw(PGCR_D, PGCR);
105 outw(PHCR_D, PHCR);
106 outw(PJCR_D, PJCR);
107 outw(PKCR_D, PKCR);
108 outw(PLCR_D, PLCR);
109 outw(PMCR_D, PMCR);
110 outw(PNCR_D, PNCR);
111 outw(PQCR_D, PQCR);
112 outw(PRCR_D, PRCR);
113 outw(PSCR_D, PSCR);
114 outw(PTCR_D, PTCR);
115 outw(PUCR_D, PUCR);
116 outw(PVCR_D, PVCR);
117 outw(PWCR_D, PWCR);
118 outw(PXCR_D, PXCR);
119 outw(PYCR_D, PYCR);
120 outw(PZCR_D, PZCR);
121
122 /* PRI control register Init */
123 outl(PRPRICR5_D, PRPRICR5);
124
125 /* cpld init */
126 init_cpld();
127
128 return 0;
129}
130
Nobuhiro Iwamatsu3e590432008-08-22 17:39:09 +0900131void led_set_state(unsigned short value)
132{
133}
134
135void ide_set_reset(int idereset)
136{
137 outw(FPGA_NAND_RST, FPGA_NAND_CTL); /* NAND RESET */
138 udelay(FPGA_NAND_RST_WAIT);
139 outw(FPGA_NAND_INIT, FPGA_NAND_CTL);
140}
Ben Warrenfbfdd3a2009-07-20 22:01:11 -0700141
142int board_eth_init(bd_t *bis)
143{
144 int rc = 0;
145#ifdef CONFIG_SMC911X
146 rc = smc911x_initialize(0, CONFIG_SMC911X_BASE);
147#endif
148 return rc;
149}