virpci.h 11.0 KB
Newer Older
1
/*
2 3
 * virpci.h: helper APIs for managing host PCI devices
 *
4
 * Copyright (C) 2009, 2011-2015 Red Hat, Inc.
5 6 7 8 9 10 11 12 13 14 15 16
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
17
 * License along with this library.  If not, see
O
Osier Yang 已提交
18
 * <http://www.gnu.org/licenses/>.
19 20
 */

21
#pragma once
22

23 24 25 26 27
#include "internal.h"
#include "virmdev.h"
#include "virobject.h"
#include "virutil.h"
#include "virenum.h"
28

29 30 31 32 33 34 35
typedef struct _virPCIDevice virPCIDevice;
typedef virPCIDevice *virPCIDevicePtr;
typedef struct _virPCIDeviceAddress virPCIDeviceAddress;
typedef virPCIDeviceAddress *virPCIDeviceAddressPtr;
typedef struct _virPCIDeviceList virPCIDeviceList;
typedef virPCIDeviceList *virPCIDeviceListPtr;

36 37 38
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virPCIDeviceList, virObjectUnref);


39 40
#define VIR_DOMAIN_DEVICE_ZPCI_MAX_UID UINT16_MAX
#define VIR_DOMAIN_DEVICE_ZPCI_MAX_FID UINT32_MAX
41

42 43 44 45 46
typedef struct _virZPCIDeviceAddress virZPCIDeviceAddress;
typedef virZPCIDeviceAddress *virZPCIDeviceAddressPtr;
struct _virZPCIDeviceAddress {
    unsigned int uid; /* exempt from syntax-check */
    unsigned int fid;
47
    /* Don't forget to update virPCIDeviceAddressCopy if needed. */
48 49
};

50
#define VIR_PCI_DEVICE_ADDRESS_FMT "%04x:%02x:%02x.%d"
51

52
struct _virPCIDeviceAddress {
53 54 55 56
    unsigned int domain;
    unsigned int bus;
    unsigned int slot;
    unsigned int function;
57
    int multi; /* virTristateSwitch */
58 59
    int extFlags; /* enum virPCIDeviceAddressExtensionFlags */
    virZPCIDeviceAddress zpci;
60
    /* Don't forget to update virPCIDeviceAddressCopy if needed. */
61 62
};

63 64 65 66 67 68 69 70 71
typedef enum {
    VIR_PCI_STUB_DRIVER_NONE = 0,
    VIR_PCI_STUB_DRIVER_XEN,
    VIR_PCI_STUB_DRIVER_VFIO,
    VIR_PCI_STUB_DRIVER_LAST
} virPCIStubDriver;

VIR_ENUM_DECL(virPCIStubDriver);

72 73 74 75 76
typedef enum {
    VIR_PCIE_LINK_SPEED_NA = 0,
    VIR_PCIE_LINK_SPEED_25,
    VIR_PCIE_LINK_SPEED_5,
    VIR_PCIE_LINK_SPEED_8,
77
    VIR_PCIE_LINK_SPEED_16,
78 79 80
    VIR_PCIE_LINK_SPEED_LAST
} virPCIELinkSpeed;

81
VIR_ENUM_DECL(virPCIELinkSpeed);
82

83 84 85 86 87 88 89 90
typedef enum {
    VIR_PCI_HEADER_ENDPOINT = 0,
    VIR_PCI_HEADER_PCI_BRIDGE,
    VIR_PCI_HEADER_CARDBUS_BRIDGE,

    VIR_PCI_HEADER_LAST
} virPCIHeaderType;

91
VIR_ENUM_DECL(virPCIHeader);
92

93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
typedef struct _virPCIELink virPCIELink;
typedef virPCIELink *virPCIELinkPtr;
struct _virPCIELink {
    int port;
    virPCIELinkSpeed speed;
    unsigned int width;
};

typedef struct _virPCIEDeviceInfo virPCIEDeviceInfo;
typedef virPCIEDeviceInfo *virPCIEDeviceInfoPtr;
struct _virPCIEDeviceInfo {
    /* Not all PCI Express devices have link. For example this 'Root Complex
     * Integrated Endpoint' and 'Root Complex Event Collector' don't have it. */
    virPCIELink *link_cap;   /* PCIe device link capabilities */
    virPCIELink *link_sta;   /* Actually negotiated capabilities */
};

110 111 112 113
virPCIDevicePtr virPCIDeviceNew(unsigned int domain,
                                unsigned int bus,
                                unsigned int slot,
                                unsigned int function);
L
Laine Stump 已提交
114
virPCIDevicePtr virPCIDeviceCopy(virPCIDevicePtr dev);
115 116
void virPCIDeviceFree(virPCIDevicePtr dev);
const char *virPCIDeviceGetName(virPCIDevicePtr dev);
117
const char *virPCIDeviceGetConfigPath(virPCIDevicePtr dev);
118 119 120

int virPCIDeviceDetach(virPCIDevicePtr dev,
                       virPCIDeviceListPtr activeDevs,
121
                       virPCIDeviceListPtr inactiveDevs);
122 123
int virPCIDeviceReattach(virPCIDevicePtr dev,
                         virPCIDeviceListPtr activeDevs,
124
                         virPCIDeviceListPtr inactiveDevs);
125 126 127 128 129
int virPCIDeviceReset(virPCIDevicePtr dev,
                      virPCIDeviceListPtr activeDevs,
                      virPCIDeviceListPtr inactiveDevs);

void virPCIDeviceSetManaged(virPCIDevice *dev,
130
                            bool managed);
131
bool virPCIDeviceGetManaged(virPCIDevice *dev);
132 133 134
void virPCIDeviceSetStubDriver(virPCIDevicePtr dev,
                               virPCIStubDriver driver);
virPCIStubDriver virPCIDeviceGetStubDriver(virPCIDevicePtr dev);
135
virPCIDeviceAddressPtr virPCIDeviceGetAddress(virPCIDevicePtr dev);
C
Chunyan Liu 已提交
136 137 138 139 140 141
int virPCIDeviceSetUsedBy(virPCIDevice *dev,
                          const char *drv_name,
                          const char *dom_name);
void virPCIDeviceGetUsedBy(virPCIDevice *dev,
                           const char **drv_name,
                           const char **dom_name);
142
bool virPCIDeviceGetUnbindFromStub(virPCIDevicePtr dev);
143
void  virPCIDeviceSetUnbindFromStub(virPCIDevice *dev,
144
                                    bool unbind);
145
bool virPCIDeviceGetRemoveSlot(virPCIDevicePtr dev);
146
void virPCIDeviceSetRemoveSlot(virPCIDevice *dev,
147
                               bool remove_slot);
148
bool virPCIDeviceGetReprobe(virPCIDevicePtr dev);
149
void virPCIDeviceSetReprobe(virPCIDevice *dev,
150
                            bool reprobe);
151 152 153 154 155


virPCIDeviceListPtr virPCIDeviceListNew(void);
int  virPCIDeviceListAdd(virPCIDeviceListPtr list,
                         virPCIDevicePtr dev);
L
Laine Stump 已提交
156
int virPCIDeviceListAddCopy(virPCIDeviceListPtr list, virPCIDevicePtr dev);
157 158
virPCIDevicePtr virPCIDeviceListGet(virPCIDeviceListPtr list,
                                    int idx);
159
size_t virPCIDeviceListCount(virPCIDeviceListPtr list);
160 161 162 163 164 165 166 167
virPCIDevicePtr virPCIDeviceListSteal(virPCIDeviceListPtr list,
                                      virPCIDevicePtr dev);
virPCIDevicePtr virPCIDeviceListStealIndex(virPCIDeviceListPtr list,
                                           int idx);
void virPCIDeviceListDel(virPCIDeviceListPtr list,
                         virPCIDevicePtr dev);
virPCIDevicePtr virPCIDeviceListFind(virPCIDeviceListPtr list,
                                     virPCIDevicePtr dev);
L
Laine Stump 已提交
168 169 170 171 172 173
virPCIDevicePtr
virPCIDeviceListFindByIDs(virPCIDeviceListPtr list,
                          unsigned int domain,
                          unsigned int bus,
                          unsigned int slot,
                          unsigned int function);
174 175
int virPCIDeviceListFindIndex(virPCIDeviceListPtr list,
                              virPCIDevicePtr dev);
176

177 178 179 180 181 182 183
/*
 * Callback that will be invoked once for each file
 * associated with / used for PCI host device access.
 *
 * Should return 0 if successfully processed, or
 * -1 to indicate error and abort iteration
 */
184 185 186 187 188
typedef int (*virPCIDeviceFileActor)(virPCIDevicePtr dev,
                                     const char *path, void *opaque);
int virPCIDeviceFileIterate(virPCIDevicePtr dev,
                            virPCIDeviceFileActor actor,
                            void *opaque);
L
Laine Stump 已提交
189

190
typedef int (*virPCIDeviceAddressActor)(virPCIDeviceAddressPtr addr,
L
Laine Stump 已提交
191 192 193 194 195 196 197 198
                                        void *opaque);
int virPCIDeviceAddressIOMMUGroupIterate(virPCIDeviceAddressPtr orig,
                                         virPCIDeviceAddressActor actor,
                                         void *opaque);
