blob: 50eb18ba94d927d6d7e9dd926add3e58668f2800 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
TsiChung Liew6d33c6a2008-07-23 17:11:47 -05002/*
3 * (C) Copyright 2000-2003
4 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5 *
Alison Wang32dbaaf2012-03-26 21:49:04 +00006 * Copyright (C) 2004-2007, 2012 Freescale Semiconductor, Inc.
TsiChung Liew6d33c6a2008-07-23 17:11:47 -05007 * Hayden Fraser (Hayden.Fraser@freescale.com)
TsiChung Liew6d33c6a2008-07-23 17:11:47 -05008 */
9
10#include <common.h>
Simon Glass49acd562019-12-28 10:45:06 -070011#include <init.h>
Simon Glass90526e92020-05-10 11:39:56 -060012#include <net.h>
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050013#include <asm/immap.h>
Remy Bohmer60f61e62009-05-02 21:49:18 +020014#include <netdev.h>
Jason Jin6752da62011-04-18 17:54:04 +080015#include <asm/io.h>
Simon Glassc05ed002020-05-10 11:40:11 -060016#include <linux/delay.h>
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050017
Simon Glass088454c2017-03-31 08:40:25 -060018DECLARE_GLOBAL_DATA_PTR;
19
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050020int checkboard(void)
21{
22 puts("Board: ");
23 puts("Freescale MCF5253 DEMO\n");
24 return 0;
25};
26
Simon Glassf1683aa2017-04-06 12:47:05 -060027int dram_init(void)
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050028{
29 u32 dramsize = 0;
30
31 /*
32 * Check to see if the SDRAM has already been initialized
33 * by a run control tool
34 */
35 if (!(mbar_readLong(MCFSIM_DCR) & 0x8000)) {
36 u32 RC, temp;
37
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020038 RC = (CONFIG_SYS_CLK / 1000000) >> 1;
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050039 RC = (RC * 15) >> 4;
40
41 /* Initialize DRAM Control Register: DCR */
42 mbar_writeShort(MCFSIM_DCR, (0x8400 | RC));
43 __asm__("nop");
44
45 mbar_writeLong(MCFSIM_DACR0, 0x00003224);
46 __asm__("nop");
47
48 /* Initialize DMR0 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020049 dramsize = (CONFIG_SYS_SDRAM_SIZE << 20);
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050050 temp = (dramsize - 1) & 0xFFFC0000;
51 mbar_writeLong(MCFSIM_DMR0, temp | 1);
52 __asm__("nop");
53
54 mbar_writeLong(MCFSIM_DACR0, 0x0000322c);
Jason Jin6752da62011-04-18 17:54:04 +080055 mb();
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050056 __asm__("nop");
57
58 /* Write to this block to initiate precharge */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020059 *(u32 *) (CONFIG_SYS_SDRAM_BASE) = 0xa5a5a5a5;
Jason Jin6752da62011-04-18 17:54:04 +080060 mb();
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050061 __asm__("nop");
62
63 /* Set RE bit in DACR */
64 mbar_writeLong(MCFSIM_DACR0,
65 mbar_readLong(MCFSIM_DACR0) | 0x8000);
66 __asm__("nop");
67
68 /* Wait for at least 8 auto refresh cycles to occur */
69 udelay(500);
70
71 /* Finish the configuration by issuing the MRS */
72 mbar_writeLong(MCFSIM_DACR0,
73 mbar_readLong(MCFSIM_DACR0) | 0x0040);
74 __asm__("nop");
75
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020076 *(u32 *) (CONFIG_SYS_SDRAM_BASE + 0x800) = 0xa5a5a5a5;
Jason Jin6752da62011-04-18 17:54:04 +080077 mb();
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050078 }
79
Simon Glass088454c2017-03-31 08:40:25 -060080 gd->ram_size = dramsize;
81
82 return 0;
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050083}
84
85int testdram(void)
86{
87 /* TODO: XXX XXX XXX */
88 printf("DRAM test not implemented!\n");
89
90 return (0);
91}
92
Simon Glassfc843a02017-05-17 03:25:30 -060093#ifdef CONFIG_IDE
TsiChung Liew6d33c6a2008-07-23 17:11:47 -050094#include <ata.h>
95int ide_preinit(void)
96{
97 return (0);
98}
99
100void ide_set_reset(int idereset)
101{
Alison Wang32dbaaf2012-03-26 21:49:04 +0000102 atac_t *ata = (atac_t *) CONFIG_SYS_ATA_BASE_ADDR;
TsiChung Liew6d33c6a2008-07-23 17:11:47 -0500103 long period;
104 /* t1, t2, t3, t4, t5, t6, t9, tRD, tA */
105 int piotms[5][9] = { {70, 165, 60, 30, 50, 5, 20, 0, 35}, /* PIO 0 */
106 {50, 125, 45, 20, 35, 5, 15, 0, 35}, /* PIO 1 */
107 {30, 100, 30, 15, 20, 5, 10, 0, 35}, /* PIO 2 */
108 {30, 80, 30, 10, 20, 5, 10, 0, 35}, /* PIO 3 */
109 {25, 70, 20, 10, 20, 5, 10, 0, 35} /* PIO 4 */
110 };
111
112 if (idereset) {
Alison Wang32dbaaf2012-03-26 21:49:04 +0000113 /* control reset */
114 out_8(&ata->cr, 0);
TsiChung Liew6d33c6a2008-07-23 17:11:47 -0500115 udelay(100);
116 } else {
117 mbar2_writeLong(CIM_MISCCR, CIM_MISCCR_CPUEND);
118
119#define CALC_TIMING(t) (t + period - 1) / period
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200120 period = 1000000000 / (CONFIG_SYS_CLK / 2); /* period in ns */
TsiChung Liew6d33c6a2008-07-23 17:11:47 -0500121
122 /*ata->ton = CALC_TIMING (180); */
Alison Wang32dbaaf2012-03-26 21:49:04 +0000123 out_8(&ata->t1, CALC_TIMING(piotms[2][0]));
124 out_8(&ata->t2w, CALC_TIMING(piotms[2][1]));
125 out_8(&ata->t2r, CALC_TIMING(piotms[2][1]));
126 out_8(&ata->ta, CALC_TIMING(piotms[2][8]));
127 out_8(&ata->trd, CALC_TIMING(piotms[2][7]));
128 out_8(&ata->t4, CALC_TIMING(piotms[2][3]));
129 out_8(&ata->t9, CALC_TIMING(piotms[2][6]));
TsiChung Liew6d33c6a2008-07-23 17:11:47 -0500130
Alison Wang32dbaaf2012-03-26 21:49:04 +0000131 /* IORDY enable */
132 out_8(&ata->cr, 0x40);
TsiChung Liew6d33c6a2008-07-23 17:11:47 -0500133 udelay(2000);
Alison Wang32dbaaf2012-03-26 21:49:04 +0000134 /* IORDY enable */
135 setbits_8(&ata->cr, 0x01);
TsiChung Liew6d33c6a2008-07-23 17:11:47 -0500136 }
137}
Simon Glassfc843a02017-05-17 03:25:30 -0600138#endif /* CONFIG_IDE */
Remy Bohmer60f61e62009-05-02 21:49:18 +0200139
140
141#ifdef CONFIG_DRIVER_DM9000
142int board_eth_init(bd_t *bis)
143{
144 return dm9000_initialize(bis);
145}
146#endif