Google
 

Trailing-Edge - PDP-10 Archives - tops20-v7-ft-dist1-clock - 7-sources/rmsfls.b36
There are 6 other files named rmsfls.b36 in the archive. Click here to see a list.
%title 'F L U S H   -- process $FLUSH call'
!<BLF/REQUIRE 'RMSBLF.REQ'>
MODULE flush (IDENT = '3.0'
		) =
BEGIN
!
!	COPYRIGHT (C) DIGITAL EQUIPMENT CORPORATION 1984, 1986.
!	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.
!
!	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 THAT IS NOT SUPPLIED BY DIGITAL.
!
!++
! FACILITY:	RMS
!
! ABSTRACT:
!
!	FLUSH contains all routines which
!	process the $FLUSH call in RMS-20.
!
! ENVIRONMENT:	User mode, top level
!
! AUTHOR: Ron Lusk , CREATION DATE:  1-Apr-83
!
! MODIFIED BY:
!
!	, : VERSION
! 01	-
! 660	-	Network $FLUSH
!--

!
! TABLE OF CONTENTS
!
!
!	$FLUSH	-   processor for $FLUSH
!	FLUBUF	-   write buffers to disk
!
!
! INCLUDE FILES:
!

REQUIRE 'rmsreq';

!
! MACROS:
!
!   None.
!
! EQUATED SYMBOLS:
!
!   None.
!
! OWN STORAGE:
!
!   None.
!

EXTERNAL ROUTINE
  Dap$Free_Flush;				! 660
GLOBAL ROUTINE $flush (rabblock, errorreturn) =

!++
! FUNCTIONAL DESCRIPTION:
!
!	$FLUSH flushes all current buffers for a record
!	stream.  This operation is valid for all file
!	organizations, but has important use primarily for
!	sequential files with ASCII or LSA record formats,
!	or for files on sequential devices.  This operation
!	can be done to an indexed file, but unless
!	Write-Behind is being used, there is no advantage in
!	doing so.
!
! FORMAL PARAMETERS
!
!	RABBLOCK	-   Record Access Block address
!	ERRORRETURN	-   user error return address
!
! IMPLICIT INPUTS
!
!	?
!
! ROUTINE VALUE:
!
!	None, yet not novalue.
!
! SIDE EFFECTS:
!
!	?
!
!--

    BEGIN
    rmsentry ($flush);
!+
!   Fetch the address of the user's RAB and his
!   error-processing routine, if any.
!-
    rab = .rabblock;				! Fetch RAB address
    erradr = .errorreturn;			!   and user error address
!+
!   Set up all system-wide pointers, etc., and allow him to
!   perform this operation no matter what his FAB value was
!   when he opened the file.
!-
    rsetup (true);				! Set up all stuff

    IF .Fst[Fst$v_Remote]			! 660
    THEN
       BEGIN
       Dap$Free_Flush (.Rab, .erradr, Dap$k_Flush);
       UsrRet();
       END;

    flubuf ();					! Clear all buffers
!+
!   Exit to the user.
!-
    usrret ()
    END;					!End of $FLUSH
GLOBAL ROUTINE flubuf : NOVALUE =

!++
! FUNCTIONAL DESCRIPTION:
!
!	FLUBUF insures that all updated buffers are written
!	to disk.
!
! FORMAL PARAMETERS
!
!	None.
!
! IMPLICIT INPUTS
!
!	FST	-   File Status Table
!	RST	-   Record Status Table
!
! ROUTINE VALUE:
!
!	NONE.
!
! SIDE EFFECTS:
!
!	None.
!
!--

    BEGIN

    REGISTER
	bdptr : ref block;

    TRACE ('FLUBUF');
!+
!   Note that this routine performs its function primarily
!   for stream or LSA records, or for sequential devices.
!   Also, the file must be currently in output mode for this
!   operation to have any effect.
!-

    IF ((mta) OR (asciifile)) 			! Magtape (?) or ASCII files
    AND ( NOT inputmode)			! We must be writing the file
    THEN                                        ! Flush buffers?        !m577
	IF .rst[rst$v_last_sequential]		! If last operation was
        AND .rst[rst$v_last_operation] EQL C$Put! sequential $Put
	THEN
	    BEGIN				! Yes
	    writebuffer ();			! Output current buffer

            IF (dasd)                                                   !m577
	    THEN pagout (.fst [fstjfn], 	! JFN
		         .currentfilepage, 	! Page to output
                         -1, 			! Just verify to disk
                         asciibktsize);         ! Number of pages
	    END;

!+
!   For disk files, we can cycle through the RST buffers and
!   update all the buffers in this stream.
!-

    IF dasd
    THEN
	BEGIN
	bdptr = bfdoffset;			! First buffer descriptor
!+
!   Loop over all buffers and update them to the disk.
!-

	INCR j FROM 1 TO .rst [rstbfdcount] DO
	    BEGIN
!+
!   If the buffer empty or have old data in it?  If the
!   buffer size is non-zero and the update flag is set, then
!   we have a full buffer that must be updated.
!-

	    IF (.bdptr [bfdbktsiz] neq 0) AND bfdupd (bdptr)
	    THEN
		pagout (.fst [fstjfn], 		! JFN
		    .bdptr [bfdfpage], 		! Page
		    .bdptr [bfdbpage], 		! Memory page
		    .bdptr [bfdbktsiz]);	! Count of pages

	    clearbfdupd (bdptr);
!+
!   Bump the buffer descriptor pointer
!-
	    bdptr = .bdptr + 1;
	    END

	END;

    RETURN;
    END;					!End of FLUBUF

END						!End of Module FLUSH

ELUDOM