| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
 | 2 |  * Copyright (C) 2003 Christoph Hellwig. | 
 | 3 |  *	Released under GPL v2. | 
 | 4 |  * | 
 | 5 |  * Support for old-style host templates. | 
 | 6 |  * | 
 | 7 |  * NOTE:  Do not use this for new drivers ever. | 
 | 8 |  */ | 
 | 9 |  | 
 | 10 | #include <linux/init.h> | 
 | 11 | #include <linux/kernel.h> | 
 | 12 | #include <linux/module.h> | 
 | 13 |  | 
 | 14 | #include <scsi/scsi_host.h> | 
 | 15 |  | 
 | 16 |  | 
 | 17 | static int __init init_this_scsi_driver(void) | 
 | 18 | { | 
 | 19 | 	struct scsi_host_template *sht = &driver_template; | 
 | 20 | 	struct Scsi_Host *shost; | 
 | 21 | 	struct list_head *l; | 
 | 22 | 	int error; | 
 | 23 |  | 
 | 24 | 	if (!sht->release) { | 
 | 25 | 		printk(KERN_ERR | 
 | 26 | 		    "scsi HBA driver %s didn't set a release method.\n", | 
 | 27 | 		    sht->name); | 
 | 28 | 		return -EINVAL; | 
 | 29 | 	} | 
 | 30 |  | 
 | 31 | 	sht->module = THIS_MODULE; | 
 | 32 | 	INIT_LIST_HEAD(&sht->legacy_hosts); | 
 | 33 |  | 
 | 34 | 	sht->detect(sht); | 
 | 35 | 	if (list_empty(&sht->legacy_hosts)) | 
 | 36 | 		return -ENODEV; | 
 | 37 |  | 
 | 38 | 	list_for_each_entry(shost, &sht->legacy_hosts, sht_legacy_list) { | 
 | 39 | 		error = scsi_add_host(shost, NULL); | 
 | 40 | 		if (error) | 
 | 41 | 			goto fail; | 
 | 42 | 		scsi_scan_host(shost); | 
 | 43 | 	} | 
 | 44 | 	return 0; | 
 | 45 |  fail: | 
 | 46 | 	l = &shost->sht_legacy_list; | 
 | 47 | 	while ((l = l->prev) != &sht->legacy_hosts) | 
 | 48 | 		scsi_remove_host(list_entry(l, struct Scsi_Host, sht_legacy_list)); | 
 | 49 | 	return error; | 
 | 50 | } | 
 | 51 |  | 
 | 52 | static void __exit exit_this_scsi_driver(void) | 
 | 53 | { | 
 | 54 | 	struct scsi_host_template *sht = &driver_template; | 
 | 55 | 	struct Scsi_Host *shost, *s; | 
 | 56 |  | 
 | 57 | 	list_for_each_entry(shost, &sht->legacy_hosts, sht_legacy_list) | 
 | 58 | 		scsi_remove_host(shost); | 
 | 59 | 	list_for_each_entry_safe(shost, s, &sht->legacy_hosts, sht_legacy_list) | 
 | 60 | 		sht->release(shost); | 
 | 61 |  | 
 | 62 | 	if (list_empty(&sht->legacy_hosts)) | 
 | 63 | 		return; | 
 | 64 |  | 
 | 65 | 	printk(KERN_WARNING "%s did not call scsi_unregister\n", sht->name); | 
 | 66 | 	dump_stack(); | 
 | 67 |  | 
 | 68 | 	list_for_each_entry_safe(shost, s, &sht->legacy_hosts, sht_legacy_list) | 
 | 69 | 		scsi_unregister(shost); | 
 | 70 | } | 
 | 71 |  | 
 | 72 | module_init(init_this_scsi_driver); | 
 | 73 | module_exit(exit_this_scsi_driver); |