blob: ce8024c1a54e1448aab41f052d46a2e78afffd3e [file] [log] [blame]
Thomas Gleixnerfd534e92019-05-23 11:14:39 +02001// SPDX-License-Identifier: GPL-2.0-or-later
Florian Fainelli7ca5dc12009-06-24 11:12:57 +02002/*
3 * Copyright (C) 2007 Felix Fietkau <nbd@openwrt.org>
4 * Copyright (C) 2007 Eugene Konev <ejka@openwrt.org>
Florian Fainelli7ca5dc12009-06-24 11:12:57 +02005 */
Mike Rapoport57c8a662018-10-30 15:09:49 -07006#include <linux/memblock.h>
Florian Fainelli7ca5dc12009-06-24 11:12:57 +02007#include <linux/init.h>
8#include <linux/mm.h>
Florian Fainelli7ca5dc12009-06-24 11:12:57 +02009#include <linux/pfn.h>
10#include <linux/proc_fs.h>
11#include <linux/string.h>
12#include <linux/swap.h>
13
14#include <asm/bootinfo.h>
15#include <asm/page.h>
16#include <asm/sections.h>
17
18#include <asm/mach-ar7/ar7.h>
Florian Fainelli7ca5dc12009-06-24 11:12:57 +020019
20static int __init memsize(void)
21{
22 u32 size = (64 << 20);
23 u32 *addr = (u32 *)KSEG1ADDR(AR7_SDRAM_BASE + size - 4);
24 u32 *kernel_end = (u32 *)KSEG1ADDR(CPHYSADDR((u32)&_end));
25 u32 *tmpaddr = addr;
26
27 while (tmpaddr > kernel_end) {
28 *tmpaddr = (u32)tmpaddr;
29 size >>= 1;
30 tmpaddr -= size >> 2;
31 }
32
33 do {
34 tmpaddr += size >> 2;
35 if (*tmpaddr != (u32)tmpaddr)
36 break;
37 size <<= 1;
38 } while (size < (64 << 20));
39
Florian Fainellidd34b5a2009-07-21 12:38:10 +020040 writel((u32)tmpaddr, &addr);
Florian Fainelli7ca5dc12009-06-24 11:12:57 +020041
42 return size;
43}
44
45void __init prom_meminit(void)
46{
47 unsigned long pages;
48
49 pages = memsize() >> PAGE_SHIFT;
Thomas Bogendoerfere7ae8d12020-10-09 14:14:46 +020050 memblock_add(PHYS_OFFSET, pages << PAGE_SHIFT);
Florian Fainelli7ca5dc12009-06-24 11:12:57 +020051}