blob: aa1ceba410bc329fb8c4a39753825852034cc6a0 [file] [log] [blame]
Stefan Reinauer597ff872013-01-07 13:21:22 -08001/*
2 * This file is part of the coreboot project.
3 *
4 * Copyright (C) 2004 Stefan Reinauer <stefan.reinauer@coreboot.org>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
Stefan Reinauer597ff872013-01-07 13:21:22 -080014 */
15
16#include <cbmem.h>
Patrick Rudolph69d5ef92018-11-11 12:43:48 +010017#include <arch/io.h>
18#include "memory.h"
Thomas Heijligen8d010db2019-01-10 19:45:47 +010019#include "fw_cfg.h"
Stefan Reinauer597ff872013-01-07 13:21:22 -080020
21#define CMOS_ADDR_PORT 0x70
22#define CMOS_DATA_PORT 0x71
Gerd Hoffmann9839a382013-06-17 12:26:17 +020023
Stefan Reinauer597ff872013-01-07 13:21:22 -080024#define HIGH_RAM_ADDR 0x35
25#define LOW_RAM_ADDR 0x34
26
Gerd Hoffmann9839a382013-06-17 12:26:17 +020027#define HIGH_HIGHRAM_ADDR 0x5d
28#define MID_HIGHRAM_ADDR 0x5c
29#define LOW_HIGHRAM_ADDR 0x5b
30
Patrick Rudolph69d5ef92018-11-11 12:43:48 +010031unsigned long qemu_get_high_memory_size(void)
32{
33 unsigned long high;
34 outb(HIGH_HIGHRAM_ADDR, CMOS_ADDR_PORT);
35 high = ((unsigned long) inb(CMOS_DATA_PORT)) << 22;
36 outb(MID_HIGHRAM_ADDR, CMOS_ADDR_PORT);
37 high |= ((unsigned long) inb(CMOS_DATA_PORT)) << 14;
38 outb(LOW_HIGHRAM_ADDR, CMOS_ADDR_PORT);
39 high |= ((unsigned long) inb(CMOS_DATA_PORT)) << 6;
40 return high;
41}
42
43unsigned long qemu_get_memory_size(void)
Stefan Reinauer597ff872013-01-07 13:21:22 -080044{
45 unsigned long tomk;
Patrick Rudolph69d5ef92018-11-11 12:43:48 +010046 outb(HIGH_RAM_ADDR, CMOS_ADDR_PORT);
Stefan Reinauer597ff872013-01-07 13:21:22 -080047 tomk = ((unsigned long) inb(CMOS_DATA_PORT)) << 14;
Patrick Rudolph69d5ef92018-11-11 12:43:48 +010048 outb(LOW_RAM_ADDR, CMOS_ADDR_PORT);
Stefan Reinauer597ff872013-01-07 13:21:22 -080049 tomk |= ((unsigned long) inb(CMOS_DATA_PORT)) << 6;
50 tomk += 16 * 1024;
51 return tomk;
52}
53
Kyösti Mälkkif1e3c762014-12-22 12:28:07 +020054void *cbmem_top(void)
Stefan Reinauer597ff872013-01-07 13:21:22 -080055{
Thomas Heijligen8d010db2019-01-10 19:45:47 +010056 uintptr_t top = 0;
57
58 top = fw_cfg_tolud();
59 if (!top)
60 top = (uintptr_t)qemu_get_memory_size() * 1024;
61
62 return (void *)top;
Stefan Reinauer597ff872013-01-07 13:21:22 -080063}