From nobody Mon Feb 9 07:23:53 2026 Received: from mail-ed1-f45.google.com (mail-ed1-f45.google.com [209.85.208.45]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 767771FC0E9; Sun, 23 Mar 2025 07:14:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.45 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714095; cv=none; b=ojQ812gd00CFeWYodPYsZHNQWcKXzV2zsBguTXjgvgsLA9Ak2t3h2Qt5LVrjrCIvzspdDjHaQeFPfvhHW1yMm0jo+wWwr5tteFdZm4mGAhGl9RrBCffvhTQcMjkZaa2UIoQbdOajgU7HDNGiMRVkQBJE24lENjk20KXMuuAExTM= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714095; c=relaxed/simple; bh=LbfqHIJBiWIwwt+TO1iq0U3ZOV0oDMuejgyOImjp2RM=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=SVTXzMaICbgVFiNtL6uYh7OIKPyyPf2rfeywezn8XxTBSAP1yP0Ea59piv8k7FrYExdsu1Nw26pd79R3+Xj3tXX/MZR8bF4J8PxEky3UChPP7kaYFxuPTMoXWKeC2cbK2ojq004beieNw1B++Hchf7uM4tTQL7RcRtFf/KukyH8= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=mQhpCroE; arc=none smtp.client-ip=209.85.208.45 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="mQhpCroE" Received: by mail-ed1-f45.google.com with SMTP id 4fb4d7f45d1cf-5e033c2f106so4839276a12.3; Sun, 23 Mar 2025 00:14:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742714091; x=1743318891; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=k1mSfG9tzE1vlwLPDBezMTy+3PVMsOvW4K1F0qCroTU=; b=mQhpCroExgEG0F8pSWbF2lIHptct9UiV1qb9rpL3U5AFDrC0tAvbt4kAl1VSzk1WuW petZfBF1g+aBvu9L8NdBfhxgX3g+gS/M+ElgH/LLMs835QbJW1VG+DFuzAo2kQeJhaOK ruVZ/9vs2i4PzUyhf1QVIYorHIEhYxhbX9MP7GS19WPGV/RWS6JGDxmItSG/waTHIGjR bIcSFYI8MqCROwd+1lK8CXxpojp0zobC6g6a3y1evB8KuFAKln4sjZBPvVL9W/if9mxn n4/WLNbhxhCe68pfAfktRskPuXyALu0XUKGFuCActhUs05qns6Nc7DZhWFIQXc8ihjxA L7mA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742714091; x=1743318891; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=k1mSfG9tzE1vlwLPDBezMTy+3PVMsOvW4K1F0qCroTU=; b=NydIqguhqax6mwhyIGJDGzqWFeSvac7H6X56zQqOv7I4YUsO/tK5yv0tpjYMJLKcpx x/3AZO8hRR/JD39fohzNhTP/t2Ai1/aqQ3AwzRoJGpeJln40ScMbBDacbqT1Q1eShsQt 6ZafI2EdIaWSU4gxIbYvdE6k1megf+xbLFtNhg0/r87Gzrk6KcgE/TKc/opzuQ/Wpm2h mA6OzlynSaRwsrKYymzn2mAqOcT40r4sDNkTsDODR0e50uj4oh2e92GEm8TEZX10SgdS y761w1rQppYFRhyWmiysjuSuX0mV/MI6XnDRZM95jGLD3VoT8e1SjpQ9M6NN73fK4JAC tC7g== X-Forwarded-Encrypted: i=1; AJvYcCU+BJdf9OzbvVJohgOCLZdDiKPggLYRq6JGOBa5PhxSJ0sDStx2vf9LKMbLNm3A2cZp8DxkfVoj5PU=@vger.kernel.org, AJvYcCU2dpLj+kHsAdiV4xEIxX67yXVcf8AM9/IGcnGxWo+DggzFYLTzHgBZD9EItKPCO2hifP/n/CU6H7JUyDI=@vger.kernel.org, AJvYcCUWU1xfUqOvIYOXAudyqZZ+Md6aDX59KA/+bfPYIiM0Kizaoy4G2GSsnPyhKKVy+2iz1AXt3uWxkSTtMlo=@vger.kernel.org X-Gm-Message-State: AOJu0YyMHOwG2bXxK7ODMnhhubPOkvCj7bo2Sl0wnyxiR/Ejrz/D9lMY 5yN/ZVABIO0YWFSfRUwwLUP8hLmtltahOK1Mq2X8urXihmcEqe0fNzJ+TA== X-Gm-Gg: ASbGncsWoI0rLtuTn3SZVk0pXsw71wQCNElFW2kzMXNVytCJkC+NGenN1jqeX3YuwoR 9hpXLgxtKExl49IuhPFZcTpNBMO5uLvd8B8jHXxwRX62pwyK/Wb2aHiQb5z9gSzoR+5Z3s3qi1b zXpM6zPBEs4+j94bcKX1SD6SUcMUWst2kO/jXR4CDjqhm2erRKrPLsb/bHtlPuEwXOw5vlJkZEy SdP+6H/VuQ2CPGvHRniva6JZlF5pw69QKmKwUc5tYxjz5MWEw6oUHnrw3Kp3oKjTqCND3u3St+/ 5CWG0ocMj9grmTFenkT+IDXFLHr4FHGCMMez X-Google-Smtp-Source: AGHT+IFUCQdaf1gJxSDknQhy2Z+Dm5vufDvDp/v5PIZGlQ15eVmjUOCJgWaoqFmDfVj/No6fvDsovw== X-Received: by 2002:a05:6402:42c8:b0:5dc:9589:9f64 with SMTP id 4fb4d7f45d1cf-5ebcd4342bfmr7112233a12.13.1742714091393; Sun, 23 Mar 2025 00:14:51 -0700 (PDT) Received: from xeon.. ([188.163.112.51]) by smtp.gmail.com with ESMTPSA id 4fb4d7f45d1cf-5ebccfaecfbsm4218283a12.41.2025.03.23.00.14.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 23 Mar 2025 00:14:50 -0700 (PDT) From: Svyatoslav Ryhel To: Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Sebastian Reichel , Svyatoslav Ryhel Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-tegra@vger.kernel.org, linux-pm@vger.kernel.org Subject: [PATCH v1 1/4] dt-bindings: vendor-prefixes: add prefix for Pegatron Corporation Date: Sun, 23 Mar 2025 09:14:21 +0200 Message-ID: <20250323071424.48779-2-clamor95@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250323071424.48779-1-clamor95@gmail.com> References: <20250323071424.48779-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" PEGATRON Corporation is a Taiwanese electronics manufacturing company that mainly develops computing, communications and consumer electronics for branded vendors. Link https://www.pegatroncorp.com/ Signed-off-by: Svyatoslav Ryhel Acked-by: Rob Herring (Arm) --- Documentation/devicetree/bindings/vendor-prefixes.yaml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Documentation/devicetree/bindings/vendor-prefixes.yaml b/Docum= entation/devicetree/bindings/vendor-prefixes.yaml index da01616802c7..d36389aa4d7b 100644 --- a/Documentation/devicetree/bindings/vendor-prefixes.yaml +++ b/Documentation/devicetree/bindings/vendor-prefixes.yaml @@ -1146,6 +1146,8 @@ patternProperties: description: Parallax Inc. "^pda,.*": description: Precision Design Associates, Inc. + "^pegatron,.*": + description: Pegatron Corporation "^pericom,.*": description: Pericom Technology Inc. "^pervasive,.*": --=20 2.43.0 From nobody Mon Feb 9 07:23:53 2026 Received: from mail-ed1-f53.google.com (mail-ed1-f53.google.com [209.85.208.53]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id AED5220296E; Sun, 23 Mar 2025 07:14:54 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.53 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714096; cv=none; b=GQ7U9lmbpJui+np8zzx5cV9YE+WRKRQeb99YQrGSUwWj+FayIXd6ueKXh9lqbnUrCP+7djTZl1Z5c6tCcV1G0MmeYsT+ZNseS1pQHEVUKDry2evqGzBqT9x4nYSUAJ2P4aQ0tqkVVEXeQ/azTGu/S5dq8sRdPJxdBXzUjr4SeKE= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714096; c=relaxed/simple; bh=CWhQXv6t3smUOD52oWFdekfMPw+WhSEXP5k7xJ0iT2g=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=GQFoH5cGGgEDexPn6W7YMv2rCNuOHvI0ZlZr9oFTOQ1h0r1zcTJLc02ZHfNib00DVKdHmJWCs+xu09Pr3iTKNtHIOGJ9GJnsikKxFwBTpu5UjJ1NobCm0ExG29V8oWgRmwnIETyZib9Eu0kmEKDS8c1vKegRObX+xvYZ/N+fIo8= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=VtdzCkhl; arc=none smtp.client-ip=209.85.208.53 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="VtdzCkhl" Received: by mail-ed1-f53.google.com with SMTP id 4fb4d7f45d1cf-5e673822f76so5243734a12.2; Sun, 23 Mar 2025 00:14:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742714093; x=1743318893; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=29uewYC+iRTpdEimjLoyLiSalpqvIJ8kugFIJHF4NTA=; b=VtdzCkhlQtIR3cjFA88sSCeXgQZttGzzySb/+mGT28t5jRj73dN9d18PT8LVperQwN Snz8lh635Q5zP5ijmFTLhz7fdKAJk9CvjjHrrGQQGWJ7o6L0i8ir7Fn70sOQ3Qsy+li2 7Jw4FxX3j3J39yMaBElVpcybayKiMjtlNe1vFD22tZEGhOz4So8UTeWlJD0QGdjcRLoX icvs1wP4R3aiZOSmFArchus12s4l5ti+UFVTzCisHOgzJsAF7SvEudwB5u9xtyhY7mxT +ctswss5+L2SX3FPYqUUPV2SzBoZc7yC1GsXE4lkEEhitGCvEffTvxPHO2sE8EWNZup/ Erfg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742714093; x=1743318893; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=29uewYC+iRTpdEimjLoyLiSalpqvIJ8kugFIJHF4NTA=; b=G4pFuxbMjzSt4YKpo99lB2kR43SFsjhP8NYNEOoAndR4HR/4kkdOkTfouysPrQy0Gx IYeXAuOJ25naQPqRi/Q0OgpdVqUsNJLJ6V5dEzM6ne4hKQWwQvXkkhFMHCERWsx/UQEG Tf7i5MozcQBT7nHeT+KqskFfR+t7e5vNaJCg2o4NOg4/s4R0jxzlKkEDnoXHZpQOD9zo uHa/vRAgucVM+IN4IaS9R/LJ17YZphOzElmF3liN3kA2dI9SSwqNu0/5s+iP6cx42MNB FXn4G8p1FAjAFv9vwyZ8rrsKrIfE2b72eYlAhhLNtK+CiKL2gWXu7HDjm9yS5wgWgCRl PRUg== X-Forwarded-Encrypted: i=1; AJvYcCV0tnujrOjcu/L57M7UdgDGMOiWdpf+OauFEaoCimmjWW7f1KjmvnFxiLgCqEddlWKtdnhNZlvHaCA=@vger.kernel.org, AJvYcCXCIrgCiNiPtkhaLfYSz3O9znNuze9riOl+YNPLMdq0o8YK7fo5/DtRRMWQRbnIqGhnJg3hX6I5hWGotaM=@vger.kernel.org, AJvYcCXltvT+GPbOoqwP6Hep4UX1qcVXKTl8McRJX15ch3kN8onk325DtikR0eJ6Vayp/7QN0EsuUoasYQEt4tA=@vger.kernel.org X-Gm-Message-State: AOJu0YwErWPEaKXrB1DnvnmmrReDpXdqbH2wS73ecZaXEcJODOVycaqh +UVm9c8I1Mn58Jc7MmoXa/idB9bJIMo66A2H7yES6yG1z2ANxMFT X-Gm-Gg: ASbGncsb/ST1t9NSg6+MUQHHxd1h1v/rnl9RmNB/TtaWHcNlsfyv1CWZWnbzzN1z4Lj 1f5A5xdvjRC7XTGI/Q2gei7stf9+XX13EBw3jQbnkBqLuCRN3opZMJwBeNyUs2gsJpS6bPNGcbo uQis4tRB3HgwYBJY2a4CEnVWExNsCpo38FkizZvoCBZsk+BkjzwVhceVQUcyL8zCC2BIMWwPgyE AvBygQRYd2998IltM1iCWnxW02m7OyDOQvg9C0l+VWH+kF7ur2wEjf4Pi0gm440xXypXIenm2YG 14U/r/bzLPzy67GMTsd5zBo5SBMxK1Htk4kB X-Google-Smtp-Source: AGHT+IEqd+7IPPUUb7zOi8eoTIbMKKkpIbd/z7ELoYmkbF9H9wVTaXKTVrjAw53cjx+cV8jr75ScWg== X-Received: by 2002:a05:6402:27d3:b0:5e5:71e:8c63 with SMTP id 4fb4d7f45d1cf-5ebcd466aa5mr8265071a12.15.1742714092740; Sun, 23 Mar 2025 00:14:52 -0700 (PDT) Received: from xeon.. ([188.163.112.51]) by smtp.gmail.com with ESMTPSA id 4fb4d7f45d1cf-5ebccfaecfbsm4218283a12.41.2025.03.23.00.14.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 23 Mar 2025 00:14:52 -0700 (PDT) From: Svyatoslav Ryhel To: Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Sebastian Reichel , Svyatoslav Ryhel Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-tegra@vger.kernel.org, linux-pm@vger.kernel.org Subject: [PATCH v1 2/4] dt-bindings: mfd: Document Infineon/Cypress CG7153AM MCU Date: Sun, 23 Mar 2025 09:14:22 +0200 Message-ID: <20250323071424.48779-3-clamor95@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250323071424.48779-1-clamor95@gmail.com> References: <20250323071424.48779-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add binding for Cypress CG7153AM embedded controller. Pegatron implemented a custom configuration of this MCU in their Chagall tablets, utilizing it for battery monitoring. Signed-off-by: Svyatoslav Ryhel --- .../bindings/mfd/cypress,cg7153am.yaml | 55 +++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 Documentation/devicetree/bindings/mfd/cypress,cg7153am.= yaml diff --git a/Documentation/devicetree/bindings/mfd/cypress,cg7153am.yaml b/= Documentation/devicetree/bindings/mfd/cypress,cg7153am.yaml new file mode 100644 index 000000000000..f8469b5e3816 --- /dev/null +++ b/Documentation/devicetree/bindings/mfd/cypress,cg7153am.yaml @@ -0,0 +1,55 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/mfd/cypress,cg7153am.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Infineon/Cypress Semicon CG7153AM Microcontroller + +maintainers: + - Svyatoslav Ryhel + +description: + The CG7153AM, an 8-bit programmable microcontroller from Infineon/Cypress + Semiconductor, communicates over I2C and is implemented in devices like = the + Pegatron Chagall tablet for fuel gauge and battery control functions. + +$ref: /schemas/power/supply/power-supply.yaml + +properties: + compatible: + oneOf: + - items: + - enum: + - pegatron,chagall-ec # Pegatron Chagall tablet device + - const: cypress,cg7153am + - items: + const: cypress,cg7153am + + reg: + maxItems: 1 + + monitored-battery: true + power-supplies: true + +required: + - compatible + - reg + +unevaluatedProperties: false + +examples: + - | + i2c { + #address-cells =3D <1>; + #size-cells =3D <0>; + + embedded-controller@10 { + compatible =3D "pegatron,chagall-ec", "cypress,cg7153am"; + reg =3D <0x10>; + + monitored-battery =3D <&battery>; + power-supplies =3D <&mains>; + }; + }; +... --=20 2.43.0 From nobody Mon Feb 9 07:23:53 2026 Received: from mail-ed1-f53.google.com (mail-ed1-f53.google.com [209.85.208.53]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6D0B0202C39; Sun, 23 Mar 2025 07:14:56 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.53 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714098; cv=none; b=fKO21J/3NYpdlJ5ZYV9l7KtB30lHstZOC/x4ArofzxTFxe3NyAyJBvtx7pzcw07LWUwaIFiHeJF+EaUkwG8ZhdGfsmB/XmOkqHruycY7YXBvh7ErZ+Iz2pA6tRVRzrwI9+MchYZZMnbYqMkneQ3p6uys8L1866oM2CVOu2LnJls= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714098; c=relaxed/simple; bh=WRrSA50y3u7WzP72Iuo1EO/GfQTRCZVJkp8p0OdO1lQ=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=urbHf3eu08uIGvAcinSZricVfFdNkwK4wbn+Z/tps+6FRhlV17V9lCmMt5fxMI9SFeXZTptdjPVyAe0sZRnjwxA/Pf9fZec+XeBoe/osUgb2wblSk2oj0FlRY+EDUmGJc2EoyWdFvPA1ztoWHjBH3cw54WcNvGHpxOjRai6aHPo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=i/k7iy2+; arc=none smtp.client-ip=209.85.208.53 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="i/k7iy2+" Received: by mail-ed1-f53.google.com with SMTP id 4fb4d7f45d1cf-5e5cd420781so5935512a12.2; Sun, 23 Mar 2025 00:14:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742714094; x=1743318894; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=hSg8v2veHrUXZxak/qhrNIhIgEeYWoo3lRbNC7Kvpd4=; b=i/k7iy2+tluknrGB+eB8FoJIxaGPi7glmpgFn2reYrsVSqinhZX0IOIA7BHQAkdKJS oQLB8QBrENJSq3LdtDZwm2jRb58UL7nVhOS7ikSlYGHnWbjgP+bI7Klk86evTU6XbWRS xTVvVFuXp1I3p19NdGGvSnk2acvZD5Gqq3b0Vjak8PLwlFcHngqgyXguUeLW0JmzCmLL RZDtWP76mqIU2pmRVQaf3XRi9fbDKwlyiQilSsGKimqVBBq2QB69xLFMbv7r11mV59xH LP5dKCu4NjkKabpjQgtLuAhQcnLamj1kOBErJrNaCKg1q0F0+99DMdn/Sx2ofBHxvwqh 9Dyw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742714094; x=1743318894; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=hSg8v2veHrUXZxak/qhrNIhIgEeYWoo3lRbNC7Kvpd4=; b=NuAqlyCjkdTGLdSToBrSmhjjMBF48oVafaMz3hm/57rqIX62NFb17vIVQkJVwwjb5Q 7rmNpom0Y0zonpT2WFjMpQq6SQEPBlhRJoqj7G/eimIuJ/lPEBiYvRsTXjf+BwRH4okA qBbp9ksduIoHu3pRJXQ6Lg31ZjMcFFcTuK17A/Ao/+HKSHB50q5tCdxa3oIrdt276gZJ LUBsARyw7tmItM+fkyKC3AONUQpPke+vJRpxdUB/1cdcsGXxT7IhpMj+0GMhraq6qGQ1 p4RB7jiKEPLZJmGpM+30VrZCCvljQNfUud6S6Egb54xVJCV1ngrZjiKqAArC48/R6h3B rqXQ== X-Forwarded-Encrypted: i=1; AJvYcCU+fVHSTHRCAgK7SHeoxRIZJd/i81+/P0BBOajWIuJMd/Rm3D+4gN7wlTITd6GAZ5HSM+VSFxIwIBYYSI0=@vger.kernel.org, AJvYcCVioyVD3l5526vVVFcZojoKYCJz7ouPTubdzqJ43ZF1KKq3c+9sgUkBmGwfL5wJXkpcOPRJH4QVnKQ=@vger.kernel.org, AJvYcCXrnG7U6gq6Wk+g1T/dK4SdziJzR14gaZ8NtxlZklfXaM4c5TgCvc3RyrFnWhpnhZYhX0cbY3Slgf3ayiY=@vger.kernel.org X-Gm-Message-State: AOJu0YxADnoH749z4DoBbilhxkCdh2szg6S43AvBWZb0otGywUkfHbrh h1IK5zLJFgZ4AT4COcxYrEtgfB+AXGYFBDhdPrTPQqse/gg7RidF X-Gm-Gg: ASbGncsRmtWbgpYWdibZafVQQhd+9x1TCbY7tCDJFCLLutvC7/PbCgGlheqLLB/P/Po bD68BF7/iJp+MrIYeLQCfNHlqsoVeViF7JBPvfXuQyqv8tK4c7g4OaDxgj0eApfmT8i7nQ8iyua vNYc3TwJdTLIZuzQahhM3C9atDxkIolPEfy2dGCuelifXjsv7bBgYfRrlI0AbFg7Fv6RithD6eJ lgOPID6P1YBTkWTdmD33mEVQ/eta5CNSfRNu51Xh9+2Ansq3mXuMLfAr+zwIb26l4dh/h/78Ojk TPfilf0LOZl7sHrVEIwd84VAIsYy2QFFWLEB X-Google-Smtp-Source: AGHT+IFApD761jQAXGhTGK/msqA+/A3HLe3e4xYkIn4DzR8q3nCb9rTaSF7rKsiPu2i5ZLE6Nn0ljA== X-Received: by 2002:a05:6402:42cb:b0:5e4:c026:2d7a with SMTP id 4fb4d7f45d1cf-5ebcd474182mr6877637a12.16.1742714094241; Sun, 23 Mar 2025 00:14:54 -0700 (PDT) Received: from xeon.. ([188.163.112.51]) by smtp.gmail.com with ESMTPSA id 4fb4d7f45d1cf-5ebccfaecfbsm4218283a12.41.2025.03.23.00.14.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 23 Mar 2025 00:14:53 -0700 (PDT) From: Svyatoslav Ryhel To: Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Sebastian Reichel , Svyatoslav Ryhel Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-tegra@vger.kernel.org, linux-pm@vger.kernel.org Subject: [PATCH v1 3/4] power/supply: Add driver for Pegatron Chagall battery Date: Sun, 23 Mar 2025 09:14:23 +0200 Message-ID: <20250323071424.48779-4-clamor95@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250323071424.48779-1-clamor95@gmail.com> References: <20250323071424.48779-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" The Pegatron Chagall is an Android tablet utilizing a customized Cypress CG7153AM microcontroller (MCU) as its battery fuel gauge. It supports a single-cell battery and features a dual-color charging LED. Signed-off-by: Svyatoslav Ryhel --- drivers/power/supply/Kconfig | 12 + drivers/power/supply/Makefile | 1 + drivers/power/supply/chagall-battery.c | 308 +++++++++++++++++++++++++ 3 files changed, 321 insertions(+) create mode 100644 drivers/power/supply/chagall-battery.c diff --git a/drivers/power/supply/Kconfig b/drivers/power/supply/Kconfig index 9f2eef6787f7..d0fc9db524bd 100644 --- a/drivers/power/supply/Kconfig +++ b/drivers/power/supply/Kconfig @@ -107,6 +107,18 @@ config BATTERY_ACT8945A Say Y here to enable support for power supply provided by Active-semi ActivePath ACT8945A charger. =20 +config BATTERY_CHAGALL + tristate "Pegatron Chagall battery driver" + depends on I2C + depends on LEDS_CLASS + help + Say Y to include support for Cypress CG7153AM IC based battery + fuel gauge with custom firmware found in Pegatron Chagall based + tablet line. + + This driver can also be built as a module. If so, the module will be + called chagall-battery. + config BATTERY_CPCAP tristate "Motorola CPCAP PMIC battery driver" depends on MFD_CPCAP && IIO diff --git a/drivers/power/supply/Makefile b/drivers/power/supply/Makefile index 59c4a9f40d28..4ecf48a33fdd 100644 --- a/drivers/power/supply/Makefile +++ b/drivers/power/supply/Makefile @@ -23,6 +23,7 @@ obj-$(CONFIG_CHARGER_ADP5061) +=3D adp5061.o obj-$(CONFIG_BATTERY_ACT8945A) +=3D act8945a_charger.o obj-$(CONFIG_BATTERY_AXP20X) +=3D axp20x_battery.o obj-$(CONFIG_CHARGER_AXP20X) +=3D axp20x_ac_power.o +obj-$(CONFIG_BATTERY_CHAGALL) +=3D chagall-battery.o obj-$(CONFIG_BATTERY_CPCAP) +=3D cpcap-battery.o obj-$(CONFIG_BATTERY_CW2015) +=3D cw2015_battery.o obj-$(CONFIG_BATTERY_DS2760) +=3D ds2760_battery.o diff --git a/drivers/power/supply/chagall-battery.c b/drivers/power/supply/= chagall-battery.c new file mode 100644 index 000000000000..1a278331efe7 --- /dev/null +++ b/drivers/power/supply/chagall-battery.c @@ -0,0 +1,308 @@ +// SPDX-License-Identifier: GPL-2.0-or-later +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#define CHAGALL_REG_LED_AMBER 0x60 +#define CHAGALL_REG_LED_WHITE 0x70 +#define CHAGALL_REG_BATTERY_TEMPERATURE 0xa2 +#define CHAGALL_REG_BATTERY_VOLTAGE 0xa4 +#define CHAGALL_REG_BATTERY_CURRENT 0xa6 +#define CHAGALL_REG_BATTERY_CAPACITY 0xa8 +#define CHAGALL_REG_BATTERY_CHARGING_CURRENT 0xaa +#define CHAGALL_REG_BATTERY_CHARGING_VOLTAGE 0xac +#define CHAGALL_REG_BATTERY_STATUS 0xae +#define BATTERY_DISCHARGING BIT(6) +#define BATTERY_FULL_CHARGED BIT(5) +#define BATTERY_FULL_DISCHARGED BIT(4) +#define CHAGALL_REG_BATTERY_REMAIN_CAPACITY 0xb0 +#define CHAGALL_REG_BATTERY_FULL_CAPACITY 0xb2 +#define CHAGALL_REG_MAX_COUNT 0xb4 + +#define CHAGALL_BATTERY_DATA_REFRESH 5000 +#define TEMP_CELSIUS_OFFSET 2731 + +static const struct regmap_config chagall_battery_regmap_config =3D { + .reg_bits =3D 8, + .val_bits =3D 8, + .max_register =3D CHAGALL_REG_MAX_COUNT, + .reg_format_endian =3D REGMAP_ENDIAN_LITTLE, + .val_format_endian =3D REGMAP_ENDIAN_LITTLE, +}; + +struct chagall_battery_data { + struct regmap *regmap; + struct led_classdev amber_led; + struct led_classdev white_led; + struct power_supply *battery; + struct delayed_work poll_work; + u16 last_state; +}; + +static void chagall_led_set_brightness_amber(struct led_classdev *led, + enum led_brightness brightness) +{ + struct chagall_battery_data *cg =3D + container_of(led, struct chagall_battery_data, amber_led); + + regmap_write(cg->regmap, CHAGALL_REG_LED_AMBER, brightness); +} + +static void chagall_led_set_brightness_white(struct led_classdev *led, + enum led_brightness brightness) +{ + struct chagall_battery_data *cg =3D + container_of(led, struct chagall_battery_data, white_led); + + regmap_write(cg->regmap, CHAGALL_REG_LED_WHITE, brightness); +} + +static void chagall_leds_status_update(struct chagall_battery_data *cg, in= t state) +{ + switch (state) { + case POWER_SUPPLY_STATUS_FULL: + led_set_brightness(&cg->amber_led, LED_OFF); + led_set_brightness(&cg->white_led, LED_ON); + break; + + case POWER_SUPPLY_STATUS_CHARGING: + led_set_brightness(&cg->white_led, LED_OFF); + led_set_brightness(&cg->amber_led, LED_ON); + break; + + default: + led_set_brightness(&cg->amber_led, LED_OFF); + led_set_brightness(&cg->white_led, LED_OFF); + break; + } +} + +static const enum power_supply_property chagall_battery_properties[] =3D { + POWER_SUPPLY_PROP_STATUS, + POWER_SUPPLY_PROP_PRESENT, + POWER_SUPPLY_PROP_VOLTAGE_NOW, + POWER_SUPPLY_PROP_VOLTAGE_MAX, + POWER_SUPPLY_PROP_CURRENT_NOW, + POWER_SUPPLY_PROP_CURRENT_MAX, + POWER_SUPPLY_PROP_CAPACITY, + POWER_SUPPLY_PROP_TEMP, + POWER_SUPPLY_PROP_CHARGE_FULL, + POWER_SUPPLY_PROP_CHARGE_NOW, +}; + +static const unsigned int chagall_battery_prop_offs[] =3D { + [POWER_SUPPLY_PROP_TEMP] =3D CHAGALL_REG_BATTERY_TEMPERATURE, + [POWER_SUPPLY_PROP_VOLTAGE_NOW] =3D CHAGALL_REG_BATTERY_VOLTAGE, + [POWER_SUPPLY_PROP_CURRENT_NOW] =3D CHAGALL_REG_BATTERY_CURRENT, + [POWER_SUPPLY_PROP_CAPACITY] =3D CHAGALL_REG_BATTERY_CAPACITY, + [POWER_SUPPLY_PROP_CURRENT_MAX] =3D CHAGALL_REG_BATTERY_CHARGING_CURRENT, + [POWER_SUPPLY_PROP_VOLTAGE_MAX] =3D CHAGALL_REG_BATTERY_CHARGING_VOLTAGE, + [POWER_SUPPLY_PROP_STATUS] =3D CHAGALL_REG_BATTERY_STATUS, + [POWER_SUPPLY_PROP_CHARGE_NOW] =3D CHAGALL_REG_BATTERY_REMAIN_CAPACITY, + [POWER_SUPPLY_PROP_CHARGE_FULL] =3D CHAGALL_REG_BATTERY_FULL_CAPACITY, +}; + +static int chagall_battery_get_value(struct chagall_battery_data *cg, + enum power_supply_property psp, u32 *val) +{ + if (psp >=3D ARRAY_SIZE(chagall_battery_prop_offs)) + return -EINVAL; + if (!chagall_battery_prop_offs[psp]) + return -EINVAL; + + /* Battery data is stored in 2 consecutive registers with little-endian */ + return regmap_bulk_read(cg->regmap, chagall_battery_prop_offs[psp], val, = 2); +} + +static int chagall_battery_get_property(struct power_supply *psy, + enum power_supply_property psp, + union power_supply_propval *val) +{ + struct chagall_battery_data *cg =3D power_supply_get_drvdata(psy); + int ret; + + switch (psp) { + case POWER_SUPPLY_PROP_PRESENT: + val->intval =3D 1; + break; + + default: + ret =3D chagall_battery_get_value(cg, psp, &val->intval); + if (ret) + return ret; + + switch (psp) { + case POWER_SUPPLY_PROP_TEMP: + val->intval -=3D TEMP_CELSIUS_OFFSET; + break; + + case POWER_SUPPLY_PROP_VOLTAGE_MAX: + case POWER_SUPPLY_PROP_VOLTAGE_NOW: + case POWER_SUPPLY_PROP_CURRENT_MAX: + case POWER_SUPPLY_PROP_CURRENT_NOW: + case POWER_SUPPLY_PROP_CHARGE_FULL: + case POWER_SUPPLY_PROP_CHARGE_NOW: + val->intval *=3D 1000; + break; + + case POWER_SUPPLY_PROP_STATUS: + if (val->intval & BATTERY_FULL_CHARGED) + val->intval =3D POWER_SUPPLY_STATUS_FULL; + else if (val->intval & BATTERY_FULL_DISCHARGED) + val->intval =3D POWER_SUPPLY_STATUS_NOT_CHARGING; + else if (val->intval & BATTERY_DISCHARGING) + val->intval =3D POWER_SUPPLY_STATUS_DISCHARGING; + else + val->intval =3D POWER_SUPPLY_STATUS_CHARGING; + break; + + default: + break; + } + + break; + } + + return 0; +} + +static void chagall_battery_poll_work(struct work_struct *work) +{ + struct chagall_battery_data *cg =3D + container_of(work, struct chagall_battery_data, poll_work.work); + u32 state; + int ret; + + ret =3D chagall_battery_get_value(cg, POWER_SUPPLY_PROP_STATUS, &state); + if (ret) + return; + + if (state & BATTERY_FULL_CHARGED) + state =3D POWER_SUPPLY_STATUS_FULL; + else if (state & BATTERY_DISCHARGING) + state =3D POWER_SUPPLY_STATUS_DISCHARGING; + else + state =3D POWER_SUPPLY_STATUS_CHARGING; + + if (cg->last_state !=3D state) { + cg->last_state =3D state; + power_supply_changed(cg->battery); + } + + chagall_leds_status_update(cg, state); + + /* continuously send uevent notification */ + schedule_delayed_work(&cg->poll_work, + msecs_to_jiffies(CHAGALL_BATTERY_DATA_REFRESH)); +} + +static const struct power_supply_desc chagall_battery_desc =3D { + .name =3D "chagall-battery", + .type =3D POWER_SUPPLY_TYPE_BATTERY, + .properties =3D chagall_battery_properties, + .num_properties =3D ARRAY_SIZE(chagall_battery_properties), + .get_property =3D chagall_battery_get_property, + .external_power_changed =3D power_supply_changed, +}; + +static int chagall_battery_probe(struct i2c_client *client) +{ + struct chagall_battery_data *cg; + struct device *dev =3D &client->dev; + struct power_supply_config cfg =3D { }; + int ret; + + cg =3D devm_kzalloc(dev, sizeof(*cg), GFP_KERNEL); + if (!cg) + return -ENOMEM; + + cfg.drv_data =3D cg; + cfg.fwnode =3D dev_fwnode(dev); + + i2c_set_clientdata(client, cg); + + cg->regmap =3D devm_regmap_init_i2c(client, &chagall_battery_regmap_confi= g); + if (IS_ERR(cg->regmap)) + return dev_err_probe(dev, PTR_ERR(cg->regmap), "cannot allocate regmap\n= "); + + cg->last_state =3D POWER_SUPPLY_STATUS_UNKNOWN; + cg->battery =3D devm_power_supply_register(dev, &chagall_battery_desc, &c= fg); + if (IS_ERR(cg->battery)) + return dev_err_probe(dev, PTR_ERR(cg->battery), "failed to register powe= r supply\n"); + + cg->amber_led.name =3D "power::amber"; + cg->amber_led.max_brightness =3D 1; + cg->amber_led.flags =3D LED_CORE_SUSPENDRESUME; + cg->amber_led.brightness_set =3D chagall_led_set_brightness_amber; + + ret =3D devm_led_classdev_register(dev, &cg->amber_led); + if (ret) + return dev_err_probe(dev, ret, "failed to register amber LED\n"); + + cg->white_led.name =3D "power::white"; + cg->white_led.max_brightness =3D 1; + cg->white_led.flags =3D LED_CORE_SUSPENDRESUME; + cg->white_led.brightness_set =3D chagall_led_set_brightness_white; + + ret =3D devm_led_classdev_register(dev, &cg->white_led); + if (ret) + return dev_err_probe(dev, ret, "failed to register white LED\n"); + + led_set_brightness(&cg->amber_led, LED_OFF); + led_set_brightness(&cg->white_led, LED_OFF); + + ret =3D devm_delayed_work_autocancel(dev, &cg->poll_work, chagall_battery= _poll_work); + if (ret) + return ret; + + schedule_delayed_work(&cg->poll_work, msecs_to_jiffies(CHAGALL_BATTERY_DA= TA_REFRESH)); + return 0; +} + +static int __maybe_unused chagall_battery_suspend(struct device *dev) +{ + struct i2c_client *client =3D to_i2c_client(dev); + struct chagall_battery_data *cg =3D i2c_get_clientdata(client); + + cancel_delayed_work_sync(&cg->poll_work); + return 0; +} + +static int __maybe_unused chagall_battery_resume(struct device *dev) +{ + struct i2c_client *client =3D to_i2c_client(dev); + struct chagall_battery_data *cg =3D i2c_get_clientdata(client); + + schedule_delayed_work(&cg->poll_work, msecs_to_jiffies(CHAGALL_BATTERY_DA= TA_REFRESH)); + return 0; +} + +static SIMPLE_DEV_PM_OPS(chagall_battery_pm_ops, + chagall_battery_suspend, chagall_battery_resume); + +static const struct of_device_id chagall_of_match[] =3D { + { .compatible =3D "pegatron,chagall-ec" }, + { } +}; +MODULE_DEVICE_TABLE(of, chagall_of_match); + +static struct i2c_driver chagall_battery_driver =3D { + .driver =3D { + .name =3D "chagall-battery", + .pm =3D &chagall_battery_pm_ops, + .of_match_table =3D chagall_of_match, + }, + .probe =3D chagall_battery_probe, +}; +module_i2c_driver(chagall_battery_driver); + +MODULE_AUTHOR("Svyatoslav Ryhel "); +MODULE_DESCRIPTION("Pegatron Chagall fuel gauge driver"); +MODULE_LICENSE("GPL"); --=20 2.43.0 From nobody Mon Feb 9 07:23:53 2026 Received: from mail-ed1-f52.google.com (mail-ed1-f52.google.com [209.85.208.52]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id AAE39202F90; Sun, 23 Mar 2025 07:14:57 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.52 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714099; cv=none; b=OVBg39+LnaTFEG6NeeUcrY12cpTIXZ/QAc7pQX+k7uTld9z7wPYF7WRE3DeVyEvBFBvUi9ZTlD8U0ERD9gsCXlWsM4zlGTUhc1j8afbv8wfshwU+j4zdeNJHEyRWkXDyYF9LQTKE1W05W+pgrOgjSfqAEzn73dhVkGXp5mWWkYg= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1742714099; c=relaxed/simple; bh=K954LDETOESsqcW9N5tUsbdpbqeKHsx9OEWL6PY90WM=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=YY1xuaKZ8kMklPLzNa99KzWeuXO1vpRiNoR+RvFzWaQNSnMqfdH+fZcFWtjOtmYhuiaxKMynzrdN9IaEjlXxxJmtDDgGVBYnIJntL43+RyUK6Gw3HAQsfzwZm5pSJLAgLg04l6RWcCgMaykPQySWuTcGAMu5rUEo5SGm1NIaSuo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=DJddlgKl; arc=none smtp.client-ip=209.85.208.52 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="DJddlgKl" Received: by mail-ed1-f52.google.com with SMTP id 4fb4d7f45d1cf-5e5b6f3025dso4998063a12.1; Sun, 23 Mar 2025 00:14:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1742714096; x=1743318896; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=d6o/yy0mJ6gEoAPM9wSzc0GuosBaD/tZXos6jZFch6o=; b=DJddlgKlCwxJ1X+msvBYGMVXbPGfnfMDUXHQvqEiaqCeVy4vKhRMwzRgbBhdMZ+ut2 LCJZYOTaZzdhzK1fel/xieq4XsmybDYu9EJ1VxjDozFxff30sJjUAa9d6EK9opR07VMf bsApo0xbxkZq9FdihJcmf/5n1GBUtYJXnWifYgKKgsqYZ8852QCbzdio86img+1c986Q h5w/Zjrzc35WW4dbMEh+1lWgCHV1/l0ScggeraHojsiZ61Ypgcj6WJU+cPwIcP9qaCkS eNURwC6TmqIrZyCwKeaKtVJiohc/pJN117Lk7c9XIe7Ahb4lQ/BHuncVEekP28gIXNx0 U/eQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1742714096; x=1743318896; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=d6o/yy0mJ6gEoAPM9wSzc0GuosBaD/tZXos6jZFch6o=; b=Q4cfib5a+U60sM1WJpGzyJEhfdrztgYaMfAlxvATbQQ0oZ2jIXRX/w5sU58AZTkpwA AjAht3N0+RaD4zv4WK7zBSmOtwDhvfbU7qlEOnGMGfLjAdbQTHtoU2R0YKpytrXH565b VInyz758k1HBC6vKqdn/azCNLuPLu1Xc3V6n+iRLyCkpM3QD2bE8Y1BNQMxHBAd09qB5 puVwy5Hk0HrY1XmgLPLtlJSLq8Z+XChWoik68lHEwlt8BfVQ0QdeskCv9OOLnssmDKTM Fbr4TDX051gnkKXxeaK7TiSefTY/D8XrtVueS7wRqs23k1stRpjeftPb5oi1geBiVjl7 FYGg== X-Forwarded-Encrypted: i=1; AJvYcCWLbnEafuIJpzi2dwQeoHudU8vheI6VXCop1exwlJ8yL2Fs2o/UFA9kohymDzaFNd7zDUsls0xxqk8Ie9M=@vger.kernel.org, AJvYcCWTdQKfGOUQYsinmNetWtE9Nax2Z9faUEvBCjvvrZdVCt0Kd4k4mdsCEFaiucGjxDqYPdLp0+dBciw=@vger.kernel.org, AJvYcCXBiogLjTJZm84Kd624SAa+MyovYBZCODQv6a0PZdjgvklvX7GP9d3j4EvNIBf4gt63zv1QfcNoEQTttnw=@vger.kernel.org X-Gm-Message-State: AOJu0YxIG7DVn1AsXj4lMJtYqA+A3sHFLhx6gKV8H8andQHe8/oPrnVs bg8c9FjGXg4zTLkOWPO4CkU0R1TBHRYcBhydMBjcFcxkMS5NPb40 X-Gm-Gg: ASbGncsQPH/wgZxORbNCNw8/hEVMa0MyuocbbRdhIQmcgdlvB+WyYqEcbILJGISBNYy /d3xcIGpTIxH4wi4vI/5U2bzMoX2PgERCfzBau6NJXc2v6nRqfloZD/+PTyEc72UMD86+Bs8OR1 bS57naO/U32Z0IrukxWtpUYzAaSnQhXQY5H7Zvg8yx3gRgpAnLB3xINr08mZ92sjrm2y7vv59b3 1RvT/9dls5eWRl65k1uvLGsu30rB1SJ6jxJEANm/RdRJn9z5A/xYBZhYJEByliCFh6RBdndsEbg jRJzjhYOx2mm0KzqsSfUQ6OOwMTpsqT0NzIO X-Google-Smtp-Source: AGHT+IFSwpraoqw/BQA/iEzngeutOVj9G954A9pOuqXbEzu4aPxLZEfsQu9PRth0KOUMeytXUYbUiw== X-Received: by 2002:a17:907:bb4b:b0:ac4:3cd:2cb2 with SMTP id a640c23a62f3a-ac403cd2eb7mr567966266b.1.1742714095690; Sun, 23 Mar 2025 00:14:55 -0700 (PDT) Received: from xeon.. ([188.163.112.51]) by smtp.gmail.com with ESMTPSA id 4fb4d7f45d1cf-5ebccfaecfbsm4218283a12.41.2025.03.23.00.14.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 23 Mar 2025 00:14:55 -0700 (PDT) From: Svyatoslav Ryhel To: Lee Jones , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Thierry Reding , Jonathan Hunter , Sebastian Reichel , Svyatoslav Ryhel Cc: devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-tegra@vger.kernel.org, linux-pm@vger.kernel.org Subject: [PATCH v1 4/4] ARM: tegra: chagall: Add embedded controller node Date: Sun, 23 Mar 2025 09:14:24 +0200 Message-ID: <20250323071424.48779-5-clamor95@gmail.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250323071424.48779-1-clamor95@gmail.com> References: <20250323071424.48779-1-clamor95@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Add embedded controller node to Pegatron Chagall device-tree. Signed-off-by: Svyatoslav Ryhel --- .../boot/dts/nvidia/tegra30-pegatron-chagall.dts | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/arch/arm/boot/dts/nvidia/tegra30-pegatron-chagall.dts b/arch/a= rm/boot/dts/nvidia/tegra30-pegatron-chagall.dts index 4012f9c799a8..fc9eeec54692 100644 --- a/arch/arm/boot/dts/nvidia/tegra30-pegatron-chagall.dts +++ b/arch/arm/boot/dts/nvidia/tegra30-pegatron-chagall.dts @@ -1155,6 +1155,14 @@ lcd_ddc: i2c@7000c000 { status =3D "okay"; clock-frequency =3D <400000>; =20 + embedded-controller@10 { + compatible =3D "pegatron,chagall-ec", "cypress,cg7153am"; + reg =3D <0x10>; + + monitored-battery =3D <&battery>; + power-supplies =3D <&mains>; + }; + /* Wolfson Microelectronics WM8903 audio codec */ wm8903: audio-codec@1a { compatible =3D "wlf,wm8903"; @@ -2596,6 +2604,14 @@ backlight: backlight { default-brightness-level =3D <15>; }; =20 + battery: battery-cell { + compatible =3D "simple-battery"; + device-chemistry =3D "lithium-ion-polymer"; + charge-full-design-microamp-hours =3D <3050000>; + energy-full-design-microwatt-hours =3D <23000000>; + operating-range-celsius =3D <0 45>; + }; + /* PMIC has a built-in 32KHz oscillator which is used by PMC */ clk32k_in: clock-32k { compatible =3D "fixed-clock"; --=20 2.43.0