drivers/spi/acpi: Add generic property list

The touchscreen vendor (Goodix) needs to use this value
(hid-report-addr) in the touch driver, and this value
needs to be changed later.So add generic property list to allow populating vendor specific device properties to ACPI SSDT table.

BUG=b:342932183
BRANCH=None
TEST=emerge-brox coreboot

Change-Id: I8b18e0a2925e6fd36e3a470bde9910661b7558b8
Signed-off-by: Kun Liu <liukun11@huaqin.corp-partner.google.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/83139
Reviewed-by: Karthik Ramasubramanian <kramasub@google.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
diff --git a/src/drivers/spi/acpi/acpi.c b/src/drivers/spi/acpi/acpi.c
index 6d92776..687dd52 100644
--- a/src/drivers/spi/acpi/acpi.c
+++ b/src/drivers/spi/acpi/acpi.c
@@ -131,7 +131,7 @@
 
 	/* Write device properties if needed */
 	if (config->compat_string || irq_gpio_index >= 0 ||
-	    reset_gpio_index >= 0 || enable_gpio_index >= 0) {
+	    reset_gpio_index >= 0 || enable_gpio_index >= 0 || config->property_count) {
 		struct acpi_dp *dsd = acpi_dp_new_table("_DSD");
 		if (config->compat_string)
 			acpi_dp_add_string(dsd, "compatible",
@@ -148,6 +148,9 @@
 			acpi_dp_add_gpio(dsd, "enable-gpios", path,
 					 enable_gpio_index, 0,
 					 config->enable_gpio.active_low);
+		/* Add generic property list */
+		acpi_dp_add_property_list(dsd, config->property_list,
+					 config->property_count);
 		acpi_dp_write(dsd);
 	}