mirror of
https://github.com/u-boot/u-boot.git
synced 2024-12-11 21:53:29 +08:00
kirkwood: implement kw_sdram_size_adjust
Size of the SDRAM chips might differ between any two (otherwise identical) instances of the same board. So add a function kw_sdram_size_adjust() which reads out the current ram size for a given bank, and adjusts the Kirkwood's SDRAM window size register accordingly. Signed-off-by: Gerlando Falauto <gerlando.falauto@keymile.com> Signed-off-by: Holger Brunck <holger.brunck@keymile.com> cc: Prafulla Wadaskar <prafulla@marvell.com> cc: Valentin Longchamp <valentin.longchamp@keymile.com>
This commit is contained in:
parent
4551516525
commit
b3168f4be8
@ -97,6 +97,17 @@ u32 kw_sdram_bs(enum memory_bank bank)
|
||||
return result;
|
||||
}
|
||||
|
||||
void kw_sdram_size_adjust(enum memory_bank bank)
|
||||
{
|
||||
u32 size;
|
||||
|
||||
/* probe currently equipped RAM size */
|
||||
size = get_ram_size((void *)kw_sdram_bar(bank), kw_sdram_bs(bank));
|
||||
|
||||
/* adjust SDRAM window size accordingly */
|
||||
kw_sdram_bs_set(bank, size);
|
||||
}
|
||||
|
||||
#ifndef CONFIG_SYS_BOARD_DRAM_INIT
|
||||
int dram_init(void)
|
||||
{
|
||||
|
@ -159,6 +159,7 @@ void reset_cpu(unsigned long ignored);
|
||||
unsigned char get_random_hex(void);
|
||||
unsigned int kw_sdram_bar(enum memory_bank bank);
|
||||
unsigned int kw_sdram_bs(enum memory_bank bank);
|
||||
void kw_sdram_size_adjust(enum memory_bank bank);
|
||||
int kw_config_adr_windows(void);
|
||||
void kw_config_gpio(unsigned int gpp0_oe_val, unsigned int gpp1_oe_val,
|
||||
unsigned int gpp0_oe, unsigned int gpp1_oe);
|
||||
|
Loading…
Reference in New Issue
Block a user