patch-2.4.20 linux-2.4.20/drivers/acorn/block/fd1772.c
Next file: linux-2.4.20/drivers/acorn/char/mouse_ps2.c
Previous file: linux-2.4.20/drivers/Makefile
Back to the patch index
Back to the overall index
- Lines: 49
- Date:
Thu Nov 28 15:53:12 2002
- Orig file:
linux-2.4.19/drivers/acorn/block/fd1772.c
- Orig date:
Fri Aug 2 17:39:43 2002
diff -urN linux-2.4.19/drivers/acorn/block/fd1772.c linux-2.4.20/drivers/acorn/block/fd1772.c
@@ -1567,6 +1567,7 @@
int fd1772_init(void)
{
+ int err;
int i;
if (!machine_is_archimedes())
@@ -1584,24 +1585,28 @@
if (request_dma(FIQ_FD1772, "fd1772 end")) {
printk("Unable to grab DMA%d for the floppy (1772) driver\n", FIQ_FD1772);
- free_dma(FLOPPY_DMA);
- return 1;
+ err = 1; /* XXX */
+ goto cleanup_dma;
};
- enable_dma(FIQ_FD1772); /* This inserts a call to our command end routine */
/* initialize variables */
+ err = -ENOMEM;
SelectedDrive = -1;
#ifdef TRACKBUFFER
BufferDrive = BufferSide = BufferTrack = -1;
/* Atari uses 512 - I want to eventually cope with 1K sectors */
DMABuffer = (char *)kmalloc((FD1772_MAX_SECTORS+1)*512,GFP_KERNEL);
+ if (DMABuffer == NULL)
+ goto cleanup_dma;
TrackBuffer = DMABuffer + 512;
#else
/* Allocate memory for the DMAbuffer - on the Atari this takes it
out of some special memory... */
DMABuffer = (char *) kmalloc(2048); /* Copes with pretty large sectors */
+ if (DMABuffer == NULL)
+ goto cleanup_dma;
#endif
-
+ enable_dma(FIQ_FD1772); /* This inserts a call to our command end routine */
for (i = 0; i < FD_MAX_UNITS; i++) {
unit[i].track = -1;
}
@@ -1619,4 +1624,7 @@
config_types();
return 0;
+cleanup_dma:
+ free_dma(FLOPPY_DMA);
+ return err;
}
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)