virPCIDeviceListPtr virPCIDeviceGetIOMMUGroupList(virPCIDevicePtr dev);
int virPCIDeviceAddressGetIOMMUGroupAddresses(virPCIDeviceAddressPtr devAddr,
                                              virPCIDeviceAddressPtr **iommuGroupDevices,
                                              size_t *nIommuGroupDevices);
199
int virPCIDeviceAddressGetIOMMUGroupNum(virPCIDeviceAddressPtr addr);
200
char *virPCIDeviceAddressGetIOMMUGroupDev(const virPCIDeviceAddress *devAddr);
L
Laine Stump 已提交
201
char *virPCIDeviceGetIOMMUGroupDev(virPCIDevicePtr dev);
202

203 204
int virPCIDeviceIsAssignable(virPCIDevicePtr dev,
                             int strict_acs_check);
J
Jiri Denemark 已提交
205

206 207 208
virPCIDeviceAddressPtr
virPCIGetDeviceAddressFromSysfsLink(const char *device_link);

209 210
int virPCIGetPhysicalFunction(const char *vf_sysfs_path,
                              virPCIDeviceAddressPtr *pf);
211

212 213
int virPCIGetVirtualFunctions(const char *sysfs_path,
                              virPCIDeviceAddressPtr **virtual_functions,
214 215
                              size_t *num_virtual_functions,
                              unsigned int *max_virtual_functions);
216

217
int virPCIIsVirtualFunction(const char *vf_sysfs_device_link);
218

219 220 221
int virPCIGetVirtualFunctionIndex(const char *pf_sysfs_device_link,
                                        const char *vf_sysfs_device_link,
                                        int *vf_index);
222

223
int virPCIDeviceAddressGetSysfsFile(virPCIDeviceAddressPtr addr,
224
                                    char **pci_sysfs_device_link);
R
Roopa Prabhu 已提交
225

226 227 228 229
int virPCIGetNetName(const char *device_link_sysfs_path,
                     size_t idx,
                     char *physPortID,
                     char **netname);
230

231 232
int virPCIGetSysfsFile(char *virPCIDeviceName,
                             char **pci_sysfs_device_link)
233
    G_GNUC_WARN_UNUSED_RESULT;
234

235 236 237 238
bool virPCIDeviceAddressIsValid(virPCIDeviceAddressPtr addr,
                                bool report);
bool virPCIDeviceAddressIsEmpty(const virPCIDeviceAddress *addr);

239 240
bool virPCIDeviceAddressEqual(const virPCIDeviceAddress *addr1,
                              const virPCIDeviceAddress *addr2);
241 242
void virPCIDeviceAddressCopy(virPCIDeviceAddressPtr dst,
                             const virPCIDeviceAddress *src);
243

244
char *virPCIDeviceAddressAsString(const virPCIDeviceAddress *addr)
245 246
      ATTRIBUTE_NONNULL(1);

247 248
int virPCIDeviceAddressParse(char *address, virPCIDeviceAddressPtr bdf);

249 250 251
bool virZPCIDeviceAddressIsValid(virZPCIDeviceAddressPtr zpci);
bool virZPCIDeviceAddressIsEmpty(const virZPCIDeviceAddress *addr);

252
int virPCIGetVirtualFunctionInfo(const char *vf_sysfs_device_path,
253 254 255
                                 int pfNetDevIdx,
                                 char **pfname,
                                 int *vf_index);
R
Roopa Prabhu 已提交
256

257
int virPCIDeviceUnbind(virPCIDevicePtr dev);
258
int virPCIDeviceRebind(virPCIDevicePtr dev);
259 260 261 262
int virPCIDeviceGetDriverPathAndName(virPCIDevicePtr dev,
                                     char **path,
                                     char **name);

263 264 265 266 267 268 269 270
int virPCIDeviceIsPCIExpress(virPCIDevicePtr dev);
int virPCIDeviceHasPCIExpressLink(virPCIDevicePtr dev);
int virPCIDeviceGetLinkCapSta(virPCIDevicePtr dev,
                              int *ca_port,
                              unsigned int *cap_speed,
                              unsigned int *cap_width,
                              unsigned int *sta_speed,
                              unsigned int *sta_width);
271

272 273
int virPCIGetHeaderType(virPCIDevicePtr dev, int *hdrType);

274 275
void virPCIEDeviceInfoFree(virPCIEDeviceInfoPtr dev);

276 277 278
ssize_t virPCIGetMdevTypes(const char *sysfspath,
                           virMediatedDeviceType ***types);

279 280
void virPCIDeviceAddressFree(virPCIDeviceAddressPtr address);

281 282 283
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virPCIDevice, virPCIDeviceFree);
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virPCIDeviceAddress, virPCIDeviceAddressFree);
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virPCIEDeviceInfo, virPCIEDeviceInfoFree);