cachepc-qemu

Fork of AMDESE/qemu with changes for cachepc side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-qemu
Log | Files | Refs | Submodules | LICENSE | sfeed.txt

nubus.h (1650B)


      1/*
      2 * Copyright (c) 2013-2018 Laurent Vivier <laurent@vivier.eu>
      3 *
      4 * This work is licensed under the terms of the GNU GPL, version 2 or later.
      5 * See the COPYING file in the top-level directory.
      6 *
      7 */
      8
      9#ifndef HW_NUBUS_NUBUS_H
     10#define HW_NUBUS_NUBUS_H
     11
     12#include "hw/qdev-properties.h"
     13#include "hw/sysbus.h"
     14#include "exec/address-spaces.h"
     15#include "qom/object.h"
     16#include "qemu/units.h"
     17
     18#define NUBUS_SUPER_SLOT_SIZE 0x10000000U
     19#define NUBUS_SUPER_SLOT_NB   0xe
     20
     21#define NUBUS_SLOT_BASE       (NUBUS_SUPER_SLOT_SIZE * \
     22                               (NUBUS_SUPER_SLOT_NB + 1))
     23
     24#define NUBUS_SLOT_SIZE       0x01000000
     25#define NUBUS_FIRST_SLOT      0x0
     26#define NUBUS_LAST_SLOT       0xf
     27#define NUBUS_SLOT_NB         (NUBUS_LAST_SLOT - NUBUS_FIRST_SLOT + 1)
     28
     29#define NUBUS_IRQS            16
     30
     31#define TYPE_NUBUS_DEVICE "nubus-device"
     32OBJECT_DECLARE_SIMPLE_TYPE(NubusDevice, NUBUS_DEVICE)
     33
     34#define TYPE_NUBUS_BUS "nubus-bus"
     35OBJECT_DECLARE_SIMPLE_TYPE(NubusBus, NUBUS_BUS)
     36
     37#define TYPE_NUBUS_BRIDGE "nubus-bridge"
     38OBJECT_DECLARE_SIMPLE_TYPE(NubusBridge, NUBUS_BRIDGE);
     39
     40struct NubusBus {
     41    BusState qbus;
     42
     43    AddressSpace nubus_as;
     44    MemoryRegion nubus_mr;
     45
     46    MemoryRegion super_slot_io;
     47    MemoryRegion slot_io;
     48
     49    uint16_t slot_available_mask;
     50
     51    qemu_irq irqs[NUBUS_IRQS];
     52};
     53
     54#define NUBUS_DECL_ROM_MAX_SIZE    (128 * KiB)
     55
     56struct NubusDevice {
     57    DeviceState qdev;
     58
     59    int32_t slot;
     60    MemoryRegion super_slot_mem;
     61    MemoryRegion slot_mem;
     62
     63    char *romfile;
     64    MemoryRegion decl_rom;
     65};
     66
     67void nubus_set_irq(NubusDevice *nd, int level);
     68
     69struct NubusBridge {
     70    SysBusDevice parent_obj;
     71
     72    NubusBus bus;
     73};
     74
     75#endif