aboutsummaryrefslogtreecommitdiff
path: root/include/hw/intc/loongarch_extioi.h
blob: 4795bdc15f572af32d9779d0bc0a41a96009e64f (plain)
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
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
 * LoongArch 3A5000 ext interrupt controller definitions
 *
 * Copyright (C) 2021 Loongson Technology Corporation Limited
 */

#ifndef LOONGARCH_EXTIOI_H
#define LOONGARCH_EXTIOI_H

#include "hw/intc/loongarch_extioi_common.h"

#define TYPE_LOONGARCH_EXTIOI "loongarch.extioi"
OBJECT_DECLARE_TYPE(LoongArchExtIOIState, LoongArchExtIOIClass, LOONGARCH_EXTIOI)

struct LoongArchExtIOIState {
    LoongArchExtIOICommonState parent_obj;
    int dev_fd;
};

struct LoongArchExtIOIClass {
    LoongArchExtIOICommonClass parent_class;

    DeviceRealize parent_realize;
    ResettablePhases parent_phases;
};

void kvm_extioi_realize(DeviceState *dev, Error **errp);
int kvm_extioi_get(void *opaque);
int kvm_extioi_put(void *opaque, int version_id);

#endif /* LOONGARCH_EXTIOI_H */