rewrite memory size detection
SVN-Revision: 13198
This commit is contained in:
parent
2b10284b62
commit
d1c40911eb
1 changed files with 6 additions and 20 deletions
|
@ -85,28 +85,14 @@ int __init ar71xx_pci_init(unsigned nr_irqs, struct ar71xx_pci_irq *map)
|
|||
|
||||
static void __init ar71xx_detect_mem_size(void)
|
||||
{
|
||||
volatile u8 *p;
|
||||
u8 memsave;
|
||||
u32 size;
|
||||
unsigned long size;
|
||||
|
||||
p = (volatile u8 *) KSEG1ADDR(0);
|
||||
memsave = *p;
|
||||
for (size = AR71XX_MEM_SIZE_MIN;
|
||||
size <= (AR71XX_MEM_SIZE_MAX >> 1); size <<= 1) {
|
||||
volatile u8 *r;
|
||||
|
||||
r = (p + size);
|
||||
*p = 0x55;
|
||||
if (*r == 0x55) {
|
||||
/* Mirrored data found, try another pattern */
|
||||
*p = 0xAA;
|
||||
if (*r == 0xAA) {
|
||||
/* Mirrored data found again, stop detection */
|
||||
break;
|
||||
}
|
||||
}
|
||||
for (size = AR71XX_MEM_SIZE_MIN; size < AR71XX_MEM_SIZE_MAX;
|
||||
size <<= 1 ) {
|
||||
if (!memcmp(ar71xx_detect_mem_size,
|
||||
ar71xx_detect_mem_size + size, 1024))
|
||||
break;
|
||||
}
|
||||
*p = memsave;
|
||||
|
||||
add_memory_region(0, size, BOOT_MEM_RAM);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue