Index: mm/sound/drivers/mpu401/mpu401.c =================================================================== --- mm.orig/sound/drivers/mpu401/mpu401.c 2006-04-13 01:37:08.000000000 +0200 +++ mm/sound/drivers/mpu401/mpu401.c 2006-04-13 01:37:40.000000000 +0200 @@ -252,10 +252,8 @@ static int __init alsa_card_mpu401_init( #endif device = platform_device_register_simple(SND_MPU401_DRIVER, i, NULL, 0); - if (IS_ERR(device)) { - err = PTR_ERR(device); - goto errout; - } + if (IS_ERR(device)) + continue; platform_devices[i] = device; snd_mpu401_devices++; } @@ -267,14 +265,10 @@ static int __init alsa_card_mpu401_init( #ifdef MODULE printk(KERN_ERR "MPU-401 device not found or device busy\n"); #endif - err = -ENODEV; - goto errout; + snd_mpu401_unregister_all(); + return -ENODEV; } return 0; - - errout: - snd_mpu401_unregister_all(); - return err; } static void __exit alsa_card_mpu401_exit(void) Index: mm/sound/drivers/serial-u16550.c =================================================================== --- mm.orig/sound/drivers/serial-u16550.c 2006-04-13 01:36:54.000000000 +0200 +++ mm/sound/drivers/serial-u16550.c 2006-04-13 01:37:40.000000000 +0200 @@ -996,10 +996,8 @@ static int __init alsa_card_serial_init( continue; device = platform_device_register_simple(SND_SERIAL_DRIVER, i, NULL, 0); - if (IS_ERR(device)) { - err = PTR_ERR(device); - goto errout; - } + if (IS_ERR(device)) + continue; devices[i] = device; cards++; } @@ -1007,14 +1005,10 @@ static int __init alsa_card_serial_init( #ifdef MODULE printk(KERN_ERR "serial midi soundcard not found or device busy\n"); #endif - err = -ENODEV; - goto errout; + snd_serial_unregister_all(); + return -ENODEV; } return 0; - - errout: - snd_serial_unregister_all(); - return err; } static void __exit alsa_card_serial_exit(void) Index: mm/sound/drivers/virmidi.c =================================================================== --- mm.orig/sound/drivers/virmidi.c 2006-04-13 01:36:54.000000000 +0200 +++ mm/sound/drivers/virmidi.c 2006-04-13 01:37:40.000000000 +0200 @@ -169,10 +169,8 @@ static int __init alsa_card_virmidi_init continue; device = platform_device_register_simple(SND_VIRMIDI_DRIVER, i, NULL, 0); - if (IS_ERR(device)) { - err = PTR_ERR(device); - goto errout; - } + if (IS_ERR(device)) + continue; devices[i] = device; cards++; } @@ -180,14 +178,10 @@ static int __init alsa_card_virmidi_init #ifdef MODULE printk(KERN_ERR "Card-VirMIDI soundcard not found or device busy\n"); #endif - err = -ENODEV; - goto errout; + snd_virmidi_unregister_all(); + return -ENODEV; } return 0; - - errout: - snd_virmidi_unregister_all(); - return err; } static void __exit alsa_card_virmidi_exit(void) Index: mm/sound/drivers/dummy.c =================================================================== --- mm.orig/sound/drivers/dummy.c 2006-04-13 01:36:54.000000000 +0200 +++ mm/sound/drivers/dummy.c 2006-04-13 01:39:12.000000000 +0200 @@ -675,10 +675,8 @@ static int __init alsa_card_dummy_init(v continue; device = platform_device_register_simple(SND_DUMMY_DRIVER, i, NULL, 0); - if (IS_ERR(device)) { - err = PTR_ERR(device); - goto errout; - } + if (IS_ERR(device)) + continue; devices[i] = device; cards++; } @@ -686,14 +684,10 @@ static int __init alsa_card_dummy_init(v #ifdef MODULE printk(KERN_ERR "Dummy soundcard not found or device busy\n"); #endif - err = -ENODEV; - goto errout; + snd_dummy_unregister_all(); + return -ENODEV; } return 0; - - errout: - snd_dummy_unregister_all(); - return err; } static void __exit alsa_card_dummy_exit(void)