mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 16:23:55 -06:00

Convert nubus_device_realize() to use a bitmap to manage available slots to allow for future Nubus devices to be plugged into arbitrary slots from the command line using a new qdev "slot" parameter for nubus devices. Update mac_nubus_bridge_init() to only allow slots 0x9 to 0xe on Macintosh machines as documented in "Designing Cards and Drivers for the Macintosh Family". Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Message-Id: <20210924073808.1041-5-mark.cave-ayland@ilande.co.uk> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
68 lines
1.5 KiB
C
68 lines
1.5 KiB
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_NUBUS_H
|
|
#define HW_NUBUS_NUBUS_H
|
|
|
|
#include "hw/qdev-properties.h"
|
|
#include "exec/address-spaces.h"
|
|
#include "qom/object.h"
|
|
|
|
#define NUBUS_SUPER_SLOT_SIZE 0x10000000U
|
|
#define NUBUS_SUPER_SLOT_NB 0xe
|
|
|
|
#define NUBUS_SLOT_SIZE 0x01000000
|
|
#define NUBUS_FIRST_SLOT 0x0
|
|
#define NUBUS_LAST_SLOT 0xf
|
|
#define NUBUS_SLOT_NB (NUBUS_LAST_SLOT - NUBUS_FIRST_SLOT + 1)
|
|
|
|
#define TYPE_NUBUS_DEVICE "nubus-device"
|
|
OBJECT_DECLARE_SIMPLE_TYPE(NubusDevice, NUBUS_DEVICE)
|
|
|
|
#define TYPE_NUBUS_BUS "nubus-bus"
|
|
OBJECT_DECLARE_SIMPLE_TYPE(NubusBus, NUBUS_BUS)
|
|
|
|
#define TYPE_NUBUS_BRIDGE "nubus-bridge"
|
|
|
|
struct NubusBus {
|
|
BusState qbus;
|
|
|
|
MemoryRegion super_slot_io;
|
|
MemoryRegion slot_io;
|
|
|
|
uint16_t slot_available_mask;
|
|
};
|
|
|
|
struct NubusDevice {
|
|
DeviceState qdev;
|
|
|
|
int32_t slot;
|
|
MemoryRegion super_slot_mem;
|
|
MemoryRegion slot_mem;
|
|
|
|
/* Format Block */
|
|
|
|
MemoryRegion fblock_io;
|
|
|
|
uint32_t rom_length;
|
|
uint32_t rom_crc;
|
|
uint8_t rom_rev;
|
|
uint8_t rom_format;
|
|
uint8_t byte_lanes;
|
|
int32_t directory_offset;
|
|
|
|
/* ROM */
|
|
|
|
MemoryRegion rom_io;
|
|
const uint8_t *rom;
|
|
};
|
|
|
|
void nubus_register_rom(NubusDevice *dev, const uint8_t *rom, uint32_t size,
|
|
int revision, int format, uint8_t byte_lanes);
|
|
|
|
#endif
|