Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp2577814pxy; Mon, 3 May 2021 03:26:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyKrOQOk3LUctchX3K36ACFvCqsmdi3/v+tTCQSbDZAA9F9v5bNOPr9HBJ6LVaUCvgAY6ju X-Received: by 2002:aa7:c3c2:: with SMTP id l2mr19635967edr.41.1620037613719; Mon, 03 May 2021 03:26:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620037613; cv=none; d=google.com; s=arc-20160816; b=cmjA6hPrDHaiPRuH6Yvop9bt2Ty4d759WP5vm93aM3h2aiS3Egoi/p/OfEUSANk3YE 6C17rcZWdNrlkJy9ZMQp02wBHsSqkYxgq4VbdeYtTaD1Or19P3nlCTu4/5uxF3NKdW2u gKL+0Depm7sJxMEOFmNgxbgz3VlNkQpCxC/Sw+o+Wqr2xD7Bt9SO9xcWM8I5koguSIWx sM6Sn6z0cyGCtCoZyRN5k5mwsLDd3xYumSkSxFerfARQZ7cBEriuAxuGgWCrNyPBz/jF FBX9CJI0JjNovJELZmsEVA8GCqnjlMrlYJOn0PorDc2WwSbpbP1dVBhf8cknGdF5O/uJ rPvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=LQ6NNzHj7Vc4za1WZ78i9zJ6ObWAdGDaPeb41LFoT6U=; b=asmA1hyHf6zdzblmsT82IVrLW3M+S0UWKqS4yDtKf0SDDkOgDNZw8f31tJu5HGWzn2 nrfYzGZgPGY5vi1nM5jlM7cUIW4sntZNGAEowsLxcbamwH9vSxb8Oxi79GR1uZB4/B9U m3BWG3W3lcxCjhYAnNPddPXiNPl0j98YDGVU3uUTdG4SUro8ORsWnIZx4RtEmG4CLgvI IiK+o8QWRpdRjNUDtoWu1wnaH6YflAb3k0fGcyZt06/poPb1RjoCKGgKAJ0fg0w5YJ/V DzSuNz6LuxKrNw4KU6KERQ5M8GSEyS1VAVj47wLl/FuZVOe8c7Bn6CSgZzRan20SxpaA ax2A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=RAnFiTa7; 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=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p2si7653590edy.345.2021.05.03.03.26.29; Mon, 03 May 2021 03:26:53 -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=@chromium.org header.s=google header.b=RAnFiTa7; 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=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233227AbhECKGK (ORCPT + 99 others); Mon, 3 May 2021 06:06:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47310 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233220AbhECKGJ (ORCPT ); Mon, 3 May 2021 06:06:09 -0400 Received: from mail-il1-x129.google.com (mail-il1-x129.google.com [IPv6:2607:f8b0:4864:20::129]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8562AC06174A for ; Mon, 3 May 2021 03:05:15 -0700 (PDT) Received: by mail-il1-x129.google.com with SMTP id e2so3326091ilr.1 for ; Mon, 03 May 2021 03:05:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=LQ6NNzHj7Vc4za1WZ78i9zJ6ObWAdGDaPeb41LFoT6U=; b=RAnFiTa7ozjql3NUcwO4cwTMp+yfw3qYe2+1pz5mfR482zkr//ZRSGg2NXRSEesQ6R 1z1hA314Ct5JDoyEoTZ6uFr65UQfpdkSuGHti40SdMCJt1lFYlivCL88kYLqPBRvYsK3 uXjETB3K1wtgrzziydGXbnN8nQBMCKQbwhOAg= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=LQ6NNzHj7Vc4za1WZ78i9zJ6ObWAdGDaPeb41LFoT6U=; b=iA14cQ2wvHa6cFgM4Wu4Ici//g3icMx1UvKcw4KIQlhSDAgRaeYtlKgkFqI/bXkPtu GYjTFv5SSzbHmvYVMrUyoR+yrTESmcgM7XT6ynpiL5Cqhs/zF0MFp3g0arCehzm9JRyX 5yp0FjTKQCJYq5pVzqmsHHPHcS9+snLP2S+gTOGE5WcgfOrjeuVMElZBC5lM7sW6FsJ1 z5hMpg5i0t2sZAkjGbXo4kCO2soFhGuR324KEl+3TjShnT9ptvUAzR29wKf5RpUxYarJ 5fe6AIf3P6PEyP1F/DpNiBBDlU988/H2s1uig1LKGEEbulB/ULEJSIe1NCu+FBp7odG8 fc5g== X-Gm-Message-State: AOAM533Pg0AjbIVmNudj+ermgxlCtHOfF5LH4Ya/AEPZsqcB0oiDNi7k rW4bCieT6xjWDzl47WWMUl4YJXN0ln3PzsMWbsaKnBKZX5Q= X-Received: by 2002:a92:d684:: with SMTP id p4mr16000363iln.150.1620036314805; Mon, 03 May 2021 03:05:14 -0700 (PDT) MIME-Version: 1.0 References: <20210427093754.3000087-1-ikjn@chromium.org> <20210428040802.3266187-1-ikjn@chromium.org> In-Reply-To: <20210428040802.3266187-1-ikjn@chromium.org> From: Hsin-Yi Wang Date: Mon, 3 May 2021 18:04:48 +0800 Message-ID: Subject: Re: [PATCH v2] power: supply: sbs-battery: cache constant string properties To: Ikjoon Jang Cc: Linux PM , Sebastian Reichel , lkml Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Apr 28, 2021 at 12:08 PM Ikjoon Jang wrote: > > Currently sbs-battery supports three string properties - > manufacturer, model_name, and chemistry. Buffers for those > properties are currently defined as global variables. > > This patch moves those global variables into struct sbs_info > and cache/reuse them as they are all constant values. > > Signed-off-by: Ikjoon Jang > Tested-by: Hsin-Yi Wang Test on a mt8183 krane device which uses sbs battery. > --- > > Changes in v2: > - change function name of sbs_get_battery_string_property() > to sbs_get_constant_string() > - use cached string properties > - use cached technology integer value in sbs_get_chemistry() > > drivers/power/supply/sbs-battery.c | 140 +++++++++++++++++------------ > 1 file changed, 82 insertions(+), 58 deletions(-) > > diff --git a/drivers/power/supply/sbs-battery.c b/drivers/power/supply/sbs-battery.c > index 4bf92831cb06..414de9bc47bf 100644 > --- a/drivers/power/supply/sbs-battery.c > +++ b/drivers/power/supply/sbs-battery.c > @@ -188,6 +188,14 @@ static const enum power_supply_property sbs_properties[] = { > /* Supports special manufacturer commands from TI BQ20Z65 and BQ20Z75 IC. */ > #define SBS_FLAGS_TI_BQ20ZX5 BIT(0) > > +static const enum power_supply_property string_properties[] = { > + POWER_SUPPLY_PROP_TECHNOLOGY, > + POWER_SUPPLY_PROP_MANUFACTURER, > + POWER_SUPPLY_PROP_MODEL_NAME, > +}; > + > +#define NR_STRING_BUFFERS ARRAY_SIZE(string_properties) > + > struct sbs_info { > struct i2c_client *client; > struct power_supply *power_supply; > @@ -201,11 +209,22 @@ struct sbs_info { > struct delayed_work work; > struct mutex mode_lock; > u32 flags; > + int technology; > + char strings[NR_STRING_BUFFERS][I2C_SMBUS_BLOCK_MAX + 1]; > }; > > -static char model_name[I2C_SMBUS_BLOCK_MAX + 1]; > -static char manufacturer[I2C_SMBUS_BLOCK_MAX + 1]; > -static char chemistry[I2C_SMBUS_BLOCK_MAX + 1]; > +static char *sbs_get_string_buf(struct sbs_info *chip, > + enum power_supply_property psp) > +{ > + int i = 0; > + > + for (i = 0; i < NR_STRING_BUFFERS; i++) > + if (string_properties[i] == psp) > + return chip->strings[i]; > + > + return ERR_PTR(-EINVAL); > +} > + > static bool force_load; > > static int sbs_read_word_data(struct i2c_client *client, u8 address); > @@ -639,17 +658,45 @@ static int sbs_get_battery_property(struct i2c_client *client, > return 0; > } > > -static int sbs_get_battery_string_property(struct i2c_client *client, > - int reg_offset, enum power_supply_property psp, char *val) > +static int sbs_get_property_index(struct i2c_client *client, > + enum power_supply_property psp) > { > - s32 ret; > + int count; > + > + for (count = 0; count < ARRAY_SIZE(sbs_data); count++) > + if (psp == sbs_data[count].psp) > + return count; > > - ret = sbs_read_string_data(client, sbs_data[reg_offset].addr, val); > + dev_warn(&client->dev, > + "%s: Invalid Property - %d\n", __func__, psp); > > - if (ret < 0) > - return ret; > + return -EINVAL; > +} > > - return 0; > +static const char *sbs_get_constant_string(struct sbs_info *chip, > + enum power_supply_property psp) > +{ > + int ret; > + char *buf; > + u8 addr; > + > + buf = sbs_get_string_buf(chip, psp); > + if (IS_ERR(buf)) > + return buf; > + > + if (!buf[0]) { > + ret = sbs_get_property_index(chip->client, psp); > + if (ret < 0) > + return ERR_PTR(ret); > + > + addr = sbs_data[ret].addr; > + > + ret = sbs_read_string_data(chip->client, addr, buf); > + if (ret < 0) > + return ERR_PTR(ret); > + } > + > + return buf; > } > > static void sbs_unit_adjustment(struct i2c_client *client, > @@ -772,48 +819,34 @@ static int sbs_get_battery_serial_number(struct i2c_client *client, > return 0; > } > > -static int sbs_get_property_index(struct i2c_client *client, > - enum power_supply_property psp) > -{ > - int count; > - for (count = 0; count < ARRAY_SIZE(sbs_data); count++) > - if (psp == sbs_data[count].psp) > - return count; > - > - dev_warn(&client->dev, > - "%s: Invalid Property - %d\n", __func__, psp); > - > - return -EINVAL; > -} > - > -static int sbs_get_chemistry(struct i2c_client *client, > +static int sbs_get_chemistry(struct sbs_info *chip, > union power_supply_propval *val) > { > - enum power_supply_property psp = POWER_SUPPLY_PROP_TECHNOLOGY; > - int ret; > + const char *chemistry; > > - ret = sbs_get_property_index(client, psp); > - if (ret < 0) > - return ret; > + if (chip->technology >= POWER_SUPPLY_TECHNOLOGY_UNKNOWN) > + return chip->technology; > > - ret = sbs_get_battery_string_property(client, ret, psp, > - chemistry); > - if (ret < 0) > - return ret; > + chemistry = sbs_get_constant_string(chip, POWER_SUPPLY_PROP_TECHNOLOGY); > + > + if (IS_ERR(chemistry)) > + return PTR_ERR(chemistry); > > if (!strncasecmp(chemistry, "LION", 4)) > - val->intval = POWER_SUPPLY_TECHNOLOGY_LION; > + chip->technology = POWER_SUPPLY_TECHNOLOGY_LION; > else if (!strncasecmp(chemistry, "LiP", 3)) > - val->intval = POWER_SUPPLY_TECHNOLOGY_LIPO; > + chip->technology = POWER_SUPPLY_TECHNOLOGY_LIPO; > else if (!strncasecmp(chemistry, "NiCd", 4)) > - val->intval = POWER_SUPPLY_TECHNOLOGY_NiCd; > + chip->technology = POWER_SUPPLY_TECHNOLOGY_NiCd; > else if (!strncasecmp(chemistry, "NiMH", 4)) > - val->intval = POWER_SUPPLY_TECHNOLOGY_NiMH; > + chip->technology = POWER_SUPPLY_TECHNOLOGY_NiMH; > else > - val->intval = POWER_SUPPLY_TECHNOLOGY_UNKNOWN; > + chip->technology = POWER_SUPPLY_TECHNOLOGY_UNKNOWN; > > - if (val->intval == POWER_SUPPLY_TECHNOLOGY_UNKNOWN) > - dev_warn(&client->dev, "Unknown chemistry: %s\n", chemistry); > + if (chip->technology == POWER_SUPPLY_TECHNOLOGY_UNKNOWN) > + dev_warn(&chip->client->dev, "Unknown chemistry: %s\n", chemistry); > + > + val->intval = chip->technology; > > return 0; > } > @@ -857,6 +890,7 @@ static int sbs_get_property(struct power_supply *psy, > int ret = 0; > struct sbs_info *chip = power_supply_get_drvdata(psy); > struct i2c_client *client = chip->client; > + const char *str; > > if (chip->gpio_detect) { > ret = gpiod_get_value_cansleep(chip->gpio_detect); > @@ -882,7 +916,7 @@ static int sbs_get_property(struct power_supply *psy, > break; > > case POWER_SUPPLY_PROP_TECHNOLOGY: > - ret = sbs_get_chemistry(client, val); > + ret = sbs_get_chemistry(chip, val); > if (ret < 0) > break; > > @@ -934,23 +968,12 @@ static int sbs_get_property(struct power_supply *psy, > break; > > case POWER_SUPPLY_PROP_MODEL_NAME: > - ret = sbs_get_property_index(client, psp); > - if (ret < 0) > - break; > - > - ret = sbs_get_battery_string_property(client, ret, psp, > - model_name); > - val->strval = model_name; > - break; > - > case POWER_SUPPLY_PROP_MANUFACTURER: > - ret = sbs_get_property_index(client, psp); > - if (ret < 0) > - break; > - > - ret = sbs_get_battery_string_property(client, ret, psp, > - manufacturer); > - val->strval = manufacturer; > + str = sbs_get_constant_string(chip, psp); > + if (IS_ERR(str)) > + ret = PTR_ERR(str); > + else > + val->strval = str; > break; > > case POWER_SUPPLY_PROP_MANUFACTURE_YEAR: > @@ -1097,6 +1120,7 @@ static int sbs_probe(struct i2c_client *client) > psy_cfg.of_node = client->dev.of_node; > psy_cfg.drv_data = chip; > chip->last_state = POWER_SUPPLY_STATUS_UNKNOWN; > + chip->technology = -1; > mutex_init(&chip->mode_lock); > > /* use pdata if available, fall back to DT properties, > -- > 2.31.1.498.g6c1eba8ee3d-goog >