Staging driver bugfixes for 3.16-rc4
Nothing major here, just 4 small bugfixes that resolve some issues reported for the IIO (staging and non-staging) and the tidspbridge driver. Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iEYEABECAAYFAlO1+gYACgkQMUfUDdst+ylqPgCdGlfPLOaFYI/IlOUDbdAG7YRP QCIAn0U3wnG4QjVAwmzCHlcPAtFt4un9 =kDww -----END PGP SIGNATURE----- Merge tag 'staging-3.16-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging Pull staging driver bugfixes from Greg KH: "Nothing major here, just 4 small bugfixes that resolve some issues reported for the IIO (staging and non-staging) and the tidspbridge driver" * tag 'staging-3.16-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging: staging: tidspbridge: fix an erroneous removal of parentheses iio: of_iio_channel_get_by_name() returns non-null pointers for error legs staging: iio/ad7291: fix error code in ad7291_probe() iio:adc:ad799x: Fix reading and writing of event values, apply shift
This commit is contained in:
commit
9911f2e154
@ -427,9 +427,12 @@ static int ad799x_write_event_value(struct iio_dev *indio_dev,
|
|||||||
int ret;
|
int ret;
|
||||||
struct ad799x_state *st = iio_priv(indio_dev);
|
struct ad799x_state *st = iio_priv(indio_dev);
|
||||||
|
|
||||||
|
if (val < 0 || val > RES_MASK(chan->scan_type.realbits))
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
mutex_lock(&indio_dev->mlock);
|
mutex_lock(&indio_dev->mlock);
|
||||||
ret = ad799x_i2c_write16(st, ad799x_threshold_reg(chan, dir, info),
|
ret = ad799x_i2c_write16(st, ad799x_threshold_reg(chan, dir, info),
|
||||||
val);
|
val << chan->scan_type.shift);
|
||||||
mutex_unlock(&indio_dev->mlock);
|
mutex_unlock(&indio_dev->mlock);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
@ -452,7 +455,8 @@ static int ad799x_read_event_value(struct iio_dev *indio_dev,
|
|||||||
mutex_unlock(&indio_dev->mlock);
|
mutex_unlock(&indio_dev->mlock);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
*val = valin;
|
*val = (valin >> chan->scan_type.shift) &
|
||||||
|
RES_MASK(chan->scan_type.realbits);
|
||||||
|
|
||||||
return IIO_VAL_INT;
|
return IIO_VAL_INT;
|
||||||
}
|
}
|
||||||
|
@ -183,7 +183,7 @@ static struct iio_channel *of_iio_channel_get_by_name(struct device_node *np,
|
|||||||
else if (name && index >= 0) {
|
else if (name && index >= 0) {
|
||||||
pr_err("ERROR: could not get IIO channel %s:%s(%i)\n",
|
pr_err("ERROR: could not get IIO channel %s:%s(%i)\n",
|
||||||
np->full_name, name ? name : "", index);
|
np->full_name, name ? name : "", index);
|
||||||
return chan;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -193,8 +193,9 @@ static struct iio_channel *of_iio_channel_get_by_name(struct device_node *np,
|
|||||||
*/
|
*/
|
||||||
np = np->parent;
|
np = np->parent;
|
||||||
if (np && !of_get_property(np, "io-channel-ranges", NULL))
|
if (np && !of_get_property(np, "io-channel-ranges", NULL))
|
||||||
break;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return chan;
|
return chan;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -317,6 +318,7 @@ struct iio_channel *iio_channel_get(struct device *dev,
|
|||||||
if (channel != NULL)
|
if (channel != NULL)
|
||||||
return channel;
|
return channel;
|
||||||
}
|
}
|
||||||
|
|
||||||
return iio_channel_get_sys(name, channel_name);
|
return iio_channel_get_sys(name, channel_name);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(iio_channel_get);
|
EXPORT_SYMBOL_GPL(iio_channel_get);
|
||||||
|
@ -465,7 +465,7 @@ static int ad7291_probe(struct i2c_client *client,
|
|||||||
struct ad7291_platform_data *pdata = client->dev.platform_data;
|
struct ad7291_platform_data *pdata = client->dev.platform_data;
|
||||||
struct ad7291_chip_info *chip;
|
struct ad7291_chip_info *chip;
|
||||||
struct iio_dev *indio_dev;
|
struct iio_dev *indio_dev;
|
||||||
int ret = 0;
|
int ret;
|
||||||
|
|
||||||
indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*chip));
|
indio_dev = devm_iio_device_alloc(&client->dev, sizeof(*chip));
|
||||||
if (!indio_dev)
|
if (!indio_dev)
|
||||||
@ -475,7 +475,7 @@ static int ad7291_probe(struct i2c_client *client,
|
|||||||
if (pdata && pdata->use_external_ref) {
|
if (pdata && pdata->use_external_ref) {
|
||||||
chip->reg = devm_regulator_get(&client->dev, "vref");
|
chip->reg = devm_regulator_get(&client->dev, "vref");
|
||||||
if (IS_ERR(chip->reg))
|
if (IS_ERR(chip->reg))
|
||||||
return ret;
|
return PTR_ERR(chip->reg);
|
||||||
|
|
||||||
ret = regulator_enable(chip->reg);
|
ret = regulator_enable(chip->reg);
|
||||||
if (ret)
|
if (ret)
|
||||||
|
@ -280,8 +280,10 @@ static int bridge_brd_monitor(struct bridge_dev_context *dev_ctxt)
|
|||||||
OMAP3430_IVA2_MOD, OMAP2_CM_CLKSTCTRL);
|
OMAP3430_IVA2_MOD, OMAP2_CM_CLKSTCTRL);
|
||||||
|
|
||||||
/* Wait until the state has moved to ON */
|
/* Wait until the state has moved to ON */
|
||||||
while (*pdata->dsp_prm_read(OMAP3430_IVA2_MOD, OMAP2_PM_PWSTST)&
|
while ((*pdata->dsp_prm_read)(OMAP3430_IVA2_MOD,
|
||||||
OMAP_INTRANSITION_MASK);
|
OMAP2_PM_PWSTST) &
|
||||||
|
OMAP_INTRANSITION_MASK)
|
||||||
|
;
|
||||||
/* Disable Automatic transition */
|
/* Disable Automatic transition */
|
||||||
(*pdata->dsp_cm_write)(OMAP34XX_CLKSTCTRL_DISABLE_AUTO,
|
(*pdata->dsp_cm_write)(OMAP34XX_CLKSTCTRL_DISABLE_AUTO,
|
||||||
OMAP3430_IVA2_MOD, OMAP2_CM_CLKSTCTRL);
|
OMAP3430_IVA2_MOD, OMAP2_CM_CLKSTCTRL);
|
||||||
|
Loading…
Reference in New Issue
Block a user