Received: by 2002:a17:90a:2044:0:0:0:0 with SMTP id n62csp534794pjc; Mon, 20 May 2019 11:24:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqzVXngurb6Ca0bEDnHDdFCOTI3HP8tIVKATpuK/04HfmsAm/SuECWxHbVSRY++sf59fX55R X-Received: by 2002:a17:902:e7:: with SMTP id a94mr52544893pla.182.1558376656648; Mon, 20 May 2019 11:24:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558376656; cv=none; d=google.com; s=arc-20160816; b=b+qM5Yy46fUbSizmkaiw66WHs+3yuBsNI8b4R71t4xq21FvScxqYl/Vz6gZDM8TnR7 IRFPzirwPXzkYEDsjXrhmGIRKhGLh+JT9Nl72HduRLR732JvbWW6aQTkdUwIJjHHE7FP mM+C7eSddgvU/Kz4+Qg/inev2coOfYfjKY1dgNml0ylfL+yctYUe/9jDTQgBHrIxYyjq V9nkBQRTYDyXOWnFNqWTqd8EYboWCI5XAY8j82bkl01J3Qe93Kk/2b9lJ6misJ/R+BEu EZHUVg53hUjhyS21j6rHf+QpP/97ttEJeFWy9KHG33E0FG2GT1oweKgomhPfcgKWsw0U VHag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:dkim-signature; bh=m8cdXZ8FfH0krHWZKQDnrPe9eKnA6LedLfVz+I5dPck=; b=vIou/WSPO8eG3InH0U2maqX/bjQaCQv7U2SrFRJZHqJXB2xJExKQO13Ank1h5TP7Ux ZHkj4sT+ogrXkgNR739vPWjr0OjxpBcjjCqsrAMqN51QVRrfGAvvLoFff7IJMtFUjc4V foGLDzzemP5QycqOjeED0ot9eeAP7uZuagFsPRRkMKz3X6z9fMO5dqFSuepjTbH8s4Hb oxIl5nfne5cLYl8Ody+c6FYUHxa/6kw0soOwwTMEKUBUHxMc09Zo1SSBsfeFECIg2LTL yUPEJ8L1OMSJAeQRZhLT4+dkhHDCyywoV2vHoingq2vfWPYOjtFyumfgplDlV7AGNI68 x/bg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@akkea.ca header.s=mail header.b="NZ/lQ9Z6"; dkim=pass header.i=@akkea.ca header.s=mail header.b=fPG2NCT1; 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 r69si11873536pgr.120.2019.05.20.11.24.02; Mon, 20 May 2019 11:24:16 -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; dkim=pass header.i=@akkea.ca header.s=mail header.b="NZ/lQ9Z6"; dkim=pass header.i=@akkea.ca header.s=mail header.b=fPG2NCT1; 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 S1727387AbfETSHf (ORCPT + 99 others); Mon, 20 May 2019 14:07:35 -0400 Received: from node.akkea.ca ([192.155.83.177]:58454 "EHLO node.akkea.ca" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727342AbfETSH2 (ORCPT ); Mon, 20 May 2019 14:07:28 -0400 Received: from localhost (localhost [127.0.0.1]) by node.akkea.ca (Postfix) with ESMTP id 6E2134E2051; Mon, 20 May 2019 18:07:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=akkea.ca; s=mail; t=1558375647; bh=m8cdXZ8FfH0krHWZKQDnrPe9eKnA6LedLfVz+I5dPck=; h=From:To:Cc:Subject:Date:In-Reply-To:References; b=NZ/lQ9Z66p9K4I4tS3uinE/saUc49yrO98R6dyqM5rV96jllHwQHTYoireeyc2RNV GptpgSic9UD9Ub2mb+AIFzYe6CS0/e6qMQ9eMkwp7+fNLlxsfsn80ND3CB7zYNYeD9 Ib6WZCmDeAdJvGcN4poaxVCn5eGlTHCvVMhvuyL8= X-Virus-Scanned: Debian amavisd-new at mail.akkea.ca Received: from node.akkea.ca ([127.0.0.1]) by localhost (mail.akkea.ca [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id SVYSlngOg6vY; Mon, 20 May 2019 18:07:27 +0000 (UTC) Received: from midas.localdomain (S0106788a2041785e.gv.shawcable.net [70.66.86.75]) by node.akkea.ca (Postfix) with ESMTPSA id 988094E204D; Mon, 20 May 2019 18:07:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=akkea.ca; s=mail; t=1558375646; bh=m8cdXZ8FfH0krHWZKQDnrPe9eKnA6LedLfVz+I5dPck=; h=From:To:Cc:Subject:Date:In-Reply-To:References; b=fPG2NCT1oq+LRMus8ji9WZO99Lj8z7KD+b3CONi+8CFpARsAp1b1cat+ri3vRq2yW LXm4XrhTkBo2dr20mvYdETSKmlQVvSY4aVCnw2gGILNvhzJ+3rvZzZib4ebjE+9dJ+ OaQzHdMh8zhNMw7hgPb+Er4REQ6Hb5SQKRjuP9b0= From: "Angus Ainslie (Purism)" To: angus.ainslie@puri.sm Cc: Sebastian Reichel , Rob Herring , Mark Rutland , linux-pm@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Eric Kuzmenko , Angus Ainslie Subject: [PATCH 1/2] power: supply: bq25890: Add support for setting bq25890 and bq25896's VINDPM Date: Mon, 20 May 2019 11:07:11 -0700 Message-Id: <20190520180712.32405-2-angus@akkea.ca> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190520180712.32405-1-angus@akkea.ca> References: <20190520180712.32405-1-angus@akkea.ca> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Eric Kuzmenko The bq25890 has low voltage protection on VIN. Allow the register to be set from the device tree. Signed-off-by: Eric Kuzmenko Signed-off-by: Angus Ainslie (Purism) --- drivers/power/supply/bq25890_charger.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/drivers/power/supply/bq25890_charger.c b/drivers/power/supply/bq25890_charger.c index 66991e6f75d9..34fc89776994 100644 --- a/drivers/power/supply/bq25890_charger.c +++ b/drivers/power/supply/bq25890_charger.c @@ -75,6 +75,8 @@ struct bq25890_init_data { u8 boosti; /* boost current limit */ u8 boostf; /* boost frequency */ u8 ilim_en; /* enable ILIM pin */ + u8 force_vindpm;/* force vinmin threshold */ + u8 vindpm; /* vinmin threshold */ u8 treg; /* thermal regulation threshold */ }; @@ -250,6 +252,7 @@ enum bq25890_table_ids { TBL_VREG, TBL_BOOSTV, TBL_SYSVMIN, + TBL_VINDPM, /* lookup tables */ TBL_TREG, @@ -289,6 +292,7 @@ static const union { [TBL_VREG] = { .rt = {3840000, 4608000, 16000} }, /* uV */ [TBL_BOOSTV] = { .rt = {4550000, 5510000, 64000} }, /* uV */ [TBL_SYSVMIN] = { .rt = {3000000, 3700000, 100000} }, /* uV */ + [TBL_VINDPM] = { .rt = {2600000, 15300000, 100000} }, /* uV */ /* lookup tables */ [TBL_TREG] = { .lt = {bq25890_treg_tbl, BQ25890_TREG_TBL_SIZE} }, @@ -621,6 +625,8 @@ static int bq25890_hw_init(struct bq25890_device *bq) {F_BOOSTI, bq->init_data.boosti}, {F_BOOSTF, bq->init_data.boostf}, {F_EN_ILIM, bq->init_data.ilim_en}, + {F_FORCE_VINDPM, bq->init_data.force_vindpm}, + {F_VINDPM, bq->init_data.vindpm}, {F_TREG, bq->init_data.treg} }; @@ -783,11 +789,14 @@ static int bq25890_fw_read_u32_props(struct bq25890_device *bq) {"ti,boost-max-current", false, TBL_BOOSTI, &init->boosti}, /* optional properties */ - {"ti,thermal-regulation-threshold", true, TBL_TREG, &init->treg} + {"ti,thermal-regulation-threshold", + true, TBL_TREG, &init->treg}, + {"ti,vinmin-threshold", true, TBL_VINDPM, &init->vindpm} }; /* initialize data for optional properties */ init->treg = 3; /* 120 degrees Celsius */ + init->vindpm = 0x12; /* 4.4V */ for (i = 0; i < ARRAY_SIZE(props); i++) { ret = device_property_read_u32(bq->dev, props[i].name, @@ -820,6 +829,8 @@ static int bq25890_fw_probe(struct bq25890_device *bq) init->ilim_en = device_property_read_bool(bq->dev, "ti,use-ilim-pin"); init->boostf = device_property_read_bool(bq->dev, "ti,boost-low-freq"); + init->force_vindpm = + device_property_read_bool(bq->dev, "ti,use-vinmin-threshold"); return 0; } -- 2.17.1