Blame view

bootloader/u-boot_2015_04/board/afeb9260/afeb9260.c 3.77 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
  /*
   * (C) Copyright 2007-2008
   * Stelian Pop <stelian@popies.net>
   * Lead Tech Design <www.leadtechdesign.com>
   * (C) Copyright 2008 Sergey Lapin <slapin@ossfans.org>
   *
   * SPDX-License-Identifier:	GPL-2.0+
   */
  
  #include <common.h>
  #include <asm/arch/at91sam9260.h>
  #include <asm/arch/at91sam9260_matrix.h>
  #include <asm/arch/at91sam9_smc.h>
  #include <asm/arch/at91_common.h>
  #include <asm/arch/at91_pmc.h>
  #include <asm/arch/gpio.h>
  #include <asm/io.h>
  #include <asm/arch/hardware.h>
  #if defined(CONFIG_RESET_PHY_R) && defined(CONFIG_MACB)
  #include <netdev.h>
  #include <net.h>
  #endif
  
  DECLARE_GLOBAL_DATA_PTR;
  
  /* ------------------------------------------------------------------------- */
  /*
   * Miscelaneous platform dependent initialisations
   */
  
  static void afeb9260_nand_hw_init(void)
  {
  	unsigned long csa;
  	struct at91_smc *smc = (struct at91_smc *)ATMEL_BASE_SMC;
  	struct at91_matrix *matrix = (struct at91_matrix *)ATMEL_BASE_MATRIX;
  
  	/* Assign CS3 to NAND/SmartMedia Interface */
  	csa = readl(&matrix->ebicsa);
  	csa |= AT91_MATRIX_CS3A_SMC_SMARTMEDIA;
  	writel(csa, &matrix->ebicsa);
  
  	/* Configure SMC CS3 for NAND/SmartMedia */
  	writel(AT91_SMC_SETUP_NWE(1) | AT91_SMC_SETUP_NCS_WR(0) |
  		AT91_SMC_SETUP_NRD(1) | AT91_SMC_SETUP_NCS_RD(0),
  		&smc->cs[3].setup);
  	writel(AT91_SMC_PULSE_NWE(3) | AT91_SMC_PULSE_NCS_WR(3) |
  		AT91_SMC_PULSE_NRD(3) | AT91_SMC_PULSE_NCS_RD(3),
  		&smc->cs[3].pulse);
  	writel(AT91_SMC_CYCLE_NWE(5) | AT91_SMC_CYCLE_NRD(5),
  		&smc->cs[3].cycle);
  	writel(AT91_SMC_MODE_RM_NRD | AT91_SMC_MODE_WM_NWE |
  		AT91_SMC_MODE_EXNW_DISABLE |
  		AT91_SMC_MODE_DBW_8 |
  		AT91_SMC_MODE_TDF_CYCLE(2),
  		&smc->cs[3].mode);
  
  	/* Configure RDY/BSY */
  	at91_set_gpio_input(CONFIG_SYS_NAND_READY_PIN, 1);
  
  	/* Enable NandFlash */
  	at91_set_gpio_output(CONFIG_SYS_NAND_ENABLE_PIN, 1);
  }
  
  #ifdef CONFIG_MACB
  static void afeb9260_macb_hw_init(void)
  {
  	struct at91_pmc *pmc = (struct at91_pmc *)ATMEL_BASE_PMC;
  	struct at91_port *pioa = (struct at91_port *)ATMEL_BASE_PIOA;
  
  
  	/* Enable EMAC clock */
  	writel(1 << ATMEL_ID_EMAC0, &pmc->pcer);
  
  
  	/*
  	 * Disable pull-up on:
  	 *	RXDV (PA17) => PHY normal mode (not Test mode)
  	 *	ERX0 (PA14) => PHY ADDR0
  	 *	ERX1 (PA15) => PHY ADDR1
  	 *	ERX2 (PA25) => PHY ADDR2
  	 *	ERX3 (PA26) => PHY ADDR3
  	 *	ECRS (PA28) => PHY ADDR4  => PHYADDR = 0x0
  	 *
  	 * PHY has internal pull-down
  	 */
  	writel(pin_to_mask(AT91_PIN_PA14) |
  	       pin_to_mask(AT91_PIN_PA15) |
  	       pin_to_mask(AT91_PIN_PA17) |
  	       pin_to_mask(AT91_PIN_PA25) |
  	       pin_to_mask(AT91_PIN_PA26) |
  	       pin_to_mask(AT91_PIN_PA28),
  	       &pioa->pudr);
  
  	at91_phy_reset();
  
  	/* Re-enable pull-up */
  	writel(pin_to_mask(AT91_PIN_PA14) |
  	       pin_to_mask(AT91_PIN_PA15) |
  	       pin_to_mask(AT91_PIN_PA17) |
  	       pin_to_mask(AT91_PIN_PA25) |
  	       pin_to_mask(AT91_PIN_PA26) |
  	       pin_to_mask(AT91_PIN_PA28),
  	       &pioa->puer);
  
  	at91_macb_hw_init();
  }
  #endif
  int board_early_init_f(void)
  {
  	struct at91_pmc *pmc = (struct at91_pmc *)ATMEL_BASE_PMC;
  	/* Enable clocks for all PIOs */
  	writel((1 << ATMEL_ID_PIOA) |
  		(1 << ATMEL_ID_PIOB) |
  		(1 << ATMEL_ID_PIOC),
  		&pmc->pcer);
  	return 0;
  }
  int board_init(void)
  {
  	/* arch number of AT91SAM9260EK-Board */
  	gd->bd->bi_arch_number = MACH_TYPE_AFEB9260;
  	/* adress of boot parameters */
  	gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100;
  
  	at91_seriald_hw_init();
  #ifdef CONFIG_CMD_NAND
  	afeb9260_nand_hw_init();
  #endif
  	at91_spi0_hw_init((1 << 0) | (1 << 1));
  #ifdef CONFIG_MACB
  	afeb9260_macb_hw_init();
  #endif
  
  	return 0;
  }
  
  int dram_init(void)
  {
  	gd->ram_size = get_ram_size(
  	(void *)CONFIG_SYS_SDRAM_BASE,
  		CONFIG_SYS_SDRAM_SIZE);
  
  	return 0;
  }
  
  #ifdef CONFIG_RESET_PHY_R
  void reset_phy(void)
  {
  }
  #endif
  
  int board_eth_init(bd_t *bis)
  {
  	int rc = 0;
  #ifdef CONFIG_MACB
  	rc = macb_eth_initialize(0, (void *)ATMEL_BASE_EMAC0, 0x01);
  #endif
  	return rc;
  }