Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp1010109ybh; Thu, 12 Mar 2020 15:25:40 -0700 (PDT) X-Google-Smtp-Source: ADFU+vs+Hacy/vGU4XDIgDavW57bTjAOsaO6QWxN7OrKU4IQWH9nTzuN3v63Ds47urnI1cagUWKM X-Received: by 2002:aca:53cb:: with SMTP id h194mr4685363oib.108.1584051939967; Thu, 12 Mar 2020 15:25:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584051939; cv=none; d=google.com; s=arc-20160816; b=QhPtsKUmKXCQSQReDAQ7GKzCor+rk5puXUiR6hdNdwxIPbZpOtSiiOdh6IVUldE1Gp tLBQmghZdWpeQ0Rm2+QHgpp/rHJVQbukQ/WOKT5C+DC8iRIKEwI3FduplvthbYGfX0W/ jzmk6wU58dIg0shPh0pZJFizQeKDHfqViPVV9I14i+7DReYAGRj+v9ND1CSaGrzCttI7 CUpqAFDkgWY55cHeFtuygOCQlUM1fTptn46mzh87N5YLA349yRXCv8YA+SKd1zg1uBm+ MBjs6VZnfVijUShsA1vkkgo/LwSzPclLsHNwQymNISAWuaSfp3ZPlgPQbi6P6QkL2EZ4 t5ew== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=Su+lDhd9yjHKdYoQ/lv1VgDz8LLCDJvrSxruX1ggkyA=; b=VOT3iKdyv9XLqWYz3gMl8AJbIf1r01WbYzsWTRC1wrBiso+n9w2kXk1TswRGF7WfIt nit3TKSNeWueGhNHYxZ7EEaCz3WLzFFkWgGBJUlk6ujceK6ijx0WUAvDqMztfXL4qBFN TrVnDVYlFRdBcebUqwGb2FhH4hdiC74KNgy8JnZeIp2eqfdKpjLMftFazKhafvwzR40m DwU0bp2hDZsP/r//YcbqI2TU+PeQG5qdFccyMa3H40yexqCoWEMqV9Oi+QRlTvzS06QB GpFJKzZkazwjs88A02S5Ip6fQcN42JoB6BAZqfo9wSZRYUz3qfnHSWMHnIO2sqTNDBbR 31nw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m5si3674774ote.187.2020.03.12.15.25.27; Thu, 12 Mar 2020 15:25:39 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726822AbgCLWZD (ORCPT + 99 others); Thu, 12 Mar 2020 18:25:03 -0400 Received: from mail.manjaro.org ([176.9.38.148]:58826 "EHLO mail.manjaro.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726715AbgCLWZD (ORCPT ); Thu, 12 Mar 2020 18:25:03 -0400 Received: from localhost (localhost [127.0.0.1]) by mail.manjaro.org (Postfix) with ESMTP id 212C037025E5; Thu, 12 Mar 2020 23:25:01 +0100 (CET) X-Virus-Scanned: Debian amavisd-new at manjaro.org Received: from mail.manjaro.org ([127.0.0.1]) by localhost (manjaro.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id ZTCbUDLXMtRJ; Thu, 12 Mar 2020 23:24:58 +0100 (CET) From: Tobias Schramm To: Andy Shevchenko , Sebastian Reichel , Rob Herring , Mark Rutland , Daniel Thompson Cc: Maxime Ripard , Sam Ravnborg , Heiko Stuebner , Stephan Gerhold , Mark Brown , Mauro Carvalho Chehab , "David S. Miller" , Greg Kroah-Hartman , Jonathan Cameron , linux-pm@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Tobias Schramm Subject: [PATCH v4 0/3] Add support for CellWise cw2015 fuel gauge Date: Thu, 12 Mar 2020 23:24:45 +0100 Message-Id: <20200312222448.25097-1-t.schramm@manjaro.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patchset adds support for the CellWise cw2015 fuel gauge. The CellWise cw2015 fuel gauge is a shuntless, single-cell Li-Ion fuel gauge. It is used in the pine64 Pinebook Pro laptop. This is v4 of the patchset. This version incorporates an additional review by Andy and a small spelling fix. I've kept the cellwise,battery-profile property in the device tree. Its content describes characteristics of the battery built into a device. The exact format is unknown and not publicly documented. It is likely comprised of some key parameters of the battery (chemistry, voltages, design capacity) and parameters for tuning the internal state of charge approximation function. Since v2 CellWise has confirmed to me that the only way to obtain the profile blob is to mail them batteries for testing. Thus we will need to keep that property. In general I'm not 100 % sure about my json-schema binding for the gauge. It is my first time ever writing a json-schema binding and I'm not sure whether properties like power-supplies or monitored-battery need to be added to a separate, common schema for power supplies or not. Best Regards, Tobias Schramm Changelog: v2: * Change subject to "Add support for CellWise cw2015 fuel gauge" * Rewrite bindings as json-schema * Use default power-supplies handling * Use regmap for register access * Use standard simple-battery node * Replace printk/pr_* by dev_{dbg,info,warn,err} * Use cancel_delayed_work_sync in remove * General code cleanup v3: * Incorporate review by Andy * Add cellwise vendor prefix * Rename cellwise,bat-config-info property to cellwise,battery-profile * Remove most state of charge post-processing * Use fwnode interface * General code cleanup * Lots of code style fixes v4: * Implement additional changes requested by Andy * Use fwnode inline wrappers * Clean up waiting for gauge * Minor code style fixes Tobias Schramm (3): dt-bindings: Document cellwise vendor-prefix dt-bindings: power: supply: add cw2015_battery bindings power: supply: add CellWise cw2015 fuel gauge driver .../bindings/power/supply/cw2015_battery.yaml | 83 ++ .../devicetree/bindings/vendor-prefixes.yaml | 2 + MAINTAINERS | 6 + drivers/power/supply/Kconfig | 8 + drivers/power/supply/Makefile | 1 + drivers/power/supply/cw2015_battery.c | 759 ++++++++++++++++++ 6 files changed, 859 insertions(+) create mode 100644 Documentation/devicetree/bindings/power/supply/cw2015_battery.yaml create mode 100644 drivers/power/supply/cw2015_battery.c -- 2.24.1