mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-03 15:53:54 -06:00

According to "Designing Cards and Drivers for the Macintosh Family" the Nubus has its own 32-bit address space based upon physical slot addressing. Move Nubus to its own 32-bit address space and then use memory region aliases to map available slot and super slot ranges into the q800 system address space via the Macintosh Nubus bridge. Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Message-Id: <20210924073808.1041-13-mark.cave-ayland@ilande.co.uk> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
30 lines
707 B
C
30 lines
707 B
C
/*
|
|
* Copyright (c) 2013-2018 Laurent Vivier <laurent@vivier.eu>
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#ifndef HW_NUBUS_MAC_H
|
|
#define HW_NUBUS_MAC_H
|
|
|
|
#include "hw/nubus/nubus.h"
|
|
#include "qom/object.h"
|
|
|
|
#define MAC_NUBUS_FIRST_SLOT 0x9
|
|
#define MAC_NUBUS_LAST_SLOT 0xe
|
|
#define MAC_NUBUS_SLOT_NB (MAC_NUBUS_LAST_SLOT - MAC_NUBUS_FIRST_SLOT + 1)
|
|
|
|
#define TYPE_MAC_NUBUS_BRIDGE "mac-nubus-bridge"
|
|
OBJECT_DECLARE_SIMPLE_TYPE(MacNubusState, MAC_NUBUS_BRIDGE)
|
|
|
|
struct MacNubusState {
|
|
SysBusDevice sysbus_dev;
|
|
|
|
NubusBus *bus;
|
|
MemoryRegion super_slot_alias;
|
|
MemoryRegion slot_alias;
|
|
};
|
|
|
|
#endif
|