1/* SPDX-License-Identifier: MIT */
2#ifndef __NVKM_PCI_H__
3#define __NVKM_PCI_H__
4#include <core/subdev.h>
5
6enum nvkm_pcie_speed {
7	NVKM_PCIE_SPEED_2_5,
8	NVKM_PCIE_SPEED_5_0,
9	NVKM_PCIE_SPEED_8_0,
10};
11
12struct nvkm_pci {
13	const struct nvkm_pci_func *func;
14	struct nvkm_subdev subdev;
15	struct pci_dev *pdev;
16
17	struct {
18		struct agp_bridge_data *bridge;
19		u32 mode;
20		u64 base;
21		u64 size;
22		int mtrr;
23		bool cma;
24		bool acquired;
25	} agp;
26
27	struct {
28		enum nvkm_pcie_speed speed;
29		u8 width;
30	} pcie;
31
32	bool msi;
33};
34
35u32 nvkm_pci_rd32(struct nvkm_pci *, u16 addr);
36void nvkm_pci_wr08(struct nvkm_pci *, u16 addr, u8 data);
37void nvkm_pci_wr32(struct nvkm_pci *, u16 addr, u32 data);
38u32 nvkm_pci_mask(struct nvkm_pci *, u16 addr, u32 mask, u32 value);
39void nvkm_pci_rom_shadow(struct nvkm_pci *, bool shadow);
40void nvkm_pci_msi_rearm(struct nvkm_device *);
41
42int nv04_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
43int nv40_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
44int nv46_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
45int nv4c_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
46int g84_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
47int g92_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
48int g94_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
49int gf100_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
50int gf106_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
51int gk104_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
52int gp100_pci_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_pci **);
53
54/* pcie functions */
55int nvkm_pcie_set_link(struct nvkm_pci *, enum nvkm_pcie_speed, u8 width);
56#endif
57