[IGDVFIO] [PATCH 5/8] RFC and help completing: Intel IGD Direct Assignment with VFIO

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



include/hw/pci-host/q35.h

this patch adds:
* #defines for q35 pci config. not all are used, added for completeness

patch
---------------------

diff --git a/include/hw/pci-host/q35.h b/include/hw/pci-host/q35.h
index d9ee978..abb795e 100644
--- a/include/hw/pci-host/q35.h
+++ b/include/hw/pci-host/q35.h
@@ -4,6 +4,7 @@
  * Copyright (c) 2009 Isaku Yamahata <yamahata at valinux co jp>
  *                    VA Linux Systems Japan K.K.
  * Copyright (C) 2012 Jason Baron <jbaron@xxxxxxxxxx>
+ *               2014 Andrew Baranes <andy@xxxxxxxxxxxxxxxx> IGD Support
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -85,6 +86,165 @@ typedef struct Q35PCIHost {
 
 /* D0:F0 configuration space */
 #define MCH_HOST_BRIDGE_REVISION_DEFAULT       0x0
+#define D0F0_VID                               0x00                         /* 16 bits RO */
+#define D0F0_VID_SIZE                          2                            /* 2 Bytes */
+
+
+#define D0F0_DID                               0x02                         /* 16 bits RO */
+#define D0F0_DID_SIZE                          2                            /* 2 Bytes */
+
+
+#define D0F0_PCICMD                            0x04                         /* 16 bits */
+                                                                            /* 15:10 RO RESERVED */
+#define D0F0_PCICMD_FB2B                       0x200                        /* 9 RO=0 Fast back-to-back Enable */
+#define D0F0_PCICMD_SERR                       0x100                        /* 8 RW */
+#define D0F0_PCICMD_ADSTEP                     0x80                         /* 7 RO=0 Address/Data Stepping Enable */
+#define D0F0_PCICMD_PERR                       0x40                         /* 6 RW */
+#define D0F0_PCICMD_VGASNOOP                   0x20                         /* 5 RO=0 VGA Palette Snoop Enable */
+#define D0F0_PCICMD_MWI                        0x10                         /* 4 RO=0 Memory Write and Invalidate Enable */
+                                                                            /* 3 RO RESERVED */
+#define D0F0_PCICMD_BME                        0x04                         /* 2 RO=1 Bus Master Enable */
+#define D0F0_PCICMD_MAE                        0x02                         /* 1 RO=1 Memory Access Enable */
+#define D0F0_PCICMD_IOAE                       0x01                         /* 0 RO=0 I/O Access Enable */
+#define D0F0_PCICMD_SIZE                       2                            /* 2 Bytes */
+
+
+#define D0F0_PCISTS                            0x06                         /* 16 bits */
+#define D0F0_PCISTS_DPE                        0x8000                       /* 15 RW1C Detected Parity Error */
+#define D0F0_PCISTS_SSE                        0x4000                       /* 14 RW1C Signaled System Error */
+#define D0F0_PCISTS_RMAS                       0x2000                       /* 13 RW1C Received Master Abort Status */
+#define D0F0_PCISTS_RTAS                       0x1000                       /* 12 RW1C Reveived Target Abort Status */
+#define D0F0_PCISTS_STAS                       0x800                        /* 11 RO=0 Signaled Target Abort Status */
+#define D0F0_PCISTS_DEVT_MASK                  0x600                        /* 10:9 RO=DEVSEL_FAST DEVSEL Timing */
+#define D0F0_PCISTS_DEVT_FAST                  0x000                        /* DEVSEL_FAST=00 */
+#define D0F0_PCISTS_DPD                        0x100                        /* 8 RW1C Master Data parity Error Detected */
+#define D0F0_PCISTS_FB2B                       0x80                         /* 7 RO=1 Fast Back-to-Back */
+                                                                            /* 6 bitpos RO RESERVED */
+#define D0F0_PCISTS_MC66                       0x20                         /* 5 RO=0 66 MHz Capable */
+#define D0F0_PCISTS_CLIST                      0x10                         /* 4 RO=1 Capability List */
+                                                                            /* 3:0 bitpos RO RESERVED */
+#define D0F0_PCISTS_SIZE                       2                            /* 2 Bytes */
+
+
+#define D0F0_RID                               0x08                         /* 8 bits RO */
+#define D0F0_RID_SIZE                          1                            /* 1 Byte */
+
+
+#define D0F0_CC                                0x09                         /* 24 bits */
+#define D0F0_CC_BCC                            0x800000                     /* 23:16 RO=06 Base Class Code indicating a Bridge Device */
+#define D0F0_CC_SUBCC                          0x8000                       /* 15:8 RO=00 Sub-Class Code indicating a  Host Bridge */
+#define D0F0_CC_PI                             0x80                         /* 7:0 RO=00 Programming Interface */
+#define D0F0_CC_SIZE                           3                            /* 3 Bytes */
+
+
+#define D0F0_HDR                               0x0e                         /* 7:0 RO=00 indicating single function */
+#define D0F0_HDR_SIZE                          1                            /* 1 Byte */
+
+
+#define D0F0_SVID                              0x2c                         /* 15:0 RW-O Subsytem Vendor ID */
+#define D0F0_SVID_SIZE                         2                            /* 2 Bytes */
+
+
+#define D0F0_SID                               0x2e                         /* 15:0 RW-O Subsytem ID */
+#define D0F0_SID_SIZE                          2                            /* 2 Bytes */
+
+
+#define D0F0_PXPEPBAR                          0x40                         /* 64 bits PCI Express Egrees Port Base Address Register */
+                                                                            /* 63:39 RO RESERVED */
+#define D0F0_PXPEPBAR_PXPEPBAR                 Q35_MASK(64, 38, 12)         /* 38:12 RW PXPEPBAR */
+                                                                            /* 11:1 RO RESERVED */
+#define D0F0_PXPEPBAR_PXPEPBAREN               0x01                         /* 0 RW PXPEPBAR Enable */
+#define D0F0_PXPEPBAR_SIZE                     8                            /* 8 Bytes */
+
+
+#define D0F0_MCHBAR                            0x48                         /* 64 bits Host Memory Mapped Register Range Base */
+                                                                            /* 63:39 RO RESERVED */
+#define D0F0_MCHBAR_MCHBAR                     Q35_MASK(64, 38, 15)         /* 38:15 RW MCHBAR */
+                                                                            /* 14:1 RO RESERVED */
+#define D0F0_MCHBAR_MCHBAREN                   0x01                         /* 0 RW MCHBAR Enable */
+#define D0F0_MCHBAR_SIZE                       8                            /* 8 Bytes */
+
+
+#define D0F0_GGC                               0x50                         /* 16 bits GMCH Graphics Control Register */
+                                                                            /* 15 RO RESERVED */
+#define D0F0_GGC_VAMEN                         0x4000                       /* 14 RW-L Versatile Acceleration Mode Enabled */
+                                                                            /* 13:10 RO RESERVED */
+#define D0F0_GGC_GGMS                          0x200                        /* 9:8 RW-L GTT Graphics Memory Size */
+#define D0F0_GGC_GMS                           Q35_MASK(16, 7, 3)           /* 7:3 RW-L Graphics Mode Select */
+                                                                            /* 2 RO RESERVED */
+#define D0F0_GGC_IVD                           0x2                          /* 1 RW-L IGD VGA Disable */
+#define D0F0_GGC_GGCLCK                        0x1                          /* 0 RW-KL GGC Lock */
+#define D0F0_GGC_SIZE                          2                            /* 2 Bytes */
+
+#define D0F0_DEVEN                             0x54                         /* 32 bits Device Enable Register */
+                                                                            /* 31:15 RO RESERVED */
+                                                                            /* 14 RO RESERVED */
+#define D0F0_DEVEN_D6F0EN                      0x2000                       /* 13 RW-L PEG60 Enable */
+                                                                            /* 12:8 RO RESERVED */
+                                                                            /* 7 RO RESERVED */
+                                                                            /* 6:5 RO RESERVED */
+#define D0F0_DEVEN_D2EN                        0x10                         /* 4 RW-L Internal Graphics Engine */
+#define D0F0_DEVEN_D1F0EN                      0x8                          /* 3 RW-L PEG10 Enable */
+#define D0F0_DEVEN_D1F1EN                      0x4                          /* 2 RW-L PEG11 Enable */
+#define D0F0_DEVEN_D1F2EN                      0x2                          /* 1 RW-L PEG12 Enable */
+#define D0F0_DEVEN_D0EN                        0x1                          /* 0 RO=1 Host Bridge */
+#define D0F0_DEVEN_SIZE                        4                            /* 4 Bytes */
+
+
+#define D0F0_PAVPC                             0x58                         /* Protected Audio Video Path Control */
+
+#define D0F0_DMIBAR                            0x68                         /* 64 bits Root Complex Register Range Base Address Register */
+                                                                            /* 63:39 RO RESERVED */
+#define D0F0_DMIBAR_DMIBAR                     Q35_MASK(64, 38, 12)         /* 38:12 DMI Base Address */
+                                                                            /* 11:1 RO RESERVED */
+#define D0F0_DMIBAR_DMIBAREN                   0x01                         /* 0 RW DMIBAR Enable */
+#define D0F0_DMIBAR_SIZE                       8                            /* 8 Bytes */
+
+
+#define D0F0_TOM                               0xa0                         /* 64 bits Top of memory register */
+                                                                            /* 63:39 RO Reserved */
+#define D0F0_TOM_TOM                           Q35_MASK(64,38,20)           /* 38:20 RW-L Top of Memory */
+                                                                            /* 19:1 RO Reserved */
+#define D0F0_TOM_LOCK                          0x1                          /* 0 RW-KL Lock */
+#define D0F0_TOM_SIZE                          8                            /* 8 Bytes */
+
+
+#define D0F0_TOUUD                             0xa8                         /* 64 bits Top of Upper Usable DRAM Register */
+                                                                            /* 63:39 RO Reserved */
+#define D0F0_TOUUD_TOUUD                       Q35_MASK(64,38,20)           /* 38:20 RW-L Top of Upper Usable DRAM Register */
+                                                                            /* 19:1 RO Reserved */
+#define D0F0_TOUUD_LOCK                        0x1                          /* 0 RW-KL Lock */
+#define D0F0_TOUUD_SIZE                        8                            /* 8 Bytes */
+
+
+#define D0F0_BDSM                              0xb0                         /* 32 bits Base Data of Stolen Memory Register */
+#define D0F0_BDSM_BDSM                         Q35_MASK(32,31,20)           /* 31:20 RW-L Graphics Base of Stolen Memory (BDSM) */
+                                                                            /* 19:1 RO Reserved */
+#define D0F0_BDSM_LOCK                         0x1                          /* 0 RW-KL Lock */
+#define D0F0_BDSM_SIZE                         4                            /* 4 Bytes */
+
+
+#define D0F0_BGSM                              0xb4                         /* 32 bits Base of GTT Stolen Memory Register */
+#define D0F0_BGSM_BGSM                         Q35_MASK(32,31,20)           /* 31:20 RW-L Graphics Base of GTT Stolen Memory (BGSM) */
+                                                                            /* 19:1 RO Reserved */
+#define D0F0_BGSM_LOCK                         0x1                          /* 0 RW-KL Lock */
+#define D0F0_BGSM_SIZE                         4                            /* 4 Bytes */
+
+
+#define D0F0_TSEG                              0xb8                         /* 32 bits G Memory Base Register */
+#define D0F0_TSEG_TSEGMB                       Q35_MASK(32,31,20)           /* 31:20 RW-L TSEG Memory Base (TSEGMB) */
+                                                                            /* 19:1 RO Reserved */
+#define D0F0_TSEG_LOCK                         0x1                          /* 0 RW-KL Lock */
+#define D0F0_TSEG_SIZE                         4                            /* 4 Bytes */
+
+
+#define D0F0_TOLUD                             0xbc                         /* 32 bits Top of Low Usable DRAM */
+#define D0F0_TOLUD_TOLUD                       Q35_MASK(32, 31, 20)         /* 31:20 RW-L TOLUD */
+                                                                            /* 19:1 RO RESERVED */
+#define D0F0_TOLUD_LOCK                        0x1                          /* 0 RW-KL Lock */
+#define D0F0_TOLUD_SIZE                        4                            /* 4 Bytes */
+
+#define MCH_HOST_BRIDGE_REVISION_DEFUALT       0x0
 
 #define MCH_HOST_BRIDGE_PCIEXBAR               0x60    /* 64bit register */
 #define MCH_HOST_BRIDGE_PCIEXBAR_SIZE          8       /* 64bit register */
_______________________________________________
Intel-gfx mailing list
Intel-gfx@xxxxxxxxxxxxxxxxxxxxx
http://lists.freedesktop.org/mailman/listinfo/intel-gfx

[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux