|
@@ -30,17 +30,32 @@
|
|
|
|
|
|
void build_mcfg(GArray *table_data, BIOSLinker *linker, AcpiMcfgInfo *info)
|
|
|
{
|
|
|
- AcpiTableMcfg *mcfg;
|
|
|
- int len = sizeof(*mcfg) + sizeof(mcfg->allocation[0]);
|
|
|
-
|
|
|
- mcfg = acpi_data_push(table_data, len);
|
|
|
- mcfg->allocation[0].address = cpu_to_le64(info->base);
|
|
|
-
|
|
|
- /* Only a single allocation so no need to play with segments */
|
|
|
- mcfg->allocation[0].pci_segment = cpu_to_le16(0);
|
|
|
- mcfg->allocation[0].start_bus_number = 0;
|
|
|
- mcfg->allocation[0].end_bus_number = PCIE_MMCFG_BUS(info->size - 1);
|
|
|
-
|
|
|
- build_header(linker, table_data, (void *)mcfg, "MCFG", len, 1, NULL, NULL);
|
|
|
+ int mcfg_start = table_data->len;
|
|
|
+
|
|
|
+ /*
|
|
|
+ * PCI Firmware Specification, Revision 3.0
|
|
|
+ * 4.1.2 MCFG Table Description.
|
|
|
+ */
|
|
|
+ acpi_data_push(table_data, sizeof(AcpiTableHeader));
|
|
|
+ /* Reserved */
|
|
|
+ build_append_int_noprefix(table_data, 0, 8);
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Memory Mapped Enhanced Configuration Space Base Address Allocation
|
|
|
+ * Structure
|
|
|
+ */
|
|
|
+ /* Base address, processor-relative */
|
|
|
+ build_append_int_noprefix(table_data, info->base, 8);
|
|
|
+ /* PCI segment group number */
|
|
|
+ build_append_int_noprefix(table_data, 0, 2);
|
|
|
+ /* Starting PCI Bus number */
|
|
|
+ build_append_int_noprefix(table_data, 0, 1);
|
|
|
+ /* Final PCI Bus number */
|
|
|
+ build_append_int_noprefix(table_data, PCIE_MMCFG_BUS(info->size - 1), 1);
|
|
|
+ /* Reserved */
|
|
|
+ build_append_int_noprefix(table_data, 0, 4);
|
|
|
+
|
|
|
+ build_header(linker, table_data, (void *)(table_data->data + mcfg_start),
|
|
|
+ "MCFG", table_data->len - mcfg_start, 1, NULL, NULL);
|
|
|
}
|
|
|
|