@@ -15,13 +15,13 @@ allOf:
properties:
compatible:
- const: qcom,geni-i2c
+ enum:
+ - qcom,geni-i2c
+ - qcom,geni-i2c-master-hub
- clocks:
- maxItems: 1
+ clocks: true
- clock-names:
- const: se
+ clock-names: true
clock-frequency:
default: 100000
@@ -34,14 +34,9 @@ properties:
- const: tx
- const: rx
- interconnects:
- maxItems: 3
+ interconnects: true
- interconnect-names:
- items:
- - const: qup-core
- - const: qup-config
- - const: qup-memory
+ interconnect-names: true
interrupts:
maxItems: 1
@@ -71,6 +66,48 @@ required:
- clock-names
- reg
+if:
+ properties:
+ compatible:
+ contains:
+ const: qcom,geni-i2c-master-hub
+then:
+ properties:
+ clock-names:
+ items:
+ - const: se
+ - const: core
+
+ clocks:
+ maxItems: 2
+
+ dmas: false
+ dma-names: false
+
+ interconnects:
+ maxItems: 2
+
+ interconnect-names:
+ items:
+ - const: qup-core
+ - const: qup-config
+else:
+ properties:
+ clocks:
+ maxItems: 1
+
+ clock-names:
+ const: se
+
+ interconnects:
+ maxItems: 3
+
+ interconnect-names:
+ items:
+ - const: qup-core
+ - const: qup-config
+ - const: qup-memory
+
unevaluatedProperties: false
examples:
The I2C Master Hub is a stripped down version of the GENI Serial Engine QUP Wrapper Controller but only supporting I2C serial engines without DMA support. This documents the I2C Serial Engine variant used within the I2C Master Hub Wrapper. This serial engine variant lacks DMA support, and requires a core clock, and since DMA support is lacking, the memory interconnect path isn't needed. Signed-off-by: Neil Armstrong <neil.armstrong@linaro.org> --- .../bindings/i2c/qcom,i2c-geni-qcom.yaml | 61 +++++++++++++++++----- 1 file changed, 49 insertions(+), 12 deletions(-)