Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp3679645ybk; Tue, 19 May 2020 10:20:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw0ueBEZ84HXEKiZe+Oup8OV3LOk/W+oYP5Yi3AIWSvzcXJ2IGAnsvHM5uHqLLx3DLEJRDa X-Received: by 2002:a05:6402:2292:: with SMTP id cw18mr13794edb.217.1589908855017; Tue, 19 May 2020 10:20:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589908855; cv=none; d=google.com; s=arc-20160816; b=nhAt+0xqQfGqxxtrXopjrXUWY6LO0iPZHD0JlWwkp9CSQnkQ5X+MiktpjQIQ3B1frY DPI2NAAaGDh2EuddbgrtCu4ChuGz5alTzeoBohtZce+eV7pvBKRzh8iOCinROeESx8yw BGm9yPoT3eG8TACPW4s8ShUS+lGQp2bWS3Po4+pO7gbm5fKJ1PXokxk+kl6Cjd8Q6mII 98YMYMA8Vt+IZORB+tdvTAbo8NWjbVv03OLF6N9MsmV9AjD9JZyzA+Lv+TA7YSeqADFS jkDrPLMzsLqnu1uPdSG6uzTP08DHpG+z0ztudXFEr2Es6O4zPi5gX2+v2Jvy0qIYmqzq 9uyA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=u9MuVS5Z4dEpCImA8CLdh3VAMXKG5b1PtenlLbgYx2g=; b=AegSvaJCjphiFYMVXj9i07upfbsdJQ2jlWx1XKcpT9ml6Y64XTFnpcoDOzritHNUSM rEh/gYsLHwuVNRshVI88V2R4xHik9VuRWAJ4r2qaYZkvyF8761gzGLu2ucr+UQJudBNa RSfe6TxUumfxSvkAO6Rk4HFgT+ZUNtViKJu9KnkflkaTCDB4i0zyyasgOHYivPkarT1k nKZHBuVZXU61Nb1B6ZiDRtImprLmRtj0YMUOY3Qp0gETJLd6KpEqhB/49RcYOCgehFZF IiH+Y9zJXAhZav5RaLSPaqxK3xKSFbF4VAtohTyX2lVOBrrPmxtseb/AkRKxG0E+ldv4 QLNA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b="eedoNQJ/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q3si287561ejb.514.2020.05.19.10.20.28; Tue, 19 May 2020 10:20:54 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b="eedoNQJ/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729238AbgESRQA (ORCPT + 99 others); Tue, 19 May 2020 13:16:00 -0400 Received: from fllv0016.ext.ti.com ([198.47.19.142]:50204 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729001AbgESRP7 (ORCPT ); Tue, 19 May 2020 13:15:59 -0400 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id 04JHFvlQ117977; Tue, 19 May 2020 12:15:57 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1589908557; bh=u9MuVS5Z4dEpCImA8CLdh3VAMXKG5b1PtenlLbgYx2g=; h=Subject:To:CC:References:From:Date:In-Reply-To; b=eedoNQJ/IZO+PCGyrR4V9EMeFcv//9WuIGa85xRrnU2sywB5fwYjoanqbE5bJv9Fe 5ZkVbdjqr0PV5NCl0+TopWps5TvTyuSEigO338o2blSOnKsEFfQFmSTCmOh/NsyPiv Qg+oPTrZJsRufSQz8Jj/lFqeLByzVAL3HwnmBglM= Received: from DFLE113.ent.ti.com (dfle113.ent.ti.com [10.64.6.34]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 04JHFv5C028049 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 19 May 2020 12:15:57 -0500 Received: from DFLE109.ent.ti.com (10.64.6.30) by DFLE113.ent.ti.com (10.64.6.34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3; Tue, 19 May 2020 12:15:57 -0500 Received: from lelv0326.itg.ti.com (10.180.67.84) by DFLE109.ent.ti.com (10.64.6.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3 via Frontend Transport; Tue, 19 May 2020 12:15:57 -0500 Received: from [10.250.43.45] (ileax41-snat.itg.ti.com [10.172.224.153]) by lelv0326.itg.ti.com (8.15.2/8.15.2) with ESMTP id 04JHFujx097330; Tue, 19 May 2020 12:15:57 -0500 Subject: Re: [PATCH v7 3/3] power: supply: bq25150 introduce the bq25150 To: "Andrew F. Davis" , Dan Murphy , CC: , , , , References: <20200519141916.28282-1-dmurphy@ti.com> <20200519141916.28282-4-dmurphy@ti.com> <50b9ca3f-36e8-d13b-672c-5e72b6158869@ti.com> From: Ricardo Rivera-Matos Message-ID: <1eaa381f-0c05-8bcf-ce30-96104ddd9080@ti.com> Date: Tue, 19 May 2020 12:15:51 -0500 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 MIME-Version: 1.0 In-Reply-To: <50b9ca3f-36e8-d13b-672c-5e72b6158869@ti.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 5/19/20 9:46 AM, Andrew F. Davis wrote: > On 5/19/20 10:19 AM, Dan Murphy wrote: >> +static int bq2515x_set_ilim_lvl(struct bq2515x_device *bq2515x, int val) >> +{ >> + int i; >> + >> + if (val > BQ2515X_ILIM_MAX || val < BQ2515X_ILIM_MIN) >> + return -EINVAL; > Clamp to these limits, not reject. Or better, modify the below loop so > it clamps to the highest or lowest value in bq2515x_ilim_lvl_values[], > then drop these #defines. > >> + >> + for (i = 0; i < ARRAY_SIZE(bq2515x_ilim_lvl_values); i++) { >> + if (val == bq2515x_ilim_lvl_values[i]) >> + break; >> + >> + if (val > bq2515x_ilim_lvl_values[i - 1] && > Index out of bounds for the i = 0 case. > >> + val < bq2515x_ilim_lvl_values[i]) { >> + if (val - bq2515x_ilim_lvl_values[i - 1] < >> + bq2515x_ilim_lvl_values[i] - val) { > You are still missing the case where the value is closer to the [i] > element, you check that it is between [i-1] and [i], but only chose > [i-1] when it is closer to that than [i] but equal and greater case is > missing. > > Given this sets input current limits, would instead always rounding down > be the safer option? > > Andrew ACK. I am going to rewrite that altogether. > >> + i = i - 1; >> + break; >> + } >> + } >> + } >> + >> + return regmap_write(bq2515x->regmap, BQ2515X_ILIMCTRL, i); >> +}