lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250415132623.14913-2-victor.duicu@microchip.com>
Date: Tue, 15 Apr 2025 16:26:22 +0300
From: <victor.duicu@...rochip.com>
To: <jic23@...nel.org>
CC: <andy@...nel.org>, <dlechner@...libre.com>, <nuno.sa@...log.com>,
	<victor.duicu@...rochip.com>, <marius.cristea@...rochip.com>,
	<linux-iio@...r.kernel.org>, <linux-kernel@...r.kernel.org>
Subject: [PATCH v1 1/2] dt-bindings: iio: temperature: add support for MCP998X

From: Victor Duicu <victor.duicu@...rochip.com>

This is the devicetree schema for Microchip MCP998X/33 and
MCP998XD/33D Multichannel Automotive Temperature Monitor Family.

Signed-off-by: Victor Duicu <victor.duicu@...rochip.com>
---
 .../iio/temperature/microchip,mcp9982.yaml    | 182 ++++++++++++++++++
 1 file changed, 182 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/iio/temperature/microchip,mcp9982.yaml

diff --git a/Documentation/devicetree/bindings/iio/temperature/microchip,mcp9982.yaml b/Documentation/devicetree/bindings/iio/temperature/microchip,mcp9982.yaml
new file mode 100644
index 000000000000..8cbf897d1278
--- /dev/null
+++ b/Documentation/devicetree/bindings/iio/temperature/microchip,mcp9982.yaml
@@ -0,0 +1,182 @@
+# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/iio/temperature/microchip,mcp9982.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Microchip MCP998X/33 and MCP998XD/33D Multichannel Automotive Temperature Monitor Family
+
+maintainers:
+  - Victor Duicu <victor.duicu@...rochip.com>
+
+description: |
+  The MCP998X/33 and MCP998XD/33D family is a high-accuracy 2-wire multichannel
+  automotive temperature monitor.
+  The datasheet can be found here:
+    https://ww1.microchip.com/downloads/aemDocuments/documents/MSLD/ProductDocuments/DataSheets/MCP998X-Family-Data-Sheet-DS20006827.pdf
+
+properties:
+  compatible:
+    enum:
+      - microchip,mcp9933
+      - microchip,mcp9933D
+      - microchip,mcp9982
+      - microchip,mcp9982D
+      - microchip,mcp9983
+      - microchip,mcp9983D
+      - microchip,mcp9984
+      - microchip,mcp9984D
+      - microchip,mcp9985
+      - microchip,mcp9985D
+
+  reg:
+    maxItems: 1
+    
+  interrupts:
+    maxItems: 2
+    
+  interrupt-names:
+    description: |
+      ALERT1 indicates a HIGH or LOW limit was exceeded.
+      ALERT2 indicates a THERM limit was exceeded.
+    items:
+      - const: ALERT1
+      - const: ALERT2
+    
+  "#address-cells":
+    const: 1
+
+  "#size-cells":
+    const: 0
+
+  microchip,temp-hysteresis:
+    description: |
+      Value of temperature limit hysteresis.
+      Omit this tag to set the default value.
+    $ref: /schemas/types.yaml#/definitions/uint32
+    
+  microchip,extended-temp-range:
+    description: |
+      Set the chip to work in the extended temperature range -64 degrees C to 191.875 degrees C.
+      Omit this tag to set the default range 0 degrees C to 127.875 degrees C
+    type: boolean
+    
+  microchip,beta-channel1:
+    description: |
+      The beta compensation factor for external channel 1 can be set
+      by the user, or can be set automatically by the chip.
+      If one wants to enable beta autodetection, omit this tag.
+      Please consult the documentation if one wants to set a specific beta.
+      If anti-parallel diode operation is enabled, the default value is set
+      and can't be changed.
+    type: boolean
+    
+  microchip,beta-channel2:
+    description: |
+      The beta compensation factor for external channel 2 can be set
+      by the user, or can be set automatically by the chip.
+      If one wants to enable beta autodetection, omit this tag.
+      Please consult the documentation if one wants to set a specific beta.
+      If anti-parallel diode operation is enabled, the default value is set
+      and can't be changed.
+    type: boolean
+    
+  microchip,apdd-state:
+    description: |
+      Enable anti-parallel diode mode operation.
+      Omit this tag to disable anti-parallel diode mode by default.
+    type: boolean
+    
+  microchip,recd12:
+    description: |
+      Enable resistance error correction for external channels 1 and 2.
+      Not all chips support resistance error correction on external
+      channels 1 and 2, please consult the documentation.
+      Omit this tag to disable REC for channels 1 and 2 by default.
+    type: boolean
+    
+  microchip,recd34:
+    description: |
+      Enable resistance error correction for external channels 3 and 4.
+      Not all chips support resistance error correction on external
+      channels 3 and 4, please consult the documentation.
+      Omit this tag to disable REC for channels 3 and 4 by default.
+    type: boolean
+    
+  label:
+    description: Unique name to identify which device this is.
+    
+  vdd-supply: true
+ 
+patternProperties:
+  "^channel@[1-4]+$":
+    description: |
+      Represents the external temperature channels to which a remote diode is
+      connected.
+    type: object
+
+    properties:
+      reg:
+        items:
+          minimum: 1
+          maximum: 4
+      
+      microchip,ideality-factor:
+        description: |
+          Each channel has an ideality factor.
+          Beta compensation and resistance error correction automatically correct
+          for most ideality error. So ideality factor does not need to be adjusted in general.
+          Omit this tag in order to set the default value.
+          Please consult the documentation if one wants to set a specific ideality value.
+        $ref: /schemas/types.yaml#/definitions/uint32
+      
+      label:
+        description: Unique name to identify which channel this is.
+    
+    required:
+      - reg
+    
+    unevaluatedProperties: false
+
+required:
+  - compatible
+  - reg
+  - vdd-supply
+
+additionalProperties: false
+
+examples:
+  - |
+    i2c {
+        #address-cells = <1>;
+        #size-cells = <0>;
+        
+        temperature-sensor@4c {
+            compatible = "microchip,mcp9985";
+            reg = <0x4c>;
+            
+            #address-cells = <1>;
+            #size-cells = <0>;
+
+            label = "temperature-sensor";
+            
+            microchip,temp-hysteresis = <10>;
+            microchip,extended-temp-range;
+            microchip,apdd-state;
+            microchip,recd12;
+            microchip,recd34;
+            vdd-supply = <&vdd>;
+            
+            channel@1{
+                reg = <0x1>;
+                label = "CPU Temperature";
+            };
+            
+            channel@2{
+                reg = <0x2>;
+                label = "GPU Temperature";
+            };
+        };
+    };
+
+...
-- 
2.45.2


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