summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/nouveau/include
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/nouveau/include')
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/class.h570
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/client.h39
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/device.h62
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/driver.h22
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/event.h62
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/ioctl.h128
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/list.h353
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/notify.h39
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/object.h75
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/os.h44
-rw-r--r--drivers/gpu/drm/nouveau/include/nvif/unpack.h24
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/client.h57
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/debug.h20
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/device.h147
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/engctx.h54
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/engine.h59
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/enum.h24
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/event.h35
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/gpuobj.h71
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/handle.h34
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/ioctl.h6
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/mm.h40
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/namedb.h56
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/notify.h37
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/object.h206
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/option.h20
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/os.h4
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/parent.h62
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/printk.h32
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/ramht.h23
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/core/subdev.h120
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/bsp.h9
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/copy.h13
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/crypt.h7
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/device.h33
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/disp.h36
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/dmaobj.h31
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/falcon.h83
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/fifo.h126
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/graph.h86
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/mpeg.h63
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/perfmon.h38
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/ppp.h7
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/software.h51
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/vp.h9
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/engine/xtensa.h38
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bar.h37
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios.h35
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/M0203.h31
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/M0205.h32
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/M0209.h30
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/P0260.h23
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/bit.h13
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/bmp.h39
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/boost.h29
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/conn.h46
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/cstep.h28
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/dcb.h69
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/disp.h48
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/dp.h35
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/extdev.h30
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/fan.h8
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/gpio.h48
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/i2c.h29
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/image.h13
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/init.h22
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/mxm.h9
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/npde.h12
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/pcir.h18
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/perf.h47
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/pll.h79
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/pmu.h37
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/ramcfg.h145
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/rammap.h26
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/therm.h77
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/timing.h14
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/vmap.h25
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/volt.h27
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bios/xpio.h19
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/bus.h53
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/clock.h166
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/devinit.h35
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/fb.h159
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/fuse.h30
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/gpio.h47
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/i2c.h136
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/ibus.h35
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/instmem.h52
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/ltc.h35
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/mc.h31
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/mxm.h37
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/pwr.h57
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/therm.h83
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/timer.h64
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/vga.h30
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/vm.h135
-rw-r--r--drivers/gpu/drm/nouveau/include/nvkm/subdev/volt.h61
97 files changed, 5581 insertions, 0 deletions
diff --git a/drivers/gpu/drm/nouveau/include/nvif/class.h b/drivers/gpu/drm/nouveau/include/nvif/class.h
new file mode 100644
index 000000000000..4e308eacb27a
--- /dev/null
+++ b/drivers/gpu/drm/nouveau/include/nvif/class.h
@@ -0,0 +1,570 @@
+#ifndef __NVIF_CLASS_H__
+#define __NVIF_CLASS_H__
+
+/*******************************************************************************
+ * class identifiers
+ ******************************************************************************/
+
+/* the below match nvidia-assigned (either in hw, or sw) class numbers */
+#define NV_DEVICE 0x00000080
+
+#define NV_DMA_FROM_MEMORY 0x00000002
+#define NV_DMA_TO_MEMORY 0x00000003
+#define NV_DMA_IN_MEMORY 0x0000003d
+
+#define NV04_DISP 0x00000046
+
+#define NV03_CHANNEL_DMA 0x0000006b
+#define NV10_CHANNEL_DMA 0x0000006e
+#define NV17_CHANNEL_DMA 0x0000176e
+#define NV40_CHANNEL_DMA 0x0000406e
+#define NV50_CHANNEL_DMA 0x0000506e
+#define G82_CHANNEL_DMA 0x0000826e
+
+#define NV50_CHANNEL_GPFIFO 0x0000506f
+#define G82_CHANNEL_GPFIFO 0x0000826f
+#define FERMI_CHANNEL_GPFIFO 0x0000906f
+#define KEPLER_CHANNEL_GPFIFO_A 0x0000a06f
+
+#define NV50_DISP 0x00005070
+#define G82_DISP 0x00008270
+#define GT200_DISP 0x00008370
+#define GT214_DISP 0x00008570
+#define GT206_DISP 0x00008870
+#define GF110_DISP 0x00009070
+#define GK104_DISP 0x00009170
+#define GK110_DISP 0x00009270
+#define GM107_DISP 0x00009470
+#define GM204_DISP 0x00009570
+
+#define NV50_DISP_CURSOR 0x0000507a
+#define G82_DISP_CURSOR 0x0000827a
+#define GT214_DISP_CURSOR 0x0000857a
+#define GF110_DISP_CURSOR 0x0000907a
+#define GK104_DISP_CURSOR 0x0000917a
+
+#define NV50_DISP_OVERLAY 0x0000507b
+#define G82_DISP_OVERLAY 0x0000827b
+#define GT214_DISP_OVERLAY 0x0000857b
+#define GF110_DISP_OVERLAY 0x0000907b
+#define GK104_DISP_OVERLAY 0x0000917b
+
+#define NV50_DISP_BASE_CHANNEL_DMA 0x0000507c
+#define G82_DISP_BASE_CHANNEL_DMA 0x0000827c
+#define GT200_DISP_BASE_CHANNEL_DMA 0x0000837c
+#define GT214_DISP_BASE_CHANNEL_DMA 0x0000857c
+#define GF110_DISP_BASE_CHANNEL_DMA 0x0000907c
+#define GK104_DISP_BASE_CHANNEL_DMA 0x0000917c
+#define GK110_DISP_BASE_CHANNEL_DMA 0x0000927c
+
+#define NV50_DISP_CORE_CHANNEL_DMA 0x0000507d
+#define G82_DISP_CORE_CHANNEL_DMA 0x0000827d
+#define GT200_DISP_CORE_CHANNEL_DMA 0x0000837d
+#define GT214_DISP_CORE_CHANNEL_DMA 0x0000857d
+#define GT206_DISP_CORE_CHANNEL_DMA 0x0000887d
+#define GF110_DISP_CORE_CHANNEL_DMA 0x0000907d
+#define GK104_DISP_CORE_CHANNEL_DMA 0x0000917d
+#define GK110_DISP_CORE_CHANNEL_DMA 0x0000927d
+#define GM107_DISP_CORE_CHANNEL_DMA 0x0000947d
+#define GM204_DISP_CORE_CHANNEL_DMA 0x0000957d
+
+#define NV50_DISP_OVERLAY_CHANNEL_DMA 0x0000507e
+#define G82_DISP_OVERLAY_CHANNEL_DMA 0x0000827e
+#define GT200_DISP_OVERLAY_CHANNEL_DMA 0x0000837e
+#define GT214_DISP_OVERLAY_CHANNEL_DMA 0x0000857e
+#define GF110_DISP_OVERLAY_CONTROL_DMA 0x0000907e
+#define GK104_DISP_OVERLAY_CONTROL_DMA 0x0000917e
+
+#define FERMI_A 0x00009097
+#define FERMI_B 0x00009197
+#define FERMI_C 0x00009297
+
+#define KEPLER_A 0x0000a097
+#define KEPLER_B 0x0000a197
+#define KEPLER_C 0x0000a297
+
+#define MAXWELL_A 0x0000b097
+
+#define FERMI_COMPUTE_A 0x000090c0
+#define FERMI_COMPUTE_B 0x000091c0
+
+#define KEPLER_COMPUTE_A 0x0000a0c0
+#define KEPLER_COMPUTE_B 0x0000a1c0
+
+#define MAXWELL_COMPUTE_A 0x0000b0c0
+
+
+/*******************************************************************************
+ * client
+ ******************************************************************************/
+
+#define NV_CLIENT_DEVLIST 0x00
+
+struct nv_client_devlist_v0 {
+ __u8 version;
+ __u8 count;
+ __u8 pad02[6];
+ __u64 device[];
+};
+
+
+/*******************************************************************************
+ * device
+ ******************************************************************************/
+
+struct nv_device_v0 {
+ __u8 version;
+ __u8 pad01[7];
+ __u64 device; /* device identifier, ~0 for client default */
+#define NV_DEVICE_V0_DISABLE_IDENTIFY 0x0000000000000001ULL
+#define NV_DEVICE_V0_DISABLE_MMIO 0x0000000000000002ULL
+#define NV_DEVICE_V0_DISABLE_VBIOS 0x0000000000000004ULL
+#define NV_DEVICE_V0_DISABLE_CORE 0x0000000000000008ULL
+#define NV_DEVICE_V0_DISABLE_DISP 0x0000000000010000ULL
+#define NV_DEVICE_V0_DISABLE_FIFO 0x0000000000020000ULL
+#define NV_DEVICE_V0_DISABLE_GRAPH 0x0000000100000000ULL
+#define NV_DEVICE_V0_DISABLE_MPEG 0x0000000200000000ULL
+#define NV_DEVICE_V0_DISABLE_ME 0x0000000400000000ULL
+#define NV_DEVICE_V0_DISABLE_VP 0x0000000800000000ULL
+#define NV_DEVICE_V0_DISABLE_CRYPT 0x0000001000000000ULL
+#define NV_DEVICE_V0_DISABLE_BSP 0x0000002000000000ULL
+#define NV_DEVICE_V0_DISABLE_PPP 0x0000004000000000ULL
+#define NV_DEVICE_V0_DISABLE_COPY0 0x0000008000000000ULL
+#define NV_DEVICE_V0_DISABLE_COPY1 0x0000010000000000ULL
+#define NV_DEVICE_V0_DISABLE_VIC 0x0000020000000000ULL
+#define NV_DEVICE_V0_DISABLE_VENC 0x0000040000000000ULL
+#define NV_DEVICE_V0_DISABLE_COPY2 0x0000080000000000ULL
+ __u64 disable; /* disable particular subsystems */
+ __u64 debug0; /* as above, but *internal* ids, and *NOT* ABI */
+};
+
+#define NV_DEVICE_V0_INFO 0x00
+
+struct nv_device_info_v0 {
+ __u8 version;
+#define NV_DEVICE_INFO_V0_IGP 0x00
+#define NV_DEVICE_INFO_V0_PCI 0x01
+#define NV_DEVICE_INFO_V0_AGP 0x02
+#define NV_DEVICE_INFO_V0_PCIE 0x03
+#define NV_DEVICE_INFO_V0_SOC 0x04
+ __u8 platform;
+ __u16 chipset; /* from NV_PMC_BOOT_0 */
+ __u8 revision; /* from NV_PMC_BOOT_0 */
+#define NV_DEVICE_INFO_V0_TNT 0x01
+#define NV_DEVICE_INFO_V0_CELSIUS 0x02
+#define NV_DEVICE_INFO_V0_KELVIN 0x03
+#define NV_DEVICE_INFO_V0_RANKINE 0x04
+#define NV_DEVICE_INFO_V0_CURIE 0x05
+#define NV_DEVICE_INFO_V0_TESLA 0x06
+#define NV_DEVICE_INFO_V0_FERMI 0x07
+#define NV_DEVICE_INFO_V0_KEPLER 0x08
+#define NV_DEVICE_INFO_V0_MAXWELL 0x09
+ __u8 family;
+ __u8 pad06[2];
+ __u64 ram_size;
+ __u64 ram_user;
+};
+
+
+/*******************************************************************************
+ * context dma
+ ******************************************************************************/
+
+struct nv_dma_v0 {