 8110fa1d94
			
		
	
	
		8110fa1d94
		
	
	
	
	
		
			
			Generated using: $ ./scripts/codeconverter/converter.py -i \ --pattern=TypeCheckMacro $(git grep -l '' -- '*.[ch]') Reviewed-by: Daniel P. Berrangé <berrange@redhat.com> Reviewed-by: Juan Quintela <quintela@redhat.com> Message-Id: <20200831210740.126168-12-ehabkost@redhat.com> Reviewed-by: Juan Quintela <quintela@redhat.com> Message-Id: <20200831210740.126168-13-ehabkost@redhat.com> Message-Id: <20200831210740.126168-14-ehabkost@redhat.com> Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
		
			
				
	
	
		
			73 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 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   0x9
 | |
| 
 | |
| #define NUBUS_SLOT_SIZE       0x01000000
 | |
| #define NUBUS_SLOT_NB         0xF
 | |
| 
 | |
| #define NUBUS_FIRST_SLOT      0x9
 | |
| #define NUBUS_LAST_SLOT       0xF
 | |
| 
 | |
| #define TYPE_NUBUS_DEVICE "nubus-device"
 | |
| typedef struct NubusDevice NubusDevice;
 | |
| DECLARE_INSTANCE_CHECKER(NubusDevice, NUBUS_DEVICE,
 | |
|                          TYPE_NUBUS_DEVICE)
 | |
| 
 | |
| #define TYPE_NUBUS_BUS "nubus-bus"
 | |
| typedef struct NubusBus NubusBus;
 | |
| DECLARE_INSTANCE_CHECKER(NubusBus, NUBUS_BUS,
 | |
|                          TYPE_NUBUS_BUS)
 | |
| 
 | |
| #define TYPE_NUBUS_BRIDGE "nubus-bridge"
 | |
| 
 | |
| struct NubusBus {
 | |
|     BusState qbus;
 | |
| 
 | |
|     MemoryRegion super_slot_io;
 | |
|     MemoryRegion slot_io;
 | |
| 
 | |
|     int current_slot;
 | |
| };
 | |
| 
 | |
| struct NubusDevice {
 | |
|     DeviceState qdev;
 | |
| 
 | |
|     int slot_nb;
 | |
|     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
 |