[coreboot-gerrit] Change in coreboot[master]: mb/google/poppy:[WIP] Add ports and endpoints configuration ...

V Sowmya (Code Review) gerrit at coreboot.org
Wed Jun 7 08:16:06 CEST 2017


V Sowmya has uploaded this change for review. ( https://review.coreboot.org/20053


Change subject: mb/google/poppy:[WIP] Add ports and endpoints configuration for sensor and CIO2 devices
......................................................................

mb/google/poppy:[WIP] Add ports and endpoints configuration for sensor and CIO2 devices

Bind the camera sensor and CIO2 devices through the ports and endpoints
configuration available in _DSD ACPI object.

* Port represents an interface in a device.
* Endpoint represents a connection to that interface.

Change-Id: I6d822165bb9a0cd6f7d4cdcb36333887953110a3
Signed-off-by: V Sowmya <v.sowmya at intel.com>
---
A src/mainboard/google/poppy/acpi/ipu_mainboard.asl
M src/mainboard/google/poppy/acpi/mipi_camera.asl
M src/mainboard/google/poppy/dsdt.asl
3 files changed, 147 insertions(+), 0 deletions(-)



  git pull ssh://review.coreboot.org:29418/coreboot refs/changes/53/20053/2

diff --git a/src/mainboard/google/poppy/acpi/ipu_mainboard.asl b/src/mainboard/google/poppy/acpi/ipu_mainboard.asl
new file mode 100644
index 0000000..4938f1c
--- /dev/null
+++ b/src/mainboard/google/poppy/acpi/ipu_mainboard.asl
@@ -0,0 +1,72 @@
+/*
+ * This file is part of the coreboot project.
+ *
+ * Copyright (C) 2017 Intel Corporation.
+ *
+ * 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.
+ */
+
+Scope (\_SB.PCI0.CIO2)
+{
+	/* Define two ports for CIO2 device where endpoint of port0
+	is connected to CAM0 and endpoint of port1 is connected to CAM1 */
+
+	Name (_DSD, Package () {
+		ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
+		Package () {
+			Package () { "port0", "PRT0" },
+			Package () { "port1", "PRT1" },
+		}
+	})
+
+	Name (PRT0, Package () {
+		ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+		Package () {
+			Package () { "port", 0 }, /* csi 0 */
+		},
+		ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
+		Package () {
+			Package () { "endpoint0", "EP00" },
+		}
+	})
+	Name (EP00, Package() {
+		ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+		Package () {
+			Package () { "endpoint", 0 },
+			Package () { "clock-lanes", 0 },
+			Package () { "data-lanes", Package () { 1, 2, 3, 4 } },
+			Package () { "remote-endpoint",
+				Package() { \_SB.PCI0.I2C2.CAM0, 0, 0 }
+			},
+		}
+	})
+
+	NAME (PRT1, Package () {
+		ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+		Package () {
+			Package () { "port", 1 }, /* csi 1 */
+		},
+		ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
+		Package () {
+			Package () { "endpoint1", "EP10" },
+		}
+	})
+	Name (EP10, Package() {
+		ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+		Package () {
+			Package () { "endpoint", 0 },
+			Package () { "clock-lanes", 0 },
+			Package () { "data-lanes", Package () { 1, 2 } },
+			Package () { "remote-endpoint",
+				Package() { \_SB.PCI0.I2C4.CAM1, 0, 0 }
+			},
+		}
+	})
+}
diff --git a/src/mainboard/google/poppy/acpi/mipi_camera.asl b/src/mainboard/google/poppy/acpi/mipi_camera.asl
index d3db2b2..3806ec8 100644
--- a/src/mainboard/google/poppy/acpi/mipi_camera.asl
+++ b/src/mainboard/google/poppy/acpi/mipi_camera.asl
@@ -53,6 +53,42 @@
 				)
 		})
 
