blob: 02a46cae3d894d01f4eeb079ad5d857ee19f3b0d [file] [log] [blame]
Mike Frysinger8b219cf2008-10-12 21:54:07 -04001/*
Bin Menga1875592016-02-05 19:30:11 -08002 * U-Boot - Configuration file for cm-bf548 board
Mike Frysinger8b219cf2008-10-12 21:54:07 -04003 */
4
5#ifndef __CONFIG_CM_BF548_H__
6#define __CONFIG_CM_BF548_H__
7
Mike Frysingerf348ab82009-04-24 17:22:40 -04008#include <asm/config-pre.h>
Mike Frysinger8b219cf2008-10-12 21:54:07 -04009
Mike Frysinger8b219cf2008-10-12 21:54:07 -040010/*
11 * Processor Settings
12 */
Mike Frysingerfbcf8e82010-12-23 14:58:37 -050013#define CONFIG_BFIN_CPU bf548-0.0
Mike Frysinger8b219cf2008-10-12 21:54:07 -040014#define CONFIG_BFIN_BOOT_MODE BFIN_BOOT_PARA
15
Mike Frysinger8b219cf2008-10-12 21:54:07 -040016/*
17 * Clock Settings
18 * CCLK = (CLKIN * VCO_MULT) / CCLK_DIV
19 * SCLK = (CLKIN * VCO_MULT) / SCLK_DIV
20 */
21/* CONFIG_CLKIN_HZ is any value in Hz */
22#define CONFIG_CLKIN_HZ 25000000
23/* CLKIN_HALF controls the DF bit in PLL_CTL 0 = CLKIN */
24/* 1 = CLKIN / 2 */
25#define CONFIG_CLKIN_HALF 0
26/* PLL_BYPASS controls the BYPASS bit in PLL_CTL 0 = do not bypass */
27/* 1 = bypass PLL */
28#define CONFIG_PLL_BYPASS 0
29/* VCO_MULT controls the MSEL (multiplier) bits in PLL_CTL */
30/* Values can range from 0-63 (where 0 means 64) */
31#define CONFIG_VCO_MULT 21
32/* CCLK_DIV controls the core clock divider */
33/* Values can be 1, 2, 4, or 8 ONLY */
34#define CONFIG_CCLK_DIV 1
35/* SCLK_DIV controls the system clock divider */
36/* Values can range from 1-15 */
37#define CONFIG_SCLK_DIV 4
38
Harald Krapfenbauerfd04a052009-10-14 08:37:32 -040039/* Decrease core voltage */
40#define CONFIG_VR_CTL_VAL (VLEV_115 | GAIN_20 | FREQ_1000)
41
Mike Frysinger8b219cf2008-10-12 21:54:07 -040042/*
43 * Memory Settings
44 */
45#define CONFIG_MEM_ADD_WDTH 10
46#define CONFIG_MEM_SIZE 64
47
48#define CONFIG_EBIU_DDRCTL0_VAL 0x218A83FE
49#define CONFIG_EBIU_DDRCTL1_VAL 0x20022222
50#define CONFIG_EBIU_DDRCTL2_VAL 0x00000021
51
52/* Default bank mapping:
53 * Async Bank 0 - 32MB Burst Flash
54 * Async Bank 1 - Ethernet
55 * Async Bank 2 - Nothing
56 * Async Bank 3 - Nothing
57 */
58#define CONFIG_EBIU_AMGCTL_VAL 0xFF
59#define CONFIG_EBIU_AMBCTL0_VAL 0x7BB07BB0
60#define CONFIG_EBIU_AMBCTL1_VAL 0xFFC27BB0
61#define CONFIG_EBIU_FCTL_VAL (BCLK_4)
62#define CONFIG_EBIU_MODE_VAL (B0MODE_FLASH)
63
Mike Frysinger98ae6072010-08-02 16:30:39 -040064#define CONFIG_SYS_MONITOR_LEN (512 * 1024)
Mike Frysinger8b219cf2008-10-12 21:54:07 -040065#define CONFIG_SYS_MALLOC_LEN (640 * 1024)
66
Mike Frysinger8b219cf2008-10-12 21:54:07 -040067/*
68 * Network Settings
69 */
70#define ADI_CMDS_NETWORK 1
Ben Warren736fead2009-07-20 22:01:11 -070071#define CONFIG_SMC911X 1
72#define CONFIG_SMC911X_BASE 0x24000000
73#define CONFIG_SMC911X_16_BIT
Mike Frysinger8b219cf2008-10-12 21:54:07 -040074#define CONFIG_HOSTNAME cm-bf548
Mike Frysinger8b219cf2008-10-12 21:54:07 -040075
Mike Frysinger8b219cf2008-10-12 21:54:07 -040076/*
77 * Flash Settings
78 */
79#define CONFIG_FLASH_CFI_DRIVER
80#define CONFIG_SYS_FLASH_BASE 0x20000000
81#define CONFIG_SYS_FLASH_CFI
82#define CONFIG_SYS_FLASH_PROTECTION
83#define CONFIG_SYS_MAX_FLASH_BANKS 1
84#define CONFIG_SYS_MAX_FLASH_SECT 259
85
Mike Frysinger8b219cf2008-10-12 21:54:07 -040086/*
87 * Env Storage Settings
88 */
89#define CONFIG_ENV_IS_IN_FLASH 1
90#define CONFIG_ENV_ADDR 0x20008000
91#define CONFIG_ENV_OFFSET 0x8000
92#define CONFIG_ENV_SIZE 0x8000
Mike Frysinger76d82182009-07-21 22:17:36 -040093#define CONFIG_ENV_IS_EMBEDDED_IN_LDR
Mike Frysinger8b219cf2008-10-12 21:54:07 -040094
Mike Frysinger8b219cf2008-10-12 21:54:07 -040095/*
96 * I2C Settings
97 */
Scott Jiangc4697032014-11-13 15:30:55 +080098#define CONFIG_SYS_I2C
Scott Jiangfea9b692014-11-13 15:30:53 +080099#define CONFIG_SYS_I2C_ADI
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400100
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400101/*
102 * Misc Settings
103 */
104#define CONFIG_BAUDRATE 115200
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400105#define CONFIG_RTC_BFIN
106#define CONFIG_UART_CONSOLE 1
Harald Krapfenbauerfd04a052009-10-14 08:37:32 -0400107#define CONFIG_BOOTCOMMAND "run flashboot"
108#define FLASHBOOT_ENV_SETTINGS "flashboot=bootm 0x20040000\0"
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400109
Sonic Zhange45eb6b2013-11-18 14:01:38 +0800110#define CONFIG_ADI_GPIO2
111
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400112#ifndef __ADSPBF542__
113/* Don't waste time transferring a logo over the UART */
114# if (CONFIG_BFIN_BOOT_MODE != BFIN_BOOT_UART)
Mike Frysinger42c6e9a2012-02-03 20:44:54 -0500115# define EASYLOGO_HEADER <asm/bfin_logo_230x230_gzip.h>
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400116# endif
117# define CONFIG_DEB_DMA_URGENT
118#endif
119
120/* Define if want to do post memory test */
121#undef CONFIG_POST
122#ifdef CONFIG_POST
123#define FLASH_START_POST_BLOCK 11 /* Should > = 11 */
124#define FLASH_END_POST_BLOCK 71 /* Should < = 71 */
125#endif
126
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400127/*
128 * Pull in common ADI header for remaining command/environment setup
129 */
130#include <configs/bfin_adi_common.h>
131
Mike Frysinger8b219cf2008-10-12 21:54:07 -0400132#endif