Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp2088903ybz; Sun, 26 Apr 2020 10:54:27 -0700 (PDT) X-Google-Smtp-Source: APiQypLNIvVswxqfoa2YT45nfO7ymubqhmv528Um14I2xOyTeDUiDXGyPL2+IMux9wSe7N6xvdY0 X-Received: by 2002:a17:906:b7da:: with SMTP id fy26mr16948782ejb.327.1587923666868; Sun, 26 Apr 2020 10:54:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587923666; cv=none; d=google.com; s=arc-20160816; b=hraqEgpmNTxYY1ppSs+n9kJL01HSe3IVDdrQPR8unUrlSTJmGnpBd2RYHU2Ch4hNWW WKOvpPGwZRPlbGbHc4HIVItO1043UtPcXjxhzi3vs5byDPZiw9fsnRNrGiJGLECGcLxz KjaHd+axKfbGN1q/7lUxwV3Q8yXveKYIcUbecfAH/pcGIc9mszlFypTF2cfrGhw6RPVk yk+dCJqhzCIl/Yq/lZxnZtAg1mtE+LPURIIxmf7BZ2OMc5ZRlT0BqqP4OuRF8ZKsMuld 8yJi1REZMQplyI1QtiWg4YJz0aAqVoqfpiIQTjkRzT+NzZzLyCOBffj2Em9CEQG/Tozj XNsg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=v9HfuWpIre+/I8Q7SK0JU4XfH0z5eJvIPqRZ0gZ0CRA=; b=v+4Y3NUbqBLnzBlknqdRtMWkoo3cuRKfo70BnI/1LWjBeyphTvCpzrEWN8DML0mKH7 AZwxbNL5m/E28noDbA8GzLBib/WxnyxXiTOAgmbOsMZ27JHn6og8cvXrf1TlAMusjcWC //SdjfuSs5cnC80oolvWHw+7LyyTshIX5gZlhdtwuAoTdNXWAm+Ivcnwlygesb+nVnxa SSxwuhAJ6mk66G2qQt4WKXjf+Es4MhQ2hc/gLefEw+RgB0x0uPEwLZmWN6ONm8LNQhdm ja+By22WpLVJw2kwd1SEd/sAqPuL6Ug2zkVtlstEk2c4T8cdWmKK1+iCFb1zSlbAxeB9 HvqA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=VrSsNAmF; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o15si6827837eje.13.2020.04.26.10.54.03; Sun, 26 Apr 2020 10:54:26 -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=@gmail.com header.s=20161025 header.b=VrSsNAmF; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726234AbgDZRuf (ORCPT + 99 others); Sun, 26 Apr 2020 13:50:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39700 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726151AbgDZRuf (ORCPT ); Sun, 26 Apr 2020 13:50:35 -0400 Received: from mail-pl1-x642.google.com (mail-pl1-x642.google.com [IPv6:2607:f8b0:4864:20::642]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B176FC061A0F; Sun, 26 Apr 2020 10:50:33 -0700 (PDT) Received: by mail-pl1-x642.google.com with SMTP id g2so5999944plo.3; Sun, 26 Apr 2020 10:50:33 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=v9HfuWpIre+/I8Q7SK0JU4XfH0z5eJvIPqRZ0gZ0CRA=; b=VrSsNAmFLy3QjESRo35sPprIrkR9ikddbsXi9/wJxoPjXs8FMmobhyHzVNZcL4TCYl zvTMrOuyClFFkSEqGb5xPbXDqWQc+TrX87oR9/FzsmJ61Y27MhOtDTFzztS3tZYJ2ODG jZAx4nawmi7SEdwbI8O6720QDtSfc8THw3//3dKarUEPNHgsOiKCRTSZHHHWVvsAgSZ5 WfQw6A+WEhlQvuZWvBMvMTHDr2Pk9ToBvBK44PnI3VU2pbNAhU40g+i3Ahc5oLbiLoMw XQXqC2Xtqb0njY8kPbF+48TNYT6Zjbmi4dav4cGpvG+GeCtNs0OIzIc/SXGnKDD/7ZDe vnTg== 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=v9HfuWpIre+/I8Q7SK0JU4XfH0z5eJvIPqRZ0gZ0CRA=; b=asKgM5/LjlC8n+9b0kcoS0e7CNP17EHABjNg5nSVLCzXmKhEGlm/lp1oXJ4Pc3uvv8 masaj/7lpS61I/6F5JKOvaLg7mMXxgPrYun/47zxkJfrSFzRVJWC/7Aiq8nJs/8m9HJH IL7SQDtA5n1y4uI7rZwFPCzLSJ6j/cD0gq3wCJXOAAoWRHqDIuqog98D+eWCIbyLyYX/ F839zzWyvIM3r82vUmo+QfaPT+8+Jcjt3Adq3moWFTNjwCeIdl+JU2A+XhCgW0KXaMzM SiTkZs+6Jtu+eSFpbNkWilaNR0ZUiHjSfJ7u1m1UiGHnudD+8qgvfLkO7DdtYbcJ5k6G DMcw== X-Gm-Message-State: AGi0PuaVwSgsAT0G16lzv28wr/e3xr1wT3NqAlDIUNrG6jZzhoYS0rIN 7QG58tVX3e9LA4qoJWUtkGAf94PqMPTznOyPwSU= X-Received: by 2002:a17:902:aa09:: with SMTP id be9mr20046274plb.18.1587923433187; Sun, 26 Apr 2020 10:50:33 -0700 (PDT) MIME-Version: 1.0 References: <20200426110256.218186-1-hdegoede@redhat.com> <20200426110256.218186-7-hdegoede@redhat.com> In-Reply-To: <20200426110256.218186-7-hdegoede@redhat.com> From: Andy Shevchenko Date: Sun, 26 Apr 2020 20:50:21 +0300 Message-ID: Subject: Re: [PATCH 7/8] iio: light: cm32181: Add support for parsing CPM0 and CPM1 ACPI tables To: Hans de Goede Cc: "Rafael J . Wysocki" , Len Brown , Darren Hart , Andy Shevchenko , Kevin Tsai , Jonathan Cameron , ACPI Devel Maling List , Platform Driver , Linux Kernel Mailing List , Hartmut Knaack , Lars-Peter Clausen , Peter Meerwald-Stadler , linux-iio Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Apr 26, 2020 at 2:03 PM Hans de Goede wrote: > > On ACPI based systems the CPLM3218 ACPI device node describing the > CM3218[1] sensor typically will have some extra tables with register > init values for initializing the sensor and calibration info. > > This is based on a newer version of cm32181.c, with a copyright of: > > * Copyright (C) 2014 Capella Microsystems Inc. > * Author: Kevin Tsai > * > * This program is free software; you can redistribute it and/or modify it > * under the terms of the GNU General Public License version 2, as published > * by the Free Software Foundation. > > Which is floating around on the net in various places, but the changes > from this newer version never made it upstream. > > This was tested on the following models: Acer Switch 10 SW5-012 (CM32181) > Asus T100TA (CM3218), Asus T100CHI (CM3218) and HP X2 10-n000nd (CM32181). > > Signed-off-by: Hans de Goede > --- > drivers/iio/light/cm32181.c | 98 +++++++++++++++++++++++++++++++++++++ > 1 file changed, 98 insertions(+) > > diff --git a/drivers/iio/light/cm32181.c b/drivers/iio/light/cm32181.c > index e5674d4a8143..878fc13632d8 100644 > --- a/drivers/iio/light/cm32181.c > +++ b/drivers/iio/light/cm32181.c > @@ -4,6 +4,7 @@ > * Author: Kevin Tsai > */ > > +#include > #include > #include > #include > @@ -53,6 +54,15 @@ > > #define SMBUS_ALERT_RESPONSE_ADDRESS 0x0c > > +/* CPM0 Index 0: device-id (3218 or 32181), 1: Unknown, 2: init_regs_bitmap */ > +#define CPM0_REGS_BITMAP 2 > +#define CPM0_HEADER_SIZE 3 > + > +/* CPM1 Index 0: lux_per_bit, 1: calibscale, 2: resolution (100000) */ > +#define CPM1_LUX_PER_BIT 0 > +#define CPM1_CALIBSCALE 1 > +#define CPM1_SIZE 3 > + > /* CM3218 Family */ > static const int cm3218_als_it_bits[] = { 0, 1, 2, 3 }; > static const int cm3218_als_it_values[] = { 100000, 200000, 400000, 800000 }; > @@ -76,6 +86,56 @@ struct cm32181_chip { > const int *als_it_values; > }; > > +static int cm32181_read_als_it(struct cm32181_chip *cm32181, int *val2); > + > +#ifdef CONFIG_ACPI > +/** > + * cm32181_acpi_get_cpm() - Get CPM object from ACPI > + * @client pointer of struct i2c_client. > + * @obj_name pointer of ACPI object name. > + * @count maximum size of return array. > + * @vals pointer of array for return elements. > + * > + * Convert ACPI CPM table to array. > + * > + * Return: -ENODEV for fail. Otherwise is number of elements. > + */ > +static int cm32181_acpi_get_cpm(struct i2c_client *client, char *obj_name, > + u64 *values, int count) > +{ > + struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL }; > + union acpi_object *cpm, *elem; > + acpi_handle handle; > + acpi_status status; > + int i; > + > + handle = ACPI_HANDLE(&client->dev); > + if (!handle) > + return -ENODEV; > + > + status = acpi_evaluate_object(handle, obj_name, NULL, &buffer); > + if (ACPI_FAILURE(status)) { > + dev_err(&client->dev, "object %s not found\n", obj_name); > + return -ENODEV; > + } > + > + cpm = buffer.pointer; > + if (cpm->package.count > count) > + dev_warn(&client->dev, "%s table contains %d values, only using first %d values\n", > + obj_name, cpm->package.count, count); > + > + count = min_t(int, cpm->package.count, count); > + for (i = 0; i < count; i++) { > + elem = &(cpm->package.elements[i]); > + values[i] = elem->integer.value; > + } > + > + kfree(buffer.pointer); > + > + return count; > +} > +#endif /* CONFIG_ACPI */ > + > /** > * cm32181_reg_init() - Initialize CM32181 registers > * @cm32181: pointer of struct cm32181. > @@ -121,6 +181,44 @@ static int cm32181_reg_init(struct cm32181_chip *cm32181) > cm32181->lux_per_bit = CM32181_LUX_PER_BIT; > cm32181->lux_per_bit_base_it = CM32181_LUX_PER_BIT_BASE_IT; > > +#ifdef CONFIG_ACPI > + if (ACPI_HANDLE(&client->dev)) { > + u64 values[CPM0_HEADER_SIZE + CM32181_CONF_REG_NUM]; > + int count; > + > + count = cm32181_acpi_get_cpm(client, "CPM0", > + values, ARRAY_SIZE(values)); > + if (count <= CPM0_HEADER_SIZE) > + goto cpm_parsing_done; > + > + count -= CPM0_HEADER_SIZE; > + > + cm32181->init_regs_bitmap = values[CPM0_REGS_BITMAP]; > + cm32181->init_regs_bitmap &= GENMASK(count - 1, 0); > + for (i = 0; i < count; i++) { > + if (cm32181->init_regs_bitmap & BIT(i)) > + cm32181->conf_regs[i] = > + values[CPM0_HEADER_SIZE + i]; > + } > + > + count = cm32181_acpi_get_cpm(client, "CPM1", > + values, ARRAY_SIZE(values)); > + if (count != CPM1_SIZE) > + goto cpm_parsing_done; > + > + cm32181->lux_per_bit = values[CPM1_LUX_PER_BIT]; > + > + /* Check for uncalibrated devices */ > + if (values[CPM1_CALIBSCALE] == CM32181_CALIBSCALE_DEFAULT) > + goto cpm_parsing_done; > + > + cm32181->calibscale = values[CPM1_CALIBSCALE]; > + /* CPM1 lux_per_bit is for the current it value */ > + cm32181_read_als_it(cm32181, &cm32181->lux_per_bit_base_it); > + } > +cpm_parsing_done: Perhaps factor out to a helper, will a) allow to get rid of a label; b) drop indentation level. > +#endif /* CONFIG_ACPI */ > + > /* Initialize registers*/ > for (i = 0; i < CM32181_CONF_REG_NUM; i++) { > if (cm32181->init_regs_bitmap & BIT(i)) { > -- > 2.26.0 > -- With Best Regards, Andy Shevchenko