1 /* SPDX-License-Identifier: GPL-2.0 */
4 #include <core/subdev.h>
13 const struct nvkm_pci_func *func;
14 struct nvkm_subdev subdev;
19 struct agp_bridge_data *bridge;
29 enum nvkm_pcie_speed speed;
36 u32 nvkm_pci_rd32(struct nvkm_pci *, u16 addr);
37 void nvkm_pci_wr08(struct nvkm_pci *, u16 addr, u8 data);
38 void nvkm_pci_wr32(struct nvkm_pci *, u16 addr, u32 data);
39 u32 nvkm_pci_mask(struct nvkm_pci *, u16 addr, u32 mask, u32 value);
40 void nvkm_pci_rom_shadow(struct nvkm_pci *, bool shadow);
42 int nv04_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
43 int nv40_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
44 int nv46_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
45 int nv4c_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
46 int g84_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
47 int g92_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
48 int g94_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
49 int gf100_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
50 int gf106_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
51 int gk104_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
52 int gp100_pci_new(struct nvkm_device *, int, struct nvkm_pci **);
55 int nvkm_pcie_set_link(struct nvkm_pci *, enum nvkm_pcie_speed, u8 width);