On 26/10/10 02:10, Emilio G. Cota wrote: > From: Emilio G. Cota <cota@xxxxxxxxx> > > This fixes an oops when removing the module. > > Signed-off-by: Emilio G. Cota <cota@xxxxxxxxx> Acked-by: Martyn Welch <martyn.welch@xxxxxx> > --- > drivers/staging/vme/bridges/vme_tsi148.c | 7 ++++--- > 1 files changed, 4 insertions(+), 3 deletions(-) > > diff --git a/drivers/staging/vme/bridges/vme_tsi148.c b/drivers/staging/vme/bridges/vme_tsi148.c > index e341122..660968e 100644 > --- a/drivers/staging/vme/bridges/vme_tsi148.c > +++ b/drivers/staging/vme/bridges/vme_tsi148.c > @@ -2532,6 +2532,7 @@ err_struct: > static void tsi148_remove(struct pci_dev *pdev) > { > struct list_head *pos = NULL; > + struct list_head *tmplist; > struct vme_master_resource *master_image; > struct vme_slave_resource *slave_image; > struct vme_dma_resource *dma_ctrlr; > @@ -2590,21 +2591,21 @@ static void tsi148_remove(struct pci_dev *pdev) > tsi148_crcsr_exit(tsi148_bridge, pdev); > > /* resources are stored in link list */ > - list_for_each(pos, &tsi148_bridge->dma_resources) { > + list_for_each_safe(pos, tmplist, &tsi148_bridge->dma_resources) { > dma_ctrlr = list_entry(pos, struct vme_dma_resource, list); > list_del(pos); > kfree(dma_ctrlr); > } > > /* resources are stored in link list */ > - list_for_each(pos, &tsi148_bridge->slave_resources) { > + list_for_each_safe(pos, tmplist, &tsi148_bridge->slave_resources) { > slave_image = list_entry(pos, struct vme_slave_resource, list); > list_del(pos); > kfree(slave_image); > } > > /* resources are stored in link list */ > - list_for_each(pos, &tsi148_bridge->master_resources) { > + list_for_each_safe(pos, tmplist, &tsi148_bridge->master_resources) { > master_image = list_entry(pos, struct vme_master_resource, > list); > list_del(pos); -- Martyn Welch (Principal Software Engineer) | Registered in England and GE Intelligent Platforms | Wales (3828642) at 100 T +44(0)127322748 | Barbirolli Square, Manchester, E martyn.welch@xxxxxx | M2 3AB VAT:GB 927559189 _______________________________________________ devel mailing list devel@xxxxxxxxxxxxxxxxxxxxxx http://driverdev.linuxdriverproject.org/mailman/listinfo/devel