diff options
author | Amol Lad <amol@verismonetworks.com> | 2006-12-08 05:40:03 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.osdl.org> | 2006-12-08 11:29:04 -0500 |
commit | a02f6402d5a18f5a4fd35cb82887c1097d0f7792 (patch) | |
tree | 43046222e74b789358190b9edca1990fc053a871 /drivers/video | |
parent | b88a57cc645c59a3652f391f8069b15d42ac0762 (diff) |
[PATCH] ioremap balanced with iounmap for drivers/video/tridentfb
ioremap must be balanced by an iounmap and failing to do so can result in a
memory leak.
Signed-off-by: Amol Lad <amol@verismonetworks.com>
Cc: "Antonino A. Daplas" <adaplas@pol.net>
Cc: Knut Petersen <Knut_Petersen@t-online.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/video')
-rw-r--r-- | drivers/video/tridentfb.c | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/drivers/video/tridentfb.c b/drivers/video/tridentfb.c index 14175cdb9c9c..55e8aa450bfa 100644 --- a/drivers/video/tridentfb.c +++ b/drivers/video/tridentfb.c | |||
@@ -1130,7 +1130,8 @@ static int __devinit trident_pci_probe(struct pci_dev * dev, const struct pci_de | |||
1130 | 1130 | ||
1131 | if (!request_mem_region(tridentfb_fix.smem_start, tridentfb_fix.smem_len, "tridentfb")) { | 1131 | if (!request_mem_region(tridentfb_fix.smem_start, tridentfb_fix.smem_len, "tridentfb")) { |
1132 | debug("request_mem_region failed!\n"); | 1132 | debug("request_mem_region failed!\n"); |
1133 | return -1; | 1133 | err = -1; |
1134 | goto out_unmap; | ||
1134 | } | 1135 | } |
1135 | 1136 | ||
1136 | fb_info.screen_base = ioremap_nocache(tridentfb_fix.smem_start, | 1137 | fb_info.screen_base = ioremap_nocache(tridentfb_fix.smem_start, |
@@ -1139,7 +1140,8 @@ static int __devinit trident_pci_probe(struct pci_dev * dev, const struct pci_de | |||
1139 | if (!fb_info.screen_base) { | 1140 | if (!fb_info.screen_base) { |
1140 | release_mem_region(tridentfb_fix.smem_start, tridentfb_fix.smem_len); | 1141 | release_mem_region(tridentfb_fix.smem_start, tridentfb_fix.smem_len); |
1141 | debug("ioremap failed\n"); | 1142 | debug("ioremap failed\n"); |
1142 | return -1; | 1143 | err = -1; |
1144 | goto out_unmap; | ||
1143 | } | 1145 | } |
1144 | 1146 | ||
1145 | output("%s board found\n", pci_name(dev)); | 1147 | output("%s board found\n", pci_name(dev)); |
@@ -1162,8 +1164,10 @@ static int __devinit trident_pci_probe(struct pci_dev * dev, const struct pci_de | |||
1162 | #endif | 1164 | #endif |
1163 | fb_info.pseudo_palette = pseudo_pal; | 1165 | fb_info.pseudo_palette = pseudo_pal; |
1164 | 1166 | ||
1165 | if (!fb_find_mode(&default_var,&fb_info,mode,NULL,0,NULL,bpp)) | 1167 | if (!fb_find_mode(&default_var,&fb_info,mode,NULL,0,NULL,bpp)) { |
1166 | return -EINVAL; | 1168 | err = -EINVAL; |
1169 | goto out_unmap; | ||
1170 | } | ||
1167 | fb_alloc_cmap(&fb_info.cmap,256,0); | 1171 | fb_alloc_cmap(&fb_info.cmap,256,0); |
1168 | if (defaultaccel && acc) | 1172 | if (defaultaccel && acc) |
1169 | default_var.accel_flags |= FB_ACCELF_TEXT; | 1173 | default_var.accel_flags |= FB_ACCELF_TEXT; |
@@ -1174,12 +1178,20 @@ static int __devinit trident_pci_probe(struct pci_dev * dev, const struct pci_de | |||
1174 | fb_info.device = &dev->dev; | 1178 | fb_info.device = &dev->dev; |
1175 | if (register_framebuffer(&fb_info) < 0) { | 1179 | if (register_framebuffer(&fb_info) < 0) { |
1176 | printk(KERN_ERR "tridentfb: could not register Trident framebuffer\n"); | 1180 | printk(KERN_ERR "tridentfb: could not register Trident framebuffer\n"); |
1177 | return -EINVAL; | 1181 | err = -EINVAL; |
1182 | goto out_unmap; | ||
1178 | } | 1183 | } |
1179 | output("fb%d: %s frame buffer device %dx%d-%dbpp\n", | 1184 | output("fb%d: %s frame buffer device %dx%d-%dbpp\n", |
1180 | fb_info.node, fb_info.fix.id,default_var.xres, | 1185 | fb_info.node, fb_info.fix.id,default_var.xres, |
1181 | default_var.yres,default_var.bits_per_pixel); | 1186 | default_var.yres,default_var.bits_per_pixel); |
1182 | return 0; | 1187 | return 0; |
1188 | |||
1189 | out_unmap: | ||
1190 | if (default_par.io_virt) | ||
1191 | iounmap(default_par.io_virt); | ||
1192 | if (fb_info.screen_base) | ||
1193 | iounmap(fb_info.screen_base); | ||
1194 | return err; | ||
1183 | } | 1195 | } |
1184 | 1196 | ||
1185 | static void __devexit trident_pci_remove(struct pci_dev * dev) | 1197 | static void __devexit trident_pci_remove(struct pci_dev * dev) |