Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751536AbdFGPUz (ORCPT ); Wed, 7 Jun 2017 11:20:55 -0400 Received: from gagarine.paulk.fr ([109.190.93.129]:64045 "EHLO gagarine.paulk.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751405AbdFGPUw (ORCPT ); Wed, 7 Jun 2017 11:20:52 -0400 Message-ID: <1496848839.5534.7.camel@paulk.fr> Subject: Re: [PATCH 5/5] power: supply: bq27xxx: Correct supply status with current draw From: Paul Kocialkowski To: Pavel Machek Cc: linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, Pali =?ISO-8859-1?Q?Roh=E1r?= , "Andrew F . Davis" , Sebastian Reichel , Chris Lapa , Matt Ranostay Date: Wed, 07 Jun 2017 18:20:39 +0300 In-Reply-To: <20170607075218.GA6268@amd> References: <20170430182727.24412-1-contact@paulk.fr> <20170430182727.24412-5-contact@paulk.fr> <20170528191619.GA20159@xo-6d-61-c0.localdomain> <1496249719.1774.1.camel@paulk.fr> <20170531173207.GA10763@amd> <1496258936.2038.8.camel@paulk.fr> <1496819733.927.16.camel@paulk.fr> <20170607075218.GA6268@amd> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.24.2 Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2757 Lines: 72 Hey, On Wed, 2017-06-07 at 09:52 +0200, Pavel Machek wrote: > I'd pass to userspace what the controller reports. Yes, I seldom see > > > > "STATUS_FULL" but that may be a problem we need to track down. > > > > > > The controller is known, from my experience, to not be reliable in that > > > regard, > > > so I don't think it makes sense to pass a state that doesn't reflect the > > > actual > > > state of charging just because the chip tells us so. > > > > > > Worst case, we could also have a dt property to enable that kind of fixup > > > workaround and let every device maintainer decide whether it is relevant > > > for > > > their device. > > > > Actually, since a similar fix[0] was accepted in sbs-battery, I'd rather not > > make this optional but rather make it the default and perhaps have a dt prop > > to > > disable it. > > > > [0]: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/comm > > it/? > > h=v4.12-rc4&id=7f93e1fa032bb5ee19b868b9649bc98c82553003 > > Is there some documentation that explains what different power supply > statuses mean? Because without that, we can have long and useless > discussions. Well, I couldn't really find much except the following from Documentation/ (which is not that helpful, and the BATTERY_STATUS_* don't seem to exist anymore): " STATUS - this attribute represents operating status (charging, full, discharging (i.e. powering a load), etc.). This corresponds to BATTERY_STATUS_* values, as defined in battery.h. " Generally speaking, I think the question to be asked is what information users will be interested in in each scenario we have to consider. > If you have 40Wh battery, and you are charging it with 1mW, I don't > believe you should be indicating "charging". That battery is > full. Yes, even full batteries are sometimes charged with very low > currents to keep them full. That makes sense. Note that this patch was however designed to solve the problem the other way round: my device will report full battery when the PSU was disconnected and that it is, in fact, drawing significant current. > And I'm not sure what this is supposed to do, but its quite strange > code. Could you comment on what is strange about it? This function corrects the status based on the current flow as explained through this thread. > +static int sbs_status_correct(struct i2c_client *client, int *intval) > +{ > + int ret; > + > + ret = sbs_read_word_data(client, sbs_data[REG_CURRENT].addr); > + if (ret < 0) > + return ret; > + > + ret = (s16)ret; > + -- Paul Kocialkowski, developer of free digital technology and hardware support Website: https://www.paulk.fr/ Coding blog: https://code.paulk.fr/ Git repositories: https://git.paulk.fr/ https://git.code.paulk.fr/