⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gfs_dsort.c

📁 <B>Digital的Unix操作系统VAX 4.2源码</B>
💻 C
字号:
#ifndef lintstatic char *sccsid = "@(#)gfs_dsort.c	4.1	ULTRIX	7/2/90";#endif/************************************************************************ *									* *			Copyright (c) 1986 by				* *		Digital Equipment Corporation, Maynard, MA		* *			All rights reserved.				* *									* *   This software is furnished under a license and may be used and	* *   copied  only  in accordance with the terms of such license and	* *   with the  inclusion  of  the  above  copyright  notice.   This	* *   software  or  any  other copies thereof may not be provided or	* *   otherwise made available to any other person.  No title to and	* *   ownership of the software is hereby transferred.			* *									* *   This software is  derived  from  software  received  from  the	* *   University    of   California,   Berkeley,   and   from   Bell	* *   Laboratories.  Use, duplication, or disclosure is  subject  to	* *   restrictions  under  license  agreements  with  University  of	* *   California and with AT&T.						* *									* *   The information in this software is subject to change  without	* *   notice  and should not be construed as a commitment by Digital	* *   Equipment Corporation.						* *									* *   Digital assumes no responsibility for the use  or  reliability	* *   of its software on equipment which is not supplied by Digital.	* *									* ************************************************************************//* * Seek sort for disks.  We depend on the driver * which calls us using b_resid as the current cylinder number. * * The argument dp structure holds a b_actf activity chain pointer * on which we keep two queues, sorted in ascending cylinder order. * The first queue holds those requests which are positioned after * the current cylinder (in the first request); the second holds * requests which came in after their cylinder number was passed. * Thus we implement a one way scan, retracting after reaching the * end of the drive to the first request on the second queue, * at which time it becomes the first queue. * * A one-way scan is natural because of the way UNIX read-ahead * blocks are allocated. *//*********************************************************************** * *		Modification History * * 11 Sep 86 -- koehler *	added modification history * ***********************************************************************/#include "../h/param.h"#include "../h/systm.h"#include "../h/buf.h"#define	b_cylin	b_residdisksort(dp, bp)	register struct buf *dp, *bp;{	register struct buf *ap;	/*	 * If nothing on the activity queue, then	 * we become the only thing.	 */	ap = dp->b_actf;	if(ap == NULL) {		dp->b_actf = bp;		dp->b_actl = bp;		bp->av_forw = NULL;		return;	}	/*	 * If we lie after the first (currently active)	 * request, then we must locate the second request list	 * and add ourselves to it.	 */	if (bp->b_cylin < ap->b_cylin) {		while (ap->av_forw) {			/*			 * Check for an ``inversion'' in the			 * normally ascending cylinder numbers,			 * indicating the start of the second request list.			 */			if (ap->av_forw->b_cylin < ap->b_cylin) {				/*				 * Search the second request list				 * for the first request at a larger				 * cylinder number.  We go before that;				 * if there is no such request, we go at end.				 */				do {					if (bp->b_cylin < ap->av_forw->b_cylin)						goto insert;					ap = ap->av_forw;				} while (ap->av_forw);				goto insert;		/* after last */			}			ap = ap->av_forw;		}		/*		 * No inversions... we will go after the last, and		 * be the first request in the second request list.		 */		goto insert;	}	/*	 * Request is at/after the current request...	 * sort in the first request list.	 */	while (ap->av_forw) {		/*		 * We want to go after the current request		 * if there is an inversion after it (i.e. it is		 * the end of the first request list), or if		 * the next request is a larger cylinder than our request.		 */		if (ap->av_forw->b_cylin < ap->b_cylin ||		    bp->b_cylin < ap->av_forw->b_cylin)			goto insert;		ap = ap->av_forw;	}	/*	 * Neither a second list nor a larger	 * request... we go at the end of the first list,	 * which is the same as the end of the whole schebang.	 */insert:	bp->av_forw = ap->av_forw;	ap->av_forw = bp;	if (ap == dp->b_actl)		dp->b_actl = bp;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -