Skip to content

Commit e1b1fa6

Browse files
Marek Vasutjic23
authored andcommitted
iio: mxs-lradc: Fix misuse of iio->trig
The struct iio_dev .trig field is to be used only by the IIO core, the driver shall not fill this field. This fixes ugly crash when the driver is compiled as a module and the module is rmmod'd. Signed-off-by: Marek Vasut <[email protected]> Cc: Fabio Estevam <[email protected]> Cc: Jonathan Cameron <[email protected]> Cc: Shawn Guo <[email protected]> Signed-off-by: Jonathan Cameron <[email protected]>
1 parent f91d1b6 commit e1b1fa6

File tree

1 file changed

+7
-4
lines changed

1 file changed

+7
-4
lines changed

drivers/staging/iio/adc/mxs-lradc.c

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -661,12 +661,13 @@ static int mxs_lradc_trigger_init(struct iio_dev *iio)
661661
{
662662
int ret;
663663
struct iio_trigger *trig;
664+
struct mxs_lradc *lradc = iio_priv(iio);
664665

665666
trig = iio_trigger_alloc("%s-dev%i", iio->name, iio->id);
666667
if (trig == NULL)
667668
return -ENOMEM;
668669

669-
trig->dev.parent = iio->dev.parent;
670+
trig->dev.parent = lradc->dev;
670671
iio_trigger_set_drvdata(trig, iio);
671672
trig->ops = &mxs_lradc_trigger_ops;
672673

@@ -676,15 +677,17 @@ static int mxs_lradc_trigger_init(struct iio_dev *iio)
676677
return ret;
677678
}
678679

679-
iio->trig = trig;
680+
lradc->trig = trig;
680681

681682
return 0;
682683
}
683684

684685
static void mxs_lradc_trigger_remove(struct iio_dev *iio)
685686
{
686-
iio_trigger_unregister(iio->trig);
687-
iio_trigger_free(iio->trig);
687+
struct mxs_lradc *lradc = iio_priv(iio);
688+
689+
iio_trigger_unregister(lradc->trig);
690+
iio_trigger_free(lradc->trig);
688691
}
689692

690693
static int mxs_lradc_buffer_preenable(struct iio_dev *iio)

0 commit comments

Comments
 (0)