Angel Pons has uploaded this change for review. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
sb/intel/lynxpoint: Use common code to generate HPET table
There's no need to reinvent the wheel.
Change-Id: If6b90c9a7a00af0322c6dd15d2c4ecf2c513d0cc Signed-off-by: Angel Pons th3fanbus@gmail.com --- M src/southbridge/intel/lynxpoint/Kconfig M src/southbridge/intel/lynxpoint/acpi.c M src/southbridge/intel/lynxpoint/lpc.c M src/southbridge/intel/lynxpoint/pch.h 4 files changed, 5 insertions(+), 33 deletions(-)
git pull ssh://review.coreboot.org:29418/coreboot refs/changes/77/46977/1
diff --git a/src/southbridge/intel/lynxpoint/Kconfig b/src/southbridge/intel/lynxpoint/Kconfig index 5abb286..7ba86b8 100644 --- a/src/southbridge/intel/lynxpoint/Kconfig +++ b/src/southbridge/intel/lynxpoint/Kconfig @@ -51,6 +51,10 @@ If you set this option to y, the serial IRQ machine will be operated in continuous mode.
+config HPET_MIN_TICKS + hex + default 0x80 + config FINALIZE_USB_ROUTE_XHCI bool "Route all ports to XHCI controller in finalize step" default y diff --git a/src/southbridge/intel/lynxpoint/acpi.c b/src/southbridge/intel/lynxpoint/acpi.c index ce1b109..e699c5d 100644 --- a/src/southbridge/intel/lynxpoint/acpi.c +++ b/src/southbridge/intel/lynxpoint/acpi.c @@ -9,37 +9,6 @@ #include "pch.h" #include "nvs.h"
-void acpi_create_intel_hpet(acpi_hpet_t * hpet) -{ - acpi_header_t *header = &(hpet->header); - acpi_addr_t *addr = &(hpet->addr); - - memset((void *)hpet, 0, sizeof(acpi_hpet_t)); - - /* fill out header fields */ - memcpy(header->signature, "HPET", 4); - memcpy(header->oem_id, OEM_ID, 6); - memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8); - memcpy(header->asl_compiler_id, ASLC, 4); - - header->length = sizeof(acpi_hpet_t); - header->revision = get_acpi_table_revision(HPET); - - /* fill out HPET address */ - addr->space_id = ACPI_ADDRESS_SPACE_MEMORY; - addr->bit_width = 64; - addr->bit_offset = 0; - addr->addrl = (unsigned long long)HPET_ADDR & 0xffffffff; - addr->addrh = (unsigned long long)HPET_ADDR >> 32; - - hpet->id = 0x8086a201; /* Intel */ - hpet->number = 0x00; - hpet->min_tick = 0x0080; - - header->checksum = - acpi_checksum((void *)hpet, sizeof(acpi_hpet_t)); -} - static void acpi_create_serialio_ssdt_entry(int id, struct global_nvs *gnvs) { char sio_name[5] = {}; diff --git a/src/southbridge/intel/lynxpoint/lpc.c b/src/southbridge/intel/lynxpoint/lpc.c index 7eef5ff..fd5297f 100644 --- a/src/southbridge/intel/lynxpoint/lpc.c +++ b/src/southbridge/intel/lynxpoint/lpc.c @@ -761,7 +761,7 @@ hpet = (acpi_hpet_t *)current; current += sizeof(acpi_hpet_t); current = acpi_align_current(current); - acpi_create_intel_hpet(hpet); + acpi_create_hpet(hpet); acpi_add_table(rsdp, hpet);
current = acpi_align_current(current); diff --git a/src/southbridge/intel/lynxpoint/pch.h b/src/southbridge/intel/lynxpoint/pch.h index 702d890..66cd05e 100644 --- a/src/southbridge/intel/lynxpoint/pch.h +++ b/src/southbridge/intel/lynxpoint/pch.h @@ -120,7 +120,6 @@ void pch_enable(struct device *dev); void pch_disable_devfn(struct device *dev); void pch_log_state(void); -void acpi_create_intel_hpet(acpi_hpet_t * hpet); void acpi_create_serialio_ssdt(acpi_header_t *ssdt);
void enable_usb_bar(void);
Michael Niewöhner has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
Patch Set 1:
(1 comment)
https://review.coreboot.org/c/coreboot/+/46977/1/src/southbridge/intel/lynxp... File src/southbridge/intel/lynxpoint/lpc.c:
https://review.coreboot.org/c/coreboot/+/46977/1/src/southbridge/intel/lynxp... PS1, Line 758: : printk(BIOS_DEBUG, "ACPI: * HPET\n"); : : hpet = (acpi_hpet_t *)current; : current += sizeof(acpi_hpet_t); : current = acpi_align_current(current); : acpi_create_hpet(hpet); : acpi_add_table(rsdp, hpet); why not use acpi_write_hpet?
Angel Pons has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
Patch Set 1:
(1 comment)
https://review.coreboot.org/c/coreboot/+/46977/1/src/southbridge/intel/lynxp... File src/southbridge/intel/lynxpoint/lpc.c:
https://review.coreboot.org/c/coreboot/+/46977/1/src/southbridge/intel/lynxp... PS1, Line 758: : printk(BIOS_DEBUG, "ACPI: * HPET\n"); : : hpet = (acpi_hpet_t *)current; : current += sizeof(acpi_hpet_t); : current = acpi_align_current(current); : acpi_create_hpet(hpet); : acpi_add_table(rsdp, hpet);
why not use acpi_write_hpet?
Good point
Hello build bot (Jenkins), Patrick Rudolph,
I'd like you to reexamine a change. Please visit
https://review.coreboot.org/c/coreboot/+/46977
to look at the new patch set (#2).
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
sb/intel/lynxpoint: Use common code to generate HPET table
There's no need to reinvent the wheel.
Change-Id: If6b90c9a7a00af0322c6dd15d2c4ecf2c513d0cc Signed-off-by: Angel Pons th3fanbus@gmail.com --- M src/southbridge/intel/lynxpoint/Kconfig M src/southbridge/intel/lynxpoint/acpi.c M src/southbridge/intel/lynxpoint/lpc.c M src/southbridge/intel/lynxpoint/pch.h 4 files changed, 5 insertions(+), 40 deletions(-)
git pull ssh://review.coreboot.org:29418/coreboot refs/changes/77/46977/2
Angel Pons has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
Patch Set 1:
(1 comment)
https://review.coreboot.org/c/coreboot/+/46977/1/src/southbridge/intel/lynxp... File src/southbridge/intel/lynxpoint/lpc.c:
https://review.coreboot.org/c/coreboot/+/46977/1/src/southbridge/intel/lynxp... PS1, Line 758: : printk(BIOS_DEBUG, "ACPI: * HPET\n"); : : hpet = (acpi_hpet_t *)current; : current += sizeof(acpi_hpet_t); : current = acpi_align_current(current); : acpi_create_hpet(hpet); : acpi_add_table(rsdp, hpet);
Good point
Done
Michael Niewöhner has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
Patch Set 2: Code-Review+2
Angel Pons has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
Patch Set 3:
a
Michael Niewöhner has posted comments on this change. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
Patch Set 3:
Patch Set 3:
a
b? ;)
Michael Niewöhner has submitted this change. ( https://review.coreboot.org/c/coreboot/+/46977 )
Change subject: sb/intel/lynxpoint: Use common code to generate HPET table ......................................................................
sb/intel/lynxpoint: Use common code to generate HPET table
There's no need to reinvent the wheel.
Change-Id: If6b90c9a7a00af0322c6dd15d2c4ecf2c513d0cc Signed-off-by: Angel Pons th3fanbus@gmail.com Reviewed-on: https://review.coreboot.org/c/coreboot/+/46977 Reviewed-by: Michael Niewöhner foss@mniewoehner.de Tested-by: build bot (Jenkins) no-reply@coreboot.org --- M src/southbridge/intel/lynxpoint/Kconfig M src/southbridge/intel/lynxpoint/acpi.c M src/southbridge/intel/lynxpoint/lpc.c M src/southbridge/intel/lynxpoint/pch.h 4 files changed, 5 insertions(+), 40 deletions(-)
Approvals: build bot (Jenkins): Verified Michael Niewöhner: Looks good to me, approved
diff --git a/src/southbridge/intel/lynxpoint/Kconfig b/src/southbridge/intel/lynxpoint/Kconfig index 5abb286..7ba86b8 100644 --- a/src/southbridge/intel/lynxpoint/Kconfig +++ b/src/southbridge/intel/lynxpoint/Kconfig @@ -51,6 +51,10 @@ If you set this option to y, the serial IRQ machine will be operated in continuous mode.
+config HPET_MIN_TICKS + hex + default 0x80 + config FINALIZE_USB_ROUTE_XHCI bool "Route all ports to XHCI controller in finalize step" default y diff --git a/src/southbridge/intel/lynxpoint/acpi.c b/src/southbridge/intel/lynxpoint/acpi.c index ce1b109..e699c5d 100644 --- a/src/southbridge/intel/lynxpoint/acpi.c +++ b/src/southbridge/intel/lynxpoint/acpi.c @@ -9,37 +9,6 @@ #include "pch.h" #include "nvs.h"
-void acpi_create_intel_hpet(acpi_hpet_t * hpet) -{ - acpi_header_t *header = &(hpet->header); - acpi_addr_t *addr = &(hpet->addr); - - memset((void *)hpet, 0, sizeof(acpi_hpet_t)); - - /* fill out header fields */ - memcpy(header->signature, "HPET", 4); - memcpy(header->oem_id, OEM_ID, 6); - memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8); - memcpy(header->asl_compiler_id, ASLC, 4); - - header->length = sizeof(acpi_hpet_t); - header->revision = get_acpi_table_revision(HPET); - - /* fill out HPET address */ - addr->space_id = ACPI_ADDRESS_SPACE_MEMORY; - addr->bit_width = 64; - addr->bit_offset = 0; - addr->addrl = (unsigned long long)HPET_ADDR & 0xffffffff; - addr->addrh = (unsigned long long)HPET_ADDR >> 32; - - hpet->id = 0x8086a201; /* Intel */ - hpet->number = 0x00; - hpet->min_tick = 0x0080; - - header->checksum = - acpi_checksum((void *)hpet, sizeof(acpi_hpet_t)); -} - static void acpi_create_serialio_ssdt_entry(int id, struct global_nvs *gnvs) { char sio_name[5] = {}; diff --git a/src/southbridge/intel/lynxpoint/lpc.c b/src/southbridge/intel/lynxpoint/lpc.c index 29cd53f..12e2625 100644 --- a/src/southbridge/intel/lynxpoint/lpc.c +++ b/src/southbridge/intel/lynxpoint/lpc.c @@ -737,7 +737,6 @@ struct acpi_rsdp *rsdp) { unsigned long current; - acpi_hpet_t *hpet; acpi_header_t *ssdt;
current = start; @@ -748,13 +747,7 @@ /* * We explicitly add these tables later on: */ - printk(BIOS_DEBUG, "ACPI: * HPET\n"); - - hpet = (acpi_hpet_t *)current; - current += sizeof(acpi_hpet_t); - current = acpi_align_current(current); - acpi_create_intel_hpet(hpet); - acpi_add_table(rsdp, hpet); + current = acpi_write_hpet(device, current, rsdp);
current = acpi_align_current(current);
diff --git a/src/southbridge/intel/lynxpoint/pch.h b/src/southbridge/intel/lynxpoint/pch.h index 1ecad62..50e0b14 100644 --- a/src/southbridge/intel/lynxpoint/pch.h +++ b/src/southbridge/intel/lynxpoint/pch.h @@ -120,7 +120,6 @@ void pch_enable(struct device *dev); void pch_disable_devfn(struct device *dev); void pch_log_state(void); -void acpi_create_intel_hpet(acpi_hpet_t * hpet); void acpi_create_serialio_ssdt(acpi_header_t *ssdt);
void enable_usb_bar(void);