aboutsummaryrefslogtreecommitdiff
path: root/src/mainboard/google/auron/variants/buddy/pei_data.c
diff options
context:
space:
mode:
authorMatt DeVillier <matt.devillier@gmail.com>2018-09-14 21:39:00 -0500
committerMartin Roth <martinroth@google.com>2018-09-17 16:00:41 +0000
commit1b25f1b47c57e32f2a27480e12daa61331e456a3 (patch)
tree92b2f22a72f475155bd6f988ae3016e79e44b312 /src/mainboard/google/auron/variants/buddy/pei_data.c
parent99416035fac228f138f3e291a47173b66954b452 (diff)
google/buddy: Add board as variant of google/auron
Add google/buddy (Acer Chromeboase 24) as a variant of google/auron, with the following changes: - add buddy-specific variant code - add handling to auron for buddy's lan init, which no other variants have - add handling to auron's mainboard ACPI due buddy having different PCIe port assigments than all other variants Ported from Chromium branch firmware-buddy-6301.202.B, commit ebb82ce [Buddy: Lock management engine + SPI descriptor] Test: build/boot Linux on google/buddy using SeaBIOS and Tianocore payloads Change-Id: Ib76eef47677b72ddaef81a2decef189a5f20c20a Signed-off-by: Matt DeVillier <matt.devillier@gmail.com> Reviewed-on: https://review.coreboot.org/28613 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Martin Roth <martinroth@google.com>
Diffstat (limited to 'src/mainboard/google/auron/variants/buddy/pei_data.c')
-rw-r--r--src/mainboard/google/auron/variants/buddy/pei_data.c60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/mainboard/google/auron/variants/buddy/pei_data.c b/src/mainboard/google/auron/variants/buddy/pei_data.c
new file mode 100644
index 0000000000..159d5f6d1e
--- /dev/null
+++ b/src/mainboard/google/auron/variants/buddy/pei_data.c
@@ -0,0 +1,60 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (C) 2014 Google Inc.
+ *
+ * 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 the Free Software Foundation; version 2 of
+ * the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ */
+
+#include <stdint.h>
+#include <string.h>
+#include <soc/gpio.h>
+#include <soc/pei_data.h>
+#include <soc/pei_wrapper.h>
+
+void mainboard_fill_pei_data(struct pei_data *pei_data)
+{
+ pei_data->ec_present = 1;
+
+ /* P0: Side USB3.0 port, USB3S1 */
+ pei_data_usb2_port(pei_data, 0, 0x0150, 1, 0,
+ USB_PORT_INTERNAL);
+ /* P1: Rear USB3.0 port, USB3R1 */
+ pei_data_usb2_port(pei_data, 1, 0x0040, 1, 0,
+ USB_PORT_INTERNAL);
+ /* P2: Rear USB3.0 port, USB3R2 */
+ pei_data_usb2_port(pei_data, 2, 0x0080, 1, 1,
+ USB_PORT_INTERNAL);
+ /* P3: Card Rearder, CRS1 */
+ pei_data_usb2_port(pei_data, 3, 0x0040, 1, USB_OC_PIN_SKIP,
+ USB_PORT_INTERNAL);
+ /* P4: Rear USB2.0 port, USB2R1 */
+ pei_data_usb2_port(pei_data, 4, 0x0040, 1, 2,
+ USB_PORT_INTERNAL);
+ /* P5: 2D Camera */
+ pei_data_usb2_port(pei_data, 5, 0x0000, 1, USB_OC_PIN_SKIP,
+ USB_PORT_INTERNAL);
+ /* P6: VP8 */
+ pei_data_usb2_port(pei_data, 6, 0x0150, 1, USB_OC_PIN_SKIP,
+ USB_PORT_MINI_PCIE);
+ /* P7: WLAN & BT */
+ pei_data_usb2_port(pei_data, 7, 0x0000, 1, USB_OC_PIN_SKIP,
+ USB_PORT_MINI_PCIE);
+
+ /* P1: Side USB3.0 port, USB3S1 */
+ pei_data_usb3_port(pei_data, 0, 1, 0, 0);
+ /* P2: Rear USB3.0 port, USB3R1 */
+ pei_data_usb3_port(pei_data, 1, 1, 0, 0);
+ /* P3: Rear USB3.0 port, USB3R2 */
+ pei_data_usb3_port(pei_data, 2, 1, 1, 0);
+ /* P4: Card Rearder, CRS1 */
+ pei_data_usb3_port(pei_data, 3, 1, USB_OC_PIN_SKIP, 0);
+}