File: nubus.h

package info (click to toggle)
qemu 1%3A10.1.2%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 415,964 kB
  • sloc: ansic: 4,763,605; pascal: 115,173; python: 105,698; asm: 68,687; sh: 53,146; makefile: 27,519; perl: 18,863; cpp: 11,443; xml: 3,629; objc: 2,877; yacc: 2,505; php: 1,299; tcl: 1,296; lex: 1,110; sql: 71; awk: 43; sed: 35; javascript: 7
file content (75 lines) | stat: -rw-r--r-- 1,650 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
 * 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 "hw/sysbus.h"
#include "system/address-spaces.h"
#include "qom/object.h"
#include "qemu/units.h"

#define NUBUS_SUPER_SLOT_SIZE 0x10000000U
#define NUBUS_SUPER_SLOT_NB   0xe

#define NUBUS_SLOT_BASE       (NUBUS_SUPER_SLOT_SIZE * \
                               (NUBUS_SUPER_SLOT_NB + 1))

#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 NUBUS_IRQS            16

#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"
OBJECT_DECLARE_SIMPLE_TYPE(NubusBridge, NUBUS_BRIDGE);

struct NubusBus {
    BusState qbus;

    AddressSpace nubus_as;
    MemoryRegion nubus_mr;

    MemoryRegion super_slot_io;
    MemoryRegion slot_io;

    uint16_t slot_available_mask;

    qemu_irq irqs[NUBUS_IRQS];
};

#define NUBUS_DECL_ROM_MAX_SIZE    (1 * MiB)

struct NubusDevice {
    DeviceState qdev;

    int32_t slot;
    MemoryRegion super_slot_mem;
    MemoryRegion slot_mem;

    char *romfile;
    MemoryRegion decl_rom;
};

void nubus_set_irq(NubusDevice *nd, int level);

struct NubusBridge {
    SysBusDevice parent_obj;

    NubusBus bus;
};

#endif