summaryrefslogtreecommitdiffstats
path: root/include/hw/remote/iohub.h
blob: 0bf98e0d78c75bb51c98579b6fe01173cadf4b2a (plain) (blame)
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
/*
 * IO Hub for remote device
 *
 * Copyright © 2018, 2021 Oracle and/or its affiliates.
 *
 * 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 REMOTE_IOHUB_H
#define REMOTE_IOHUB_H

#include "hw/pci/pci.h"
#include "qemu/event_notifier.h"
#include "qemu/thread-posix.h"
#include "hw/remote/mpqemu-link.h"

#define REMOTE_IOHUB_NB_PIRQS    PCI_DEVFN_MAX

typedef struct ResampleToken {
    void *iohub;
    int pirq;
} ResampleToken;

typedef struct RemoteIOHubState {
    PCIDevice d;
    EventNotifier irqfds[REMOTE_IOHUB_NB_PIRQS];
    EventNotifier resamplefds[REMOTE_IOHUB_NB_PIRQS];
    unsigned int irq_level[REMOTE_IOHUB_NB_PIRQS];
    ResampleToken token[REMOTE_IOHUB_NB_PIRQS];
    QemuMutex irq_level_lock[REMOTE_IOHUB_NB_PIRQS];
} RemoteIOHubState;

int remote_iohub_map_irq(PCIDevice *pci_dev, int intx);
void remote_iohub_set_irq(void *opaque, int pirq, int level);
void process_set_irqfd_msg(PCIDevice *pci_dev, MPQemuMsg *msg);

void remote_iohub_init(RemoteIOHubState *iohub);
void remote_iohub_finalize(RemoteIOHubState *iohub);

#endif