-
Notifications
You must be signed in to change notification settings - Fork 4
/
sample.c
108 lines (92 loc) · 3.12 KB
/
sample.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/*
* QEMU AVR CPU
*
* Copyright (c) 2016 Michael Rolnik
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, see
* <http://www.gnu.org/licenses/lgpl-2.1.html>
*/
/*
* NOTE:
* This is not a real AVR board !!! This is an example !!!
*
* This example can be used to build a real AVR board.
*
* This example board loads provided binary file into flash memory and
* executes it from 0x00000000 address in the code memory space.
*
* Currently used for AVR CPU validation
*
*/
#include "qemu/osdep.h"
#include "qapi/error.h"
#include "qemu-common.h"
#include "cpu.h"
#include "hw/hw.h"
#include "sysemu/sysemu.h"
#include "sysemu/qtest.h"
#include "ui/console.h"
#include "hw/boards.h"
#include "hw/devices.h"
#include "hw/loader.h"
#include "qemu/error-report.h"
#include "exec/address-spaces.h"
#include "include/hw/sysbus.h"
#define VIRT_BASE_FLASH 0x00000000
#define VIRT_BASE_ISRAM 0x00000100
#define VIRT_BASE_EXMEM 0x00001100
#define VIRT_BASE_EEPROM 0x00000000
#define SIZE_FLASH 0x00020000
#define SIZE_ISRAM 0x00001000
#define SIZE_EXMEM 0x00010000
#define SIZE_EEPROM 0x00001000
#define SIZE_IOREG SIZE_REGS
#define PHYS_BASE_FLASH (PHYS_BASE_CODE)
#define PHYS_BASE_ISRAM (PHYS_BASE_DATA)
#define PHYS_BASE_EXMEM (PHYS_BASE_ISRAM + SIZE_ISRAM)
#define PHYS_BASE_EEPROM (PHYS_BASE_EXMEM + SIZE_EXMEM)
#define PHYS_BASE_IOREG (PHYS_BASE_REGS + 0x20)
static void sample_init(MachineState *machine)
{
MemoryRegion *address_space_mem;
MemoryRegion *ram;
MemoryRegion *flash;
unsigned ram_size = SIZE_ISRAM + SIZE_EXMEM;
AVRCPU *cpu_avr ATTRIBUTE_UNUSED;
const char *firmware = NULL;
const char *filename;
address_space_mem = get_system_memory();
ram = g_new(MemoryRegion, 1);
flash = g_new(MemoryRegion, 1);
cpu_avr = cpu_avr_init("avr5");
memory_region_allocate_system_memory(ram, NULL, "avr.ram", ram_size);
memory_region_add_subregion(address_space_mem, PHYS_BASE_ISRAM, ram);
memory_region_init_rom(flash, NULL, "avr.flash", SIZE_FLASH, &error_fatal);
memory_region_add_subregion(address_space_mem, PHYS_BASE_FLASH, flash);
vmstate_register_ram_global(flash);
if (machine->firmware) {
firmware = machine->firmware;
}
filename = qemu_find_file(QEMU_FILE_TYPE_BIOS, firmware);
if (filename) {
load_image_targphys(filename, PHYS_BASE_FLASH, SIZE_FLASH);
}
}
static void sample_machine_init(MachineClass *mc)
{
mc->desc = "AVR sample/example board";
mc->init = sample_init;
mc->is_default = 1;
}
DEFINE_MACHINE("sample", sample_machine_init)