+                /* Port0 of CAM0 is connected to port0 of CIO2 device */
+		Name (_DSD, Package () {
+                        ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
+                        Package () {
+                                Package () { "port0", "PRT0" },
+                        }
+                })
+
+                Name (PRT0, Package() {
+                        ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+                        Package () {
+                                Package () { "port", 0 },
+                        },
+                        ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
+                        Package () {
+                                Package () { "endpoint0", "EP00" },
+                        }
+                })
+
+                Name (EP00, Package() {
+                        ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+                        Package () {
+                                Package () { "endpoint", 0 },
+                                Package () { "clock-lanes", 0 },
+                                Package () { "data-lanes",
+                                        Package () { 1, 2, 3, 4 }
+                                },
+                                Package () { "link-frequencies",
+                                        Package() { 1190400000, 640000000 }
+                                },
+                                Package () { "remote-endpoint",
+                                        Package() { \_SB.PCI0.CIO2, 0, 0 }
+                                },
+                        }
+                })
+
 		Method (SSDB, 0, Serialized)
 		{
 			Return (Buffer (0x5E)
@@ -90,6 +126,7 @@
 		}
 
 		Name (_DEP, Package() {\_SB.PCI0.I2C2.PMIC})
+
 		Name (_CRS, ResourceTemplate ()
 		{
 			I2cSerialBus (0x000C, ControllerInitiated, 0x00061A80,
@@ -116,6 +153,7 @@
 		}
 
 		Name (_DEP, Package() {\_SB.PCI0.I2C2.PMIC})
+
 		Name (_CRS, ResourceTemplate ()
 		{
 			I2cSerialBus (0x0010, ControllerInitiated, 0x00061A80,
@@ -124,6 +162,42 @@
 			)
 		})
 
+		/* Port0 of CAM1 is connected to port1 of CIO2 device */
+                Name (_DSD, Package () {
+                        ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
+                        Package () {
+                                Package () { "port0", "PRT0" },
+                        }
+                })
+
+                Name (PRT0, Package() {
+                        ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+                        Package () {
+                                Package () { "port", 0 },
+                        },
+                        ToUUID("dbb8e3e6-5886-4ba6-8795-1319f52a966b"),
+                        Package () {
+                                Package () { "endpoint0", "EP00" },
+                        }
+                })
+
+                Name (EP00, Package() {
+                        ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
+                        Package () {
+                                Package () { "endpoint", 0 },
+                                Package () { "clock-lanes", 0 },
+                                Package () { "data-lanes",
+                                        Package () { 1, 2 }
+                                },
+                                Package () { "link-frequencies",
+                                        Package() { 844800000 }
+                                },
+                                Package () { "remote-endpoint",
+                                        Package() { \_SB.PCI0.CIO2, 1, 0 }
+                                },
+                        }
+                })
+
 		Method (SSDB, 0, Serialized)
 		{
 			Return (Buffer (0x5E)
diff --git a/src/mainboard/google/poppy/dsdt.asl b/src/mainboard/google/poppy/dsdt.asl
index 5008e05..89ca5c6 100644
--- a/src/mainboard/google/poppy/dsdt.asl
+++ b/src/mainboard/google/poppy/dsdt.asl
@@ -51,6 +51,7 @@
 
 	/* MIPI camera */
 	#include "acpi/mipi_camera.asl"
+	#include "acpi/ipu_mainboard.asl"
 
 	/* Chrome OS specific */
 	#include <vendorcode/google/chromeos/acpi/chromeos.asl>

-- 
To view, visit https://review.coreboot.org/20053
To unsubscribe, visit https://review.coreboot.org/settings

Gerrit-Project: coreboot
Gerrit-Branch: master
Gerrit-MessageType: newchange
Gerrit-Change-Id: I6d822165bb9a0cd6f7d4cdcb36333887953110a3
Gerrit-Change-Number: 20053
Gerrit-PatchSet: 2
Gerrit-Owner: V Sowmya <v.sowmya at intel.com>
Gerrit-Reviewer: Balaji Manigandan <balaji.manigandan at intel.com>
Gerrit-Reviewer: Rajmohan Mani <rajmohan.mani at intel.com>
Gerrit-Reviewer: Rizwan Qureshi <rizwan.qureshi at intel.com>



More information about the coreboot-gerrit mailing list