summaryrefslogtreecommitdiffstats
path: root/share/examples/scsi_target
diff options
context:
space:
mode:
authorgibbs <gibbs@FreeBSD.org>1999-08-16 22:52:17 +0000
committergibbs <gibbs@FreeBSD.org>1999-08-16 22:52:17 +0000
commit2aae5e70727528e937ac776fb30429b624935242 (patch)
treeaca08e3397b34188ec1fc39b53897a996f3d2a40 /share/examples/scsi_target
parentedb123178ed447ee9d8297ad8387ff6b3e6f72ec (diff)
downloadFreeBSD-src-2aae5e70727528e937ac776fb30429b624935242.zip
FreeBSD-src-2aae5e70727528e937ac776fb30429b624935242.tar.gz
Add a cleanup handler called "atexit" to make sure we free up target
mode instances. Print out exception information passed out from the kernel target mode driver to this userland daemon.
Diffstat (limited to 'share/examples/scsi_target')
-rw-r--r--share/examples/scsi_target/scsi_target.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/share/examples/scsi_target/scsi_target.c b/share/examples/scsi_target/scsi_target.c
index 798c30b..cad82c3 100644
--- a/share/examples/scsi_target/scsi_target.c
+++ b/share/examples/scsi_target/scsi_target.c
@@ -26,7 +26,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
- * $Id: scsi_target.c,v 1.2 1998/12/10 04:00:03 gibbs Exp $
+ * $Id: scsi_target.c,v 1.3 1999/03/05 23:12:02 gibbs Exp $
*/
#include <sys/types.h>
@@ -63,6 +63,7 @@ struct ioc_alloc_unit alloc_unit = {
};
static void pump_events();
+static void cleanup();
static void handle_exception();
static void quit_handler();
static void usage();
@@ -154,8 +155,16 @@ main(int argc, char *argv[])
signal(SIGINT, quit_handler);
signal(SIGTERM, quit_handler);
+ atexit(cleanup);
+
pump_events();
+ return (0);
+}
+
+static void
+cleanup()
+{
close(targfd);
if (ioctl(targctlfd, TARGCTLIOFREEUNIT, &alloc_unit) == -1) {
@@ -164,7 +173,6 @@ main(int argc, char *argv[])
}
close(targctlfd);
- return (0);
}
static void
@@ -207,6 +215,8 @@ pump_events()
if (retval == -1) {
perror("Read from targ failed");
+ /* Go look for exceptions */
+ continue;
} else {
retval = write(ofd, buf, retval);
if (retval == -1) {
@@ -248,8 +258,10 @@ handle_exception()
exit(EX_SOFTWARE);
}
+ printf("Saw exceptions %x\n", exceptions);
if ((exceptions & TARG_EXCEPT_DEVICE_INVALID) != 0) {
/* Device went away. Nothing more to do. */
+ printf("Device went away\n");
exit(0);
}
OpenPOWER on IntegriCloud