From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752545Ab2GTOE1 (ORCPT ); Fri, 20 Jul 2012 10:04:27 -0400 Received: from cantor2.suse.de ([195.135.220.15]:42879 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751449Ab2GTOEZ (ORCPT ); Fri, 20 Jul 2012 10:04:25 -0400 From: Oliver Neukum To: Johannes Winkelmann Cc: linux-kernel@vger.kernel.org, lm-sensors@lm-sensors.org, Jean Delvare , Guenter Roeck , Johannes Winkelmann Subject: Re: [RFC][PATCH] hwmon: add support for Sensirion C1 sensor Date: Fri, 20 Jul 2012 16:03:38 +0200 Message-ID: <6190165.D1PKLQQHEK@linux-lqwf.site> Organization: SUSE User-Agent: KMail/4.8.4 (Linux/3.5.0-rc6-117-g918227b-1-vanilla; KDE/4.8.4; x86_64; ; ) In-Reply-To: <1342789042-13433-1-git-send-email-johannes.winkelmann@sensirion.com> References: <1342789042-13433-1-git-send-email-johannes.winkelmann@sensirion.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Friday 20 July 2012 14:57:22 Johannes Winkelmann wrote: > +/* sysfs attributes */ > +static struct shtc1_data *shtc1_update_client(struct device *dev) > +{ > + struct i2c_client *client = to_i2c_client(dev); > + struct shtc1_data *data = i2c_get_clientdata(client); > + > + char buf[SHTC1_RESPONSE_LENGTH]; Is this used for DMA? > + int val; > + int ret; > + > + mutex_lock(&data->update_lock); > + > + /* > + * initialize 'ret' in case we had a valid result before, but > + * read too quickly in which case we return the last values > + */ > + ret = !data->valid; > + > + if (time_after(jiffies, data->last_updated + HZ / 10) > + || !data->valid) { > + ret = shtc1_update_values(client, data, buf, sizeof(buf)); > + > + if (ret) > + goto out; > + > + /* > + * From datasheet: > + * T = -45 + 175 * ST / 2^16 > + * RH = -10 + 120 * SRH / 2^16 > + * > + * Adapted for integer fixed point (3 digit) arithmetic > + */ > + val = (buf[0] << 8) | buf[1]; > + data->temperature = ((21875 * val) >> 13) - 45000; > + val = (buf[3] << 8) | buf[4]; We have dedicated macros for conversion of endianness. > + data->humidity = ((15000 * val) >> 13) - 10000; > + > + data->last_updated = jiffies; > + data->valid = 1; > + } > + > +out: > + mutex_unlock(&data->update_lock); > + > + return ret == 0 ? data : NULL; > +} Regards Oliver