summaryrefslogtreecommitdiffstats
path: root/include/hw/cpu/core.h
blob: 61ea3481f811bb3210d8530fb7301a0e28f3e810 (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
/*
 * CPU core abstract device
 *
 * Copyright (C) 2016 Bharata B Rao <bharata@linux.vnet.ibm.com>
 *
 * 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_CPU_CORE_H
#define HW_CPU_CORE_H

#include "hw/qdev-core.h"
#include "qom/object.h"

#define TYPE_CPU_CORE "cpu-core"

typedef struct CPUCore CPUCore;
DECLARE_INSTANCE_CHECKER(CPUCore, CPU_CORE,
                         TYPE_CPU_CORE)

struct CPUCore {
    /*< private >*/
    DeviceState parent_obj;

    /*< public >*/
    int core_id;
    int nr_threads;
};

/* Note: topology field names need to be kept in sync with
 * 'CpuInstanceProperties' */

#define CPU_CORE_PROP_CORE_ID "core-id"

#endif