mirror of https://gitlab.com/qemu-project/qemu
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
51 lines
1.3 KiB
C
51 lines
1.3 KiB
C
/*
|
|
* MAX78000FTHR Evaluation Board
|
|
*
|
|
* Copyright (c) 2025 Jackson Donaldson <jcksn@duck.com>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
*/
|
|
|
|
#include "qemu/osdep.h"
|
|
#include "qapi/error.h"
|
|
#include "hw/boards.h"
|
|
#include "hw/qdev-properties.h"
|
|
#include "hw/qdev-clock.h"
|
|
#include "qemu/error-report.h"
|
|
#include "hw/arm/max78000_soc.h"
|
|
#include "hw/arm/boot.h"
|
|
|
|
/* 60MHz is the default, but other clocks can be selected. */
|
|
#define SYSCLK_FRQ 60000000ULL
|
|
static void max78000_init(MachineState *machine)
|
|
{
|
|
DeviceState *dev;
|
|
Clock *sysclk;
|
|
|
|
sysclk = clock_new(OBJECT(machine), "SYSCLK");
|
|
clock_set_hz(sysclk, SYSCLK_FRQ);
|
|
|
|
dev = qdev_new(TYPE_MAX78000_SOC);
|
|
object_property_add_child(OBJECT(machine), "soc", OBJECT(dev));
|
|
qdev_connect_clock_in(dev, "sysclk", sysclk);
|
|
sysbus_realize_and_unref(SYS_BUS_DEVICE(dev), &error_fatal);
|
|
|
|
armv7m_load_kernel(ARM_CPU(first_cpu),
|
|
machine->kernel_filename,
|
|
0x00000000, FLASH_SIZE);
|
|
}
|
|
|
|
static void max78000_machine_init(MachineClass *mc)
|
|
{
|
|
static const char * const valid_cpu_types[] = {
|
|
ARM_CPU_TYPE_NAME("cortex-m4"),
|
|
NULL
|
|
};
|
|
|
|
mc->desc = "MAX78000FTHR Board (Cortex-M4 / (Unimplemented) RISC-V)";
|
|
mc->init = max78000_init;
|
|
mc->valid_cpu_types = valid_cpu_types;
|
|
}
|
|
|
|
DEFINE_MACHINE("max78000fthr", max78000_machine_init)
|