From: Vladimir Barinov <vladimir.barinov@cogentembedded.com>
To: Krzysztof Kozlowski <k.kozlowski@samsung.com>
Cc: dwmw2@infradead.org, linux-kernel@vger.kernel.org,
devicetree@vger.kernel.org, anton@enomsg.org,
mk7.kang@samsung.com, kmpark@infradead.org
Subject: Re: [PATCH 1/3] power_supply: modelgauge_battery: Maxim ModelGauge ICs gauge
Date: Wed, 15 Jan 2014 14:20:57 +0400 [thread overview]
Message-ID: <52D66109.5080809@cogentembedded.com> (raw)
In-Reply-To: <52D56650.9070607@samsung.com>
Hello, Krzysztof,
Thank you for the review.
On 01/14/2014 08:31 PM, Krzysztof Kozlowski wrote:
> On 01/09/2014 05:49 PM, Vladimir Barinov wrote:
>> Add Maxim ModelGauge ICs gauge driver for
>> MAX17040/41/43/44/48/49/58/59 chips
>>
>> Signed-off-by: Vladimir Barinov
>> <vladimir.barinov-M4DtvfQ/ZS1MRgGoP+s0PdBPR1lH4CV8@public.gmane.org>
>>
>> ---
>> drivers/power/Kconfig | 8
>> drivers/power/Makefile | 1
>> drivers/power/modelgauge_battery.c | 875
>> +++++++++++++++++++++++
>> include/linux/platform_data/battery-modelgauge.h | 44 +
>> 4 files changed, 928 insertions(+)
>>
>
> [...]
>
>> +static int modelgauge_read_reg(struct i2c_client *client, u8 reg,
>> u16 *value)
>> +{
>> + int ret = i2c_smbus_read_word_data(client, reg);
>> +
>> + if (ret < 0) {
>> + dev_err(&client->dev, "%s: err %d\n", __func__, ret);
>> + return ret;
>> + }
>> +
>> + *value = be16_to_cpu(ret);
>> + return 0;
>> +}
>
> Have you considered using regmap for accessing registers? I know that
> other max17* drivers don't use it but it may be this could be the time
> to switch to regmap API?
>
> [...]
Sure, I will rework for the next try. Thx for pointing to this.
>
>> +static int modelgauge_probe(struct i2c_client *client,
>> + const struct i2c_device_id *id)
>> +{
>> + struct i2c_adapter *adapter = to_i2c_adapter(client->dev.parent);
>> + struct modelgauge_priv *priv;
>> + int ret;
>> +
>> + if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_WORD_DATA))
>> + return -EIO;
>> +
>> + priv = devm_kzalloc(&client->dev, sizeof(*priv), GFP_KERNEL);
>> + if (!priv)
>> + return -ENOMEM;
>> +
>> + if (client->dev.of_node)
>> + priv->pdata = modelgauge_parse_dt(&client->dev);
>> + else
>> + priv->pdata = client->dev.platform_data;
>> +
>> + priv->client = client;
>> + priv->chip = id->driver_data;
>> +
>> + i2c_set_clientdata(client, priv);
>> +
>> + priv->battery.name = "modelgauge_battery";
>> + priv->battery.type = POWER_SUPPLY_TYPE_BATTERY;
>> + priv->battery.get_property = modelgauge_get_property;
>> + priv->battery.properties = modelgauge_battery_props;
>> + priv->battery.num_properties =
>> ARRAY_SIZE(modelgauge_battery_props);
>> +
>> + INIT_WORK(&priv->load_work, modelgauge_load_model_work);
>> + INIT_DELAYED_WORK(&priv->rcomp_work, modelgauge_update_rcomp_work);
>> +
>> + ret = modelgauge_init(priv);
>> + if (ret)
>> + return ret;
>> +
>> + ret = power_supply_register(&client->dev, &priv->battery);
>> + if (ret) {
>> + dev_err(&client->dev, "failed: power supply register\n");
>> + goto err_supply;
>> + }
>> +
>> + if (client->irq) {
>> + switch (priv->chip) {
>> + case ID_MAX17040:
>> + case ID_MAX17041:
>> + dev_err(&client->dev, "alert line is not supported\n");
>> + ret = -EINVAL;
>> + goto err_irq;
>> + default:
>> + ret = request_threaded_irq(client->irq, NULL,
>> + modelgauge_irq_handler,
>> + IRQF_TRIGGER_FALLING,
>> + priv->battery.name, priv);
>
> I think you may use devm_request_threaded_irq() here.
Ok, thx,
>
> Best regards,
> Krzysztof
Regards,
Vladimir
next prev parent reply other threads:[~2014-01-15 10:20 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-01-09 16:49 [PATCH 0/3] power_supply: modelgauge_battery: Add Maxim ModelGauge ICs gauge Vladimir Barinov
2014-01-09 16:49 ` [PATCH 2/3] dt: Document ModelGauge gauge bindings Vladimir Barinov
[not found] ` <1389286145-15375-3-git-send-email-vladimir.barinov-M4DtvfQ/ZS1MRgGoP+s0PdBPR1lH4CV8@public.gmane.org>
2014-01-10 1:00 ` Kyungmin Park
2014-01-10 12:59 ` Vladimir Barinov
2014-01-10 10:56 ` Mark Rutland
2014-01-10 14:08 ` Vladimir Barinov
[not found] ` <1389286145-15375-1-git-send-email-vladimir.barinov-M4DtvfQ/ZS1MRgGoP+s0PdBPR1lH4CV8@public.gmane.org>
2014-01-09 16:49 ` [PATCH 1/3] power_supply: modelgauge_battery: Maxim ModelGauge ICs gauge Vladimir Barinov
2014-01-10 11:11 ` Mark Rutland
[not found] ` <20140110111130.GD6798-NuALmloUBlrZROr8t4l/smS4ubULX0JqMm0uRHvK7Nw@public.gmane.org>
2014-01-10 14:29 ` Vladimir Barinov
2014-01-14 16:31 ` Krzysztof Kozlowski
2014-01-15 10:20 ` Vladimir Barinov [this message]
2014-01-09 16:49 ` [PATCH 3/3] power_supply: modelgauge_battery: Remove Maxim MAX17040 gauge Vladimir Barinov
2014-01-14 15:59 ` [PATCH 0/3] power_supply: modelgauge_battery: Add Maxim ModelGauge ICs gauge Krzysztof Kozlowski
2014-01-14 16:29 ` Krzysztof Kozlowski
[not found] ` <52D565D5.4050704-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
2014-01-15 10:16 ` Vladimir Barinov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=52D66109.5080809@cogentembedded.com \
--to=vladimir.barinov@cogentembedded.com \
--cc=anton@enomsg.org \
--cc=devicetree@vger.kernel.org \
--cc=dwmw2@infradead.org \
--cc=k.kozlowski@samsung.com \
--cc=kmpark@infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mk7.kang@samsung.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).