From: Stephen M. Cameron Date: Thu, 19 Jan 2012 20:00:42 +0000 (-0600) Subject: [SCSI] hpsa: fix per device memory leak on driver unload X-Git-Tag: v2.6.39-400.9.0~423^2~19^2~11^2~719 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=25b5f8c9c976e24798314c07b50d35f7a0cab73d;p=users%2Fjedix%2Flinux-maple.git [SCSI] hpsa: fix per device memory leak on driver unload Signed-off-by: Stephen M. Cameron Signed-off-by: James Bottomley (cherry picked from commit 55e14e764df5e24bedf93220f1da167af8300c2f) Signed-off-by: Joe Jin --- diff --git a/drivers/scsi/hpsa.c b/drivers/scsi/hpsa.c index 6309de72be92..7763b4473ca9 100644 --- a/drivers/scsi/hpsa.c +++ b/drivers/scsi/hpsa.c @@ -4511,6 +4511,14 @@ static void hpsa_shutdown(struct pci_dev *pdev) #endif /* CONFIG_PCI_MSI */ } +static void __devexit hpsa_free_device_info(struct ctlr_info *h) +{ + int i; + + for (i = 0; i < h->ndevices; i++) + kfree(h->dev[i]); +} + static void __devexit hpsa_remove_one(struct pci_dev *pdev) { struct ctlr_info *h; @@ -4526,6 +4534,7 @@ static void __devexit hpsa_remove_one(struct pci_dev *pdev) iounmap(h->vaddr); iounmap(h->transtable); iounmap(h->cfgtable); + hpsa_free_device_info(h); hpsa_free_sg_chain_blocks(h); pci_free_consistent(h->pdev, h->nr_cmds * sizeof(struct CommandList),