Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 5 Aug 2014 23:35:19 +0000 (UTC)
From:      John Baldwin <jhb@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r269612 - head/sys/dev/hptiop
Message-ID:  <53e16a37.5b77.57894f1c@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: jhb
Date: Tue Aug  5 23:35:19 2014
New Revision: 269612
URL: http://svnweb.freebsd.org/changeset/base/269612

Log:
  Various fixes to hptiop(4):
  - Use callout(9) instead of timeout(9).
  - Use the existing hba lock as the CAM sim lock instead of Giant.
  - Mark interrupt handler MPSAFE.
  - Reorder detach and destroy the hba lock in detach.
  
  Reviewed by:	Steve Chang <ychang@highpoint-tech.com>

Modified:
  head/sys/dev/hptiop/hptiop.c
  head/sys/dev/hptiop/hptiop.h

Modified: head/sys/dev/hptiop/hptiop.c
==============================================================================
--- head/sys/dev/hptiop/hptiop.c	Tue Aug  5 23:32:53 2014	(r269611)
+++ head/sys/dev/hptiop/hptiop.c	Tue Aug  5 23:35:19 2014	(r269612)
@@ -643,7 +643,7 @@ static void hptiop_request_callback_mvfr
 
 		ccb = (union ccb *)srb->ccb;
 
-		untimeout(hptiop_reset_adapter, hba, srb->timeout_ch);
+		callout_stop(&srb->timeout);
 
 		if (ccb->ccb_h.flags & CAM_CDB_POINTER)
 			cdb = ccb->csio.cdb_io.cdb_ptr;
@@ -2013,12 +2013,13 @@ static int hptiop_attach(device_t dev)
 	}
 
 	hba->sim = cam_sim_alloc(hptiop_action, hptiop_poll, driver_name,
-			hba, unit, &Giant, hba->max_requests - 1, 1, devq);
+			hba, unit, &hba->lock, hba->max_requests - 1, 1, devq);
 	if (!hba->sim) {
 		device_printf(dev, "cam_sim_alloc failed\n");
 		cam_simq_free(devq);
 		goto srb_dmamap_unload;
 	}
+	hptiop_lock_adapter(hba);
 	if (xpt_bus_register(hba->sim, dev, 0) != CAM_SUCCESS)
 	{
 		device_printf(dev, "xpt_bus_register failed\n");
@@ -2031,6 +2032,7 @@ static int hptiop_attach(device_t dev)
 		device_printf(dev, "xpt_create_path failed\n");
 		goto deregister_xpt_bus;
 	}
+	hptiop_unlock_adapter(hba);
 
 	bzero(&set_config, sizeof(set_config));
 	set_config.iop_id = unit;
@@ -2056,7 +2058,7 @@ static int hptiop_attach(device_t dev)
 		goto free_hba_path;
 	}
 
-	if (bus_setup_intr(hba->pcidev, hba->irq_res, INTR_TYPE_CAM,
+	if (bus_setup_intr(hba->pcidev, hba->irq_res, INTR_TYPE_CAM | INTR_MPSAFE,
 				NULL, hptiop_pci_intr, hba, &hba->irq_handle))
 	{
 		device_printf(dev, "allocate intr function failed!\n");
@@ -2086,6 +2088,7 @@ teartown_irq_resource:
 free_irq_resource:
 	bus_release_resource(dev, SYS_RES_IRQ, 0, hba->irq_res);
 
+	hptiop_lock_adapter(hba);
 free_hba_path:
 	xpt_free_path(hba->path);
 
@@ -2094,6 +2097,7 @@ deregister_xpt_bus:
 
 free_cam_sim:
 	cam_sim_free(hba->sim, /*free devq*/ TRUE);
+	hptiop_unlock_adapter(hba);
 
 srb_dmamap_unload:
 	if (hba->uncached_ptr)
@@ -2145,9 +2149,10 @@ static int hptiop_detach(device_t dev)
 	if (hptiop_send_sync_msg(hba,
 		IOPMU_INBOUND_MSG0_STOP_BACKGROUND_TASK, 60000))
 		goto out;
+	hptiop_unlock_adapter(hba);
 
 	hptiop_release_resource(hba);
-	error = 0;
+	return (0);
 out:
 	hptiop_unlock_adapter(hba);
 	return error;
@@ -2182,7 +2187,10 @@ static void hptiop_pci_intr(void *arg)
 
 static void hptiop_poll(struct cam_sim *sim)
 {
-	hptiop_pci_intr(cam_sim_softc(sim));
+	struct hpt_iop_hba *hba;
+
+	hba = cam_sim_softc(sim);
+	hba->ops->iop_intr(hba);
 }
 
 static void hptiop_async(void * callback_arg, u_int32_t code,
@@ -2289,21 +2297,20 @@ static void hptiop_action(struct cam_sim
 	switch (ccb->ccb_h.func_code) {
 
 	case XPT_SCSI_IO:
-		hptiop_lock_adapter(hba);
 		if (ccb->ccb_h.target_lun != 0 ||
 			ccb->ccb_h.target_id >= hba->max_devices ||
 			(ccb->ccb_h.flags & CAM_CDB_PHYS))
 		{
 			ccb->ccb_h.status = CAM_TID_INVALID;
 			xpt_done(ccb);
-			goto scsi_done;
+			return;
 		}
 
 		if ((srb = hptiop_get_srb(hba)) == NULL) {
 			device_printf(hba->pcidev, "srb allocated failed");
 			ccb->ccb_h.status = CAM_REQ_CMP_ERR;
 			xpt_done(ccb);
-			goto scsi_done;
+			return;
 		}
 
 		srb->ccb = ccb;
@@ -2322,19 +2329,15 @@ static void hptiop_action(struct cam_sim
 			ccb->ccb_h.status = CAM_REQ_CMP_ERR;
 			hptiop_free_srb(hba, srb);
 			xpt_done(ccb);
-			goto scsi_done;
+			return;
 		}
 
-scsi_done:
-		hptiop_unlock_adapter(hba);
 		return;
 
 	case XPT_RESET_BUS:
 		device_printf(hba->pcidev, "reset adapter");
-		hptiop_lock_adapter(hba);
 		hba->msg_done = 0;
 		hptiop_reset_adapter(hba);
-		hptiop_unlock_adapter(hba);
 		break;
 
 	case XPT_GET_TRAN_SETTINGS:
@@ -2629,7 +2632,7 @@ static void hptiop_post_req_mvfrey(struc
 	BUS_SPACE_RD4_MVFREY2(inbound_write_ptr);
 
 	if (req->header.type == IOP_REQUEST_TYPE_SCSI_COMMAND) {
-		srb->timeout_ch = timeout(hptiop_reset_adapter, hba, 20*hz);
+		callout_reset(&srb->timeout, 20 * hz, hptiop_reset_adapter, hba);
 	}
 }
 
@@ -2741,7 +2744,7 @@ static void hptiop_map_srb(void *arg, bu
 				tmp_srb->phy_addr = phy_addr;
 			}
 
-			callout_handle_init(&tmp_srb->timeout_ch);
+			callout_init_mtx(&tmp_srb->timeout, &hba->lock, 0);
 			hptiop_free_srb(hba, tmp_srb);
 			hba->srb[i] = tmp_srb;
 			phy_addr += HPT_SRB_MAX_SIZE;
@@ -2785,6 +2788,10 @@ static  int hptiop_os_query_remove_devic
 static void hptiop_release_resource(struct hpt_iop_hba *hba)
 {
 	int i;
+
+	if (hba->ioctl_dev)
+		destroy_dev(hba->ioctl_dev);
+
 	if (hba->path) {
 		struct ccb_setasync ccb;
 
@@ -2797,9 +2804,14 @@ static void hptiop_release_resource(stru
 		xpt_free_path(hba->path);
 	}
 
+	if (hba->irq_handle)
+		bus_teardown_intr(hba->pcidev, hba->irq_res, hba->irq_handle);
+
 	if (hba->sim) {
+		hptiop_lock_adapter(hba);
 		xpt_bus_deregister(cam_sim_path(hba->sim));
 		cam_sim_free(hba->sim, TRUE);
+		hptiop_unlock_adapter(hba);
 	}
 
 	if (hba->ctlcfg_dmat) {
@@ -2813,6 +2825,7 @@ static void hptiop_release_resource(stru
 		struct hpt_iop_srb *srb = hba->srb[i];
 		if (srb->dma_map)
 			bus_dmamap_destroy(hba->io_dmat, srb->dma_map);
+		callout_drain(&srb->timeout);
 	}
 
 	if (hba->srb_dmat) {
@@ -2827,9 +2840,6 @@ static void hptiop_release_resource(stru
 	if (hba->parent_dmat)
 		bus_dma_tag_destroy(hba->parent_dmat);
 
-	if (hba->irq_handle)
-		bus_teardown_intr(hba->pcidev, hba->irq_res, hba->irq_handle);
-
 	if (hba->irq_res)
 		bus_release_resource(hba->pcidev, SYS_RES_IRQ,
 					0, hba->irq_res);
@@ -2840,6 +2850,5 @@ static void hptiop_release_resource(stru
 	if (hba->bar2_res)
 		bus_release_resource(hba->pcidev, SYS_RES_MEMORY,
 					hba->bar2_rid, hba->bar2_res);
-	if (hba->ioctl_dev)
-		destroy_dev(hba->ioctl_dev);
+	mtx_destroy(&hba->lock);
 }

Modified: head/sys/dev/hptiop/hptiop.h
==============================================================================
--- head/sys/dev/hptiop/hptiop.h	Tue Aug  5 23:32:53 2014	(r269611)
+++ head/sys/dev/hptiop/hptiop.h	Tue Aug  5 23:35:19 2014	(r269612)
@@ -460,7 +460,7 @@ struct hpt_iop_srb {
 	u_int64_t            phy_addr;
 	u_int32_t            srb_flag;
 	int                  index;
-	struct callout_handle	timeout_ch;
+	struct callout	     timeout;
 };
 
 #define hptiop_lock_adapter(hba)   mtx_lock(&(hba)->lock)



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?53e16a37.5b77.57894f1c>