162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci# Copyright (C) 2008-2011 Freescale Semiconductor Inc. 362306a36Sopenharmony_ci%YAML 1.2 462306a36Sopenharmony_ci--- 562306a36Sopenharmony_ci$id: http://devicetree.org/schemas/crypto/fsl,sec-v4.0-mon.yaml# 662306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 762306a36Sopenharmony_ci 862306a36Sopenharmony_cititle: Freescale Secure Non-Volatile Storage (SNVS) 962306a36Sopenharmony_ci 1062306a36Sopenharmony_cimaintainers: 1162306a36Sopenharmony_ci - '"Horia Geantă" <horia.geanta@nxp.com>' 1262306a36Sopenharmony_ci - Pankaj Gupta <pankaj.gupta@nxp.com> 1362306a36Sopenharmony_ci - Gaurav Jain <gaurav.jain@nxp.com> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_cidescription: 1662306a36Sopenharmony_ci Node defines address range and the associated interrupt for the SNVS function. 1762306a36Sopenharmony_ci This function monitors security state information & reports security 1862306a36Sopenharmony_ci violations. This also included rtc, system power off and ON/OFF key. 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ciproperties: 2162306a36Sopenharmony_ci compatible: 2262306a36Sopenharmony_ci oneOf: 2362306a36Sopenharmony_ci - items: 2462306a36Sopenharmony_ci - const: fsl,sec-v4.0-mon 2562306a36Sopenharmony_ci - const: syscon 2662306a36Sopenharmony_ci - const: simple-mfd 2762306a36Sopenharmony_ci - items: 2862306a36Sopenharmony_ci - const: fsl,sec-v5.0-mon 2962306a36Sopenharmony_ci - const: fsl,sec-v4.0-mon 3062306a36Sopenharmony_ci - items: 3162306a36Sopenharmony_ci - enum: 3262306a36Sopenharmony_ci - fsl,sec-v5.3-mon 3362306a36Sopenharmony_ci - fsl,sec-v5.4-mon 3462306a36Sopenharmony_ci - const: fsl,sec-v5.0-mon 3562306a36Sopenharmony_ci - const: fsl,sec-v4.0-mon 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci reg: 3862306a36Sopenharmony_ci maxItems: 1 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci interrupts: 4162306a36Sopenharmony_ci maxItems: 2 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci snvs-rtc-lp: 4462306a36Sopenharmony_ci type: object 4562306a36Sopenharmony_ci additionalProperties: false 4662306a36Sopenharmony_ci description: 4762306a36Sopenharmony_ci Secure Non-Volatile Storage (SNVS) Low Power (LP) RTC Node 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci properties: 5062306a36Sopenharmony_ci compatible: 5162306a36Sopenharmony_ci const: fsl,sec-v4.0-mon-rtc-lp 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci clocks: 5462306a36Sopenharmony_ci maxItems: 1 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci clock-names: 5762306a36Sopenharmony_ci const: snvs-rtc 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci interrupts: 6062306a36Sopenharmony_ci # VFxxx has only one. What is the 2nd one? 6162306a36Sopenharmony_ci minItems: 1 6262306a36Sopenharmony_ci maxItems: 2 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci regmap: 6562306a36Sopenharmony_ci description: Parent node containing registers 6662306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci offset: 6962306a36Sopenharmony_ci description: LP register offset 7062306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/uint32 7162306a36Sopenharmony_ci default: 0x34 7262306a36Sopenharmony_ci 7362306a36Sopenharmony_ci required: 7462306a36Sopenharmony_ci - compatible 7562306a36Sopenharmony_ci - interrupts 7662306a36Sopenharmony_ci - regmap 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_ci snvs-powerkey: 7962306a36Sopenharmony_ci type: object 8062306a36Sopenharmony_ci additionalProperties: false 8162306a36Sopenharmony_ci description: 8262306a36Sopenharmony_ci The snvs-pwrkey is designed to enable POWER key function which controlled 8362306a36Sopenharmony_ci by SNVS ONOFF, the driver can report the status of POWER key and wakeup 8462306a36Sopenharmony_ci system if pressed after system suspend. 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_ci properties: 8762306a36Sopenharmony_ci compatible: 8862306a36Sopenharmony_ci const: fsl,sec-v4.0-pwrkey 8962306a36Sopenharmony_ci 9062306a36Sopenharmony_ci clocks: 9162306a36Sopenharmony_ci maxItems: 1 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_ci clock-names: 9462306a36Sopenharmony_ci const: snvs-pwrkey 9562306a36Sopenharmony_ci 9662306a36Sopenharmony_ci interrupts: 9762306a36Sopenharmony_ci maxItems: 1 9862306a36Sopenharmony_ci 9962306a36Sopenharmony_ci regmap: 10062306a36Sopenharmony_ci description: Parent node containing registers 10162306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 10262306a36Sopenharmony_ci 10362306a36Sopenharmony_ci wakeup-source: true 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci linux,keycode: 10662306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/uint32 10762306a36Sopenharmony_ci default: 116 10862306a36Sopenharmony_ci deprecated: true 10962306a36Sopenharmony_ci 11062306a36Sopenharmony_ci linux,keycodes: 11162306a36Sopenharmony_ci maxItems: 1 11262306a36Sopenharmony_ci default: 116 11362306a36Sopenharmony_ci 11462306a36Sopenharmony_ci required: 11562306a36Sopenharmony_ci - compatible 11662306a36Sopenharmony_ci - interrupts 11762306a36Sopenharmony_ci - regmap 11862306a36Sopenharmony_ci 11962306a36Sopenharmony_ci snvs-lpgpr: 12062306a36Sopenharmony_ci $ref: /schemas/nvmem/snvs-lpgpr.yaml# 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_ci snvs-poweroff: 12362306a36Sopenharmony_ci description: 12462306a36Sopenharmony_ci The SNVS could drive signal to PMIC to turn off system power by setting 12562306a36Sopenharmony_ci SNVS_LP LPCR register. 12662306a36Sopenharmony_ci $ref: /schemas/power/reset/syscon-poweroff.yaml# 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_cirequired: 12962306a36Sopenharmony_ci - compatible 13062306a36Sopenharmony_ci - reg 13162306a36Sopenharmony_ci 13262306a36Sopenharmony_ciadditionalProperties: false 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ciexamples: 13562306a36Sopenharmony_ci - | 13662306a36Sopenharmony_ci #include <dt-bindings/interrupt-controller/arm-gic.h> 13762306a36Sopenharmony_ci #include <dt-bindings/clock/imx7d-clock.h> 13862306a36Sopenharmony_ci 13962306a36Sopenharmony_ci sec_mon: sec-mon@314000 { 14062306a36Sopenharmony_ci compatible = "fsl,sec-v4.0-mon", "syscon", "simple-mfd"; 14162306a36Sopenharmony_ci reg = <0x314000 0x1000>; 14262306a36Sopenharmony_ci 14362306a36Sopenharmony_ci snvs-rtc-lp { 14462306a36Sopenharmony_ci compatible = "fsl,sec-v4.0-mon-rtc-lp"; 14562306a36Sopenharmony_ci regmap = <&sec_mon>; 14662306a36Sopenharmony_ci offset = <0x34>; 14762306a36Sopenharmony_ci clocks = <&clks IMX7D_SNVS_CLK>; 14862306a36Sopenharmony_ci clock-names = "snvs-rtc"; 14962306a36Sopenharmony_ci interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>, 15062306a36Sopenharmony_ci <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>; 15162306a36Sopenharmony_ci }; 15262306a36Sopenharmony_ci 15362306a36Sopenharmony_ci snvs-powerkey { 15462306a36Sopenharmony_ci compatible = "fsl,sec-v4.0-pwrkey"; 15562306a36Sopenharmony_ci regmap = <&sec_mon>; 15662306a36Sopenharmony_ci clocks = <&clks IMX7D_SNVS_CLK>; 15762306a36Sopenharmony_ci clock-names = "snvs-pwrkey"; 15862306a36Sopenharmony_ci interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; 15962306a36Sopenharmony_ci linux,keycode = <116>; /* KEY_POWER */ 16062306a36Sopenharmony_ci wakeup-source; 16162306a36Sopenharmony_ci }; 16262306a36Sopenharmony_ci }; 163