Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 9 Jan 2018 16:11:33 +0000 (UTC)
From:      Warner Losh <imp@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r327729 - in head/sys: cam/scsi i386/isa
Message-ID:  <201801091611.w09GBYV5076188@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: imp
Date: Tue Jan  9 16:11:33 2018
New Revision: 327729
URL: https://svnweb.freebsd.org/changeset/base/327729

Log:
  Remove ccbque.h from i386/isa.
  
  inline ccbque.h into scsi_low.h. The file isn't MD, so shouldn't live
  in i386/isa. It's only used by scsi_low, so move it there so no new
  clients accidentally grow. scsi_low may not even still work, and the
  locking here is still SPL based. CAM should do the right thing, but
  I've received no reports of these cards still working. At least it
  compiles still and there's one fewer files in sys/i386/isa. While I'm
  here, ansify and de-splize. CCB_MWANTED appears to be a clear-only
  flag, but I've not changed that.
  
  Differential Review: https://reviews.freebsd.org/D13672

Deleted:
  head/sys/i386/isa/ccbque.h
Modified:
  head/sys/cam/scsi/scsi_low.c
  head/sys/cam/scsi/scsi_low.h

Modified: head/sys/cam/scsi/scsi_low.c
==============================================================================
--- head/sys/cam/scsi/scsi_low.c	Tue Jan  9 15:57:09 2018	(r327728)
+++ head/sys/cam/scsi/scsi_low.c	Tue Jan  9 16:11:33 2018	(r327729)
@@ -88,6 +88,65 @@ __FBSDID("$FreeBSD$");
 #include <sys/cons.h>
 
 /**************************************************************
+ * CCB Macros
+ **************************************************************/
+
+/* (II)  static allocated memory */
+#define GENERIC_CCB_STATIC_ALLOC(DEV, CCBTYPE)				\
+static struct CCBTYPE##que CCBTYPE##que;
+
+/* (III)  functions */
+#define GENERIC_CCB(DEV, CCBTYPE, CHAIN)				\
+									\
+void									\
+DEV##_init_ccbque(int count)						\
+{									\
+	if (CCBTYPE##que.maxccb == 0)					\
+		TAILQ_INIT(&CCBTYPE##que.CCBTYPE##tab);			\
+	CCBTYPE##que.maxccb += count;					\
+}									\
+									\
+struct CCBTYPE *							\
+DEV##_get_ccb(void)							\
+{									\
+	struct CCBTYPE *cb;						\
+									\
+	if (CCBTYPE##que.count < CCBTYPE##que.maxccb)			\
+	{								\
+		CCBTYPE##que.count ++;					\
+		cb = TAILQ_FIRST(&(CCBTYPE##que.CCBTYPE##tab));		\
+		if (cb != NULL) {					\
+			TAILQ_REMOVE(&CCBTYPE##que.CCBTYPE##tab, cb, CHAIN);\
+			goto out;					\
+		} else {						\
+			cb = malloc(sizeof(*cb), M_DEVBUF, M_NOWAIT  | M_ZERO);	\
+			if (cb != NULL)					\
+				goto out;				\
+		}							\
+		CCBTYPE##que.count --;					\
+	}								\
+									\
+	cb = NULL;							\
+									\
+out:									\
+	return cb;							\
+}									\
+									\
+void									\
+DEV##_free_ccb(struct CCBTYPE *cb)					\
+{									\
+									\
+	TAILQ_INSERT_TAIL(&CCBTYPE##que.CCBTYPE##tab, cb, CHAIN);	\
+	CCBTYPE##que.count --;						\
+									\
+	if (CCBTYPE##que.flags & CCB_MWANTED)				\
+	{								\
+		CCBTYPE##que.flags &= ~CCB_MWANTED;			\
+		wakeup ((caddr_t) &CCBTYPE##que.count);			\
+	}								\
+}
+
+/**************************************************************
  * Constants
  **************************************************************/
 #define	SCSI_LOW_POLL_HZ	1000

Modified: head/sys/cam/scsi/scsi_low.h
==============================================================================
--- head/sys/cam/scsi/scsi_low.h	Tue Jan  9 15:57:09 2018	(r327728)
+++ head/sys/cam/scsi/scsi_low.h	Tue Jan  9 16:11:33 2018	(r327729)
@@ -57,7 +57,61 @@
 #include <cam/cam_debug.h>
 
 #include <cam/scsi/scsi_dvcfg.h>
-#include <i386/isa/ccbque.h>
+/************ ccbque.h ***************************/
+
+/*	$NetBSD$	*/
+/*-
+ * SPDX-License-Identifier: BSD-3-Clause
+ *
+ * [NetBSD for NEC PC98 series]
+ *  Copyright (c) 1994, 1995, 1996 NetBSD/pc98 porting staff.
+ *  All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without
+ *  modification, are permitted provided that the following conditions
+ *  are met:
+ *  1. Redistributions of source code must retain the above copyright
+ *     notice, this list of conditions and the following disclaimer.
+ *  2. Redistributions in binary form must reproduce the above copyright
+ *     notice, this list of conditions and the following disclaimer in the
+ *     documentation and/or other materials provided with the distribution.
+ *  3. The name of the author may not be used to endorse or promote products
+ *     derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ *
+ * $FreeBSD$
+ */
+/*
+ * Common command control queue funcs.
+ * Written by N. Honda.
+ */
+
+#define	CCB_MWANTED 0x01
+
+/* (I)  structure and prototype */
+#define GENERIC_CCB_ASSERT(DEV, CCBTYPE)				\
+TAILQ_HEAD(CCBTYPE##tab, CCBTYPE);					\
+struct CCBTYPE##que {							\
+	struct CCBTYPE##tab CCBTYPE##tab;				\
+	int count;							\
+	int maxccb;							\
+	u_int flags;							\
+};									\
+									\
+void DEV##_init_ccbque(int);						\
+struct CCBTYPE *DEV##_get_ccb(void);					\
+void DEV##_free_ccb(struct CCBTYPE *);
 
 /******** functions macro ************************/
 



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201801091611.w09GBYV5076188>