2023-06-21 11:53:32 +03:00
|
|
|
/*
|
|
|
|
* QEMU Motorla 680x0 Macintosh hardware System Emulator
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
|
|
* in the Software without restriction, including without limitation the rights
|
|
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
|
|
* furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
* THE SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef HW_Q800_H
|
|
|
|
#define HW_Q800_H
|
|
|
|
|
|
|
|
#include "hw/boards.h"
|
|
|
|
#include "qom/object.h"
|
2023-06-21 11:53:34 +03:00
|
|
|
#include "target/m68k/cpu-qom.h"
|
2023-06-21 11:53:35 +03:00
|
|
|
#include "exec/memory.h"
|
2023-06-21 11:53:38 +03:00
|
|
|
#include "hw/m68k/q800-glue.h"
|
2023-06-21 11:53:41 +03:00
|
|
|
#include "hw/misc/mac_via.h"
|
2023-06-21 11:53:44 +03:00
|
|
|
#include "hw/net/dp8393x.h"
|
2023-06-21 11:53:45 +03:00
|
|
|
#include "hw/char/escc.h"
|
2023-06-21 11:53:46 +03:00
|
|
|
#include "hw/or-irq.h"
|
2023-06-21 11:53:47 +03:00
|
|
|
#include "hw/scsi/esp.h"
|
2023-06-21 11:53:48 +03:00
|
|
|
#include "hw/block/swim.h"
|
2023-06-21 11:53:49 +03:00
|
|
|
#include "hw/nubus/mac-nubus-bridge.h"
|
2023-06-21 11:53:51 +03:00
|
|
|
#include "hw/display/macfb.h"
|
2023-10-04 11:37:48 +03:00
|
|
|
#include "hw/misc/djmemc.h"
|
2023-10-04 11:37:51 +03:00
|
|
|
#include "hw/misc/iosb.h"
|
2023-10-04 11:37:55 +03:00
|
|
|
#include "hw/audio/asc.h"
|
2023-06-21 11:53:32 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* The main Q800 machine
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct Q800MachineState {
|
|
|
|
MachineState parent_obj;
|
2023-06-21 11:53:34 +03:00
|
|
|
|
2023-10-04 11:37:56 +03:00
|
|
|
bool easc;
|
2023-06-21 11:53:34 +03:00
|
|
|
M68kCPU cpu;
|
2023-06-21 11:53:35 +03:00
|
|
|
MemoryRegion rom;
|
2023-10-04 11:38:05 +03:00
|
|
|
MemoryRegion rom_alias;
|
2023-06-21 11:53:38 +03:00
|
|
|
GLUEState glue;
|
2023-06-21 11:53:41 +03:00
|
|
|
MOS6522Q800VIA1State via1;
|
2023-06-21 11:53:42 +03:00
|
|
|
MOS6522Q800VIA2State via2;
|
2023-06-21 11:53:44 +03:00
|
|
|
dp8393xState dp8393x;
|
2023-06-21 11:53:45 +03:00
|
|
|
ESCCState escc;
|
2023-06-21 11:53:46 +03:00
|
|
|
OrIRQState escc_orgate;
|
2023-06-21 11:53:47 +03:00
|
|
|
SysBusESPState esp;
|
2023-06-21 11:53:48 +03:00
|
|
|
Swim swim;
|
2023-06-21 11:53:49 +03:00
|
|
|
MacNubusBridge mac_nubus_bridge;
|
2023-06-21 11:53:51 +03:00
|
|
|
MacfbNubusState macfb;
|
2023-10-04 11:37:48 +03:00
|
|
|
DJMEMCState djmemc;
|
2023-10-04 11:37:51 +03:00
|
|
|
IOSBState iosb;
|
2023-10-04 11:37:55 +03:00
|
|
|
ASCState asc;
|
2023-10-04 11:37:52 +03:00
|
|
|
MemoryRegion ramio;
|
2023-06-21 11:53:39 +03:00
|
|
|
MemoryRegion macio;
|
2023-06-21 11:53:40 +03:00
|
|
|
MemoryRegion macio_alias;
|
2023-10-04 11:37:49 +03:00
|
|
|
MemoryRegion machine_id;
|
2023-10-04 11:38:04 +03:00
|
|
|
MemoryRegion escc_alias;
|
2023-06-21 11:53:32 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
#define TYPE_Q800_MACHINE MACHINE_TYPE_NAME("q800")
|
|
|
|
OBJECT_DECLARE_SIMPLE_TYPE(Q800MachineState, Q800_MACHINE)
|
|
|
|
|
|
|
|
#endif
|