diff options
Diffstat (limited to 'drivers/hwmon')
| -rw-r--r-- | drivers/hwmon/da9055-hwmon.c | 4 | ||||
| -rw-r--r-- | drivers/hwmon/max1668.c | 2 | ||||
| -rw-r--r-- | drivers/hwmon/ntc_thermistor.c | 6 | ||||
| -rw-r--r-- | drivers/hwmon/pmbus/pmbus_core.c | 68 | 
4 files changed, 40 insertions, 40 deletions
| diff --git a/drivers/hwmon/da9055-hwmon.c b/drivers/hwmon/da9055-hwmon.c index 029ecabc4380..73b3865f1207 100644 --- a/drivers/hwmon/da9055-hwmon.c +++ b/drivers/hwmon/da9055-hwmon.c @@ -278,10 +278,6 @@ static int da9055_hwmon_probe(struct platform_device *pdev)  	if (hwmon_irq < 0)  		return hwmon_irq; -	hwmon_irq = regmap_irq_get_virq(hwmon->da9055->irq_data, hwmon_irq); -	if (hwmon_irq < 0) -		return hwmon_irq; -  	ret = devm_request_threaded_irq(&pdev->dev, hwmon_irq,  					NULL, da9055_auxadc_irq,  					IRQF_TRIGGER_HIGH | IRQF_ONESHOT, diff --git a/drivers/hwmon/max1668.c b/drivers/hwmon/max1668.c index a7626358c95d..029b65e6c589 100644 --- a/drivers/hwmon/max1668.c +++ b/drivers/hwmon/max1668.c @@ -243,7 +243,7 @@ static ssize_t set_temp_min(struct device *dev,  	data->temp_min[index] = clamp_val(temp/1000, -128, 127);  	if (i2c_smbus_write_byte_data(client,  					MAX1668_REG_LIML_WR(index), -					data->temp_max[index])) +					data->temp_min[index]))  		count = -EIO;  	mutex_unlock(&data->update_lock); diff --git a/drivers/hwmon/ntc_thermistor.c b/drivers/hwmon/ntc_thermistor.c index 8c23203915af..8a17f01e8672 100644 --- a/drivers/hwmon/ntc_thermistor.c +++ b/drivers/hwmon/ntc_thermistor.c @@ -145,7 +145,7 @@ struct ntc_data {  static int ntc_adc_iio_read(struct ntc_thermistor_platform_data *pdata)  {  	struct iio_channel *channel = pdata->chan; -	unsigned int result; +	s64 result;  	int val, ret;  	ret = iio_read_channel_raw(channel, &val); @@ -155,10 +155,10 @@ static int ntc_adc_iio_read(struct ntc_thermistor_platform_data *pdata)  	}  	/* unit: mV */ -	result = pdata->pullup_uv * val; +	result = pdata->pullup_uv * (s64) val;  	result >>= 12; -	return result; +	return (int)result;  }  static const struct of_device_id ntc_match[] = { diff --git a/drivers/hwmon/pmbus/pmbus_core.c b/drivers/hwmon/pmbus/pmbus_core.c index 3cbf66e9d861..291d11fe93e7 100644 --- a/drivers/hwmon/pmbus/pmbus_core.c +++ b/drivers/hwmon/pmbus/pmbus_core.c @@ -90,7 +90,8 @@ struct pmbus_data {  	u32 flags;		/* from platform data */ -	int exponent;		/* linear mode: exponent for output voltages */ +	int exponent[PMBUS_PAGES]; +				/* linear mode: exponent for output voltages */  	const struct pmbus_driver_info *info; @@ -410,7 +411,7 @@ static long pmbus_reg2data_linear(struct pmbus_data *data,  	long val;  	if (sensor->class == PSC_VOLTAGE_OUT) {	/* LINEAR16 */ -		exponent = data->exponent; +		exponent = data->exponent[sensor->page];  		mantissa = (u16) sensor->data;  	} else {				/* LINEAR11 */  		exponent = ((s16)sensor->data) >> 11; @@ -516,7 +517,7 @@ static long pmbus_reg2data(struct pmbus_data *data, struct pmbus_sensor *sensor)  #define MIN_MANTISSA	(511 * 1000)  static u16 pmbus_data2reg_linear(struct pmbus_data *data, -				 enum pmbus_sensor_classes class, long val) +				 struct pmbus_sensor *sensor, long val)  {  	s16 exponent = 0, mantissa;  	bool negative = false; @@ -525,7 +526,7 @@ static u16 pmbus_data2reg_linear(struct pmbus_data *data,  	if (val == 0)  		return 0; -	if (class == PSC_VOLTAGE_OUT) { +	if (sensor->class == PSC_VOLTAGE_OUT) {  		/* LINEAR16 does not support negative voltages */  		if (val < 0)  			return 0; @@ -534,10 +535,10 @@ static u16 pmbus_data2reg_linear(struct pmbus_data *data,  		 * For a static exponents, we don't have a choice  		 * but to adjust the value to it.  		 */ -		if (data->exponent < 0) -			val <<= -data->exponent; +		if (data->exponent[sensor->page] < 0) +			val <<= -data->exponent[sensor->page];  		else -			val >>= data->exponent; +			val >>= data->exponent[sensor->page];  		val = DIV_ROUND_CLOSEST(val, 1000);  		return val & 0xffff;  	} @@ -548,14 +549,14 @@ static u16 pmbus_data2reg_linear(struct pmbus_data *data,  	}  	/* Power is in uW. Convert to mW before converting. */ -	if (class == PSC_POWER) +	if (sensor->class == PSC_POWER)  		val = DIV_ROUND_CLOSEST(val, 1000L);  	/*  	 * For simplicity, convert fan data to milli-units  	 * before calculating the exponent.  	 */ -	if (class == PSC_FAN) +	if (sensor->class == PSC_FAN)  		val = val * 1000;  	/* Reduce large mantissa until it fits into 10 bit */ @@ -585,22 +586,22 @@ static u16 pmbus_data2reg_linear(struct pmbus_data *data,  }  static u16 pmbus_data2reg_direct(struct pmbus_data *data, -				 enum pmbus_sensor_classes class, long val) +				 struct pmbus_sensor *sensor, long val)  {  	long m, b, R; -	m = data->info->m[class]; -	b = data->info->b[class]; -	R = data->info->R[class]; +	m = data->info->m[sensor->class]; +	b = data->info->b[sensor->class]; +	R = data->info->R[sensor->class];  	/* Power is in uW. Adjust R and b. */ -	if (class == PSC_POWER) { +	if (sensor->class == PSC_POWER) {  		R -= 3;  		b *= 1000;  	}  	/* Calculate Y = (m * X + b) * 10^R */ -	if (class != PSC_FAN) { +	if (sensor->class != PSC_FAN) {  		R -= 3;		/* Adjust R and b for data in milli-units */  		b *= 1000;  	} @@ -619,7 +620,7 @@ static u16 pmbus_data2reg_direct(struct pmbus_data *data,  }  static u16 pmbus_data2reg_vid(struct pmbus_data *data, -			      enum pmbus_sensor_classes class, long val) +			      struct pmbus_sensor *sensor, long val)  {  	val = clamp_val(val, 500, 1600); @@ -627,20 +628,20 @@ static u16 pmbus_data2reg_vid(struct pmbus_data *data,  }  static u16 pmbus_data2reg(struct pmbus_data *data, -			  enum pmbus_sensor_classes class, long val) +			  struct pmbus_sensor *sensor, long val)  {  	u16 regval; -	switch (data->info->format[class]) { +	switch (data->info->format[sensor->class]) {  	case direct: -		regval = pmbus_data2reg_direct(data, class, val); +		regval = pmbus_data2reg_direct(data, sensor, val);  		break;  	case vid: -		regval = pmbus_data2reg_vid(data, class, val); +		regval = pmbus_data2reg_vid(data, sensor, val);  		break;  	case linear:  	default: -		regval = pmbus_data2reg_linear(data, class, val); +		regval = pmbus_data2reg_linear(data, sensor, val);  		break;  	}  	return regval; @@ -746,7 +747,7 @@ static ssize_t pmbus_set_sensor(struct device *dev,  		return -EINVAL;  	mutex_lock(&data->update_lock); -	regval = pmbus_data2reg(data, sensor->class, val); +	regval = pmbus_data2reg(data, sensor, val);  	ret = _pmbus_write_word_data(client, sensor->page, sensor->reg, regval);  	if (ret < 0)  		rv = ret; @@ -1643,12 +1644,13 @@ static int pmbus_find_attributes(struct i2c_client *client,   * This function is called for all chips.   */  static int pmbus_identify_common(struct i2c_client *client, -				 struct pmbus_data *data) +				 struct pmbus_data *data, int page)  {  	int vout_mode = -1; -	if (pmbus_check_byte_register(client, 0, PMBUS_VOUT_MODE)) -		vout_mode = _pmbus_read_byte_data(client, 0, PMBUS_VOUT_MODE); +	if (pmbus_check_byte_register(client, page, PMBUS_VOUT_MODE)) +		vout_mode = _pmbus_read_byte_data(client, page, +						  PMBUS_VOUT_MODE);  	if (vout_mode >= 0 && vout_mode != 0xff) {  		/*  		 * Not all chips support the VOUT_MODE command, @@ -1659,7 +1661,7 @@ static int pmbus_identify_common(struct i2c_client *client,  			if (data->info->format[PSC_VOLTAGE_OUT] != linear)  				return -ENODEV; -			data->exponent = ((s8)(vout_mode << 3)) >> 3; +			data->exponent[page] = ((s8)(vout_mode << 3)) >> 3;  			break;  		case 1: /* VID mode         */  			if (data->info->format[PSC_VOLTAGE_OUT] != vid) @@ -1674,7 +1676,7 @@ static int pmbus_identify_common(struct i2c_client *client,  		}  	} -	pmbus_clear_fault_page(client, 0); +	pmbus_clear_fault_page(client, page);  	return 0;  } @@ -1682,7 +1684,7 @@ static int pmbus_init_common(struct i2c_client *client, struct pmbus_data *data,  			     struct pmbus_driver_info *info)  {  	struct device *dev = &client->dev; -	int ret; +	int page, ret;  	/*  	 * Some PMBus chips don't support PMBUS_STATUS_BYTE, so try @@ -1715,10 +1717,12 @@ static int pmbus_init_common(struct i2c_client *client, struct pmbus_data *data,  		return -ENODEV;  	} -	ret = pmbus_identify_common(client, data); -	if (ret < 0) { -		dev_err(dev, "Failed to identify chip capabilities\n"); -		return ret; +	for (page = 0; page < info->pages; page++) { +		ret = pmbus_identify_common(client, data, page); +		if (ret < 0) { +			dev_err(dev, "Failed to identify chip capabilities\n"); +			return ret; +		}  	}  	return 0;  } | 
