Google
 

Trailing-Edge - PDP-10 Archives - bb-4157h-bm_fortran20_v10_16mt9 - fortran-compiler/inpt.bli
There are 12 other files named inpt.bli in the archive. Click here to see a list.
!COPYRIGHT (C) DIGITAL EQUIPMENT CORPORATION 1972, 1985
!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 WHICH IS NOT SUPPLIED BY DIGITAL.

!AUTHOR: S.MURPHY/HPW/TFV

MODULE INPT(RESERVE(0,1,2,3),DREGS=4,SREG=#17,FREG=#16,VREG=#15,GLOROUTINES)=
BEGIN

GLOBAL BIND INPTV = #10^24 + 0^18 + #1530;	! Version Date: 4-May-82

%(

***** Begin Revision History *****

83	-----	-----	INTERFACE TO SKOPTIO

***** Begin Version 7 *****

1530	TFV	4-May-82
	Setup IOLSTATEMENT filed in IOLSCLS nodes.

***** End Revision History *****

)%

SWITCHES NOLIST;
REQUIRE FIRST.BLI;
REQUIRE TABLES.BLI;
SWITCHES LIST;

EXTERNAL
	BASE CSTMNT,
	DOWDP,		! Global used in determining whether a given loop can
			! have its loop index live in a register.
	FOLDIOLST,
	NEGFLG,
	NOTFLG,
	P2SKL1DISP,
	P2SKSTMNT,
%1530%	TOPIO;		! Pointer to the I/O statement above an IOLSCLS node.
GLOBAL ROUTINE SKIOLIST=
BEGIN
	!***************************************************************
	! Perform phase 2 skeleton optimizations on an iolist.  Makes  3
	! passes over the list:
	!
	!	1. Perform  phase  2   skeleton  optimizations  on   the
	!	   expressions under the iolist elements.
	!	2. Detect DO loops  that can be  folded into elists  and
	!	   fold them (not implemented in release 1).
	!	3. Detect groups of DATACALLs and SLISTCALLs that can be
	!	   folded into a single IOLISTCALL and fold them.
	!
	! Called with the global CSTMNT  pointing to a statement with  a
	! potential iolist.
	!***************************************************************

	REGISTER
		PEXPRNODE ARGNODE,
		BASE IOLELEM,
		BASE SAVSTMNT;

	MAP OBJECTCODE DOWDP;

	! Return if this statement has no iolist

	IF .CSTMNT[IOLIST] EQL 0 THEN RETURN;

	! Save pointer to  this statement (will  recurse through  SKSTMN
	! routines if there are any statements on this iolist

	SAVSTMNT = .CSTMNT;

	! Walk down the iolist performing phase 2 skeleton optimizations
	! on each element

	IOLELEM = .CSTMNT[IOLIST];

	UNTIL .IOLELEM EQL 0
	DO
	BEGIN	! Walk down the iolist

		IF .IOLELEM[OPRCLS] EQL STATEMENT
		THEN
		BEGIN
			CSTMNT = .IOLELEM;
			P2SKSTMNT();		! Do skeleton optimizations
		END
		ELSE	IF .IOLELEM[OPRCLS] EQL IOLSCLS
		THEN
		BEGIN
%1530%			! Setup pointer to the I/O statement above the IOLSCLS

%1530%			IOLELEM[IOLSTATEMENT] = .TOPIO;

			! For a DATACALL node, perform phase 2  skeleton
			! optimizations on expressions under this node

			IF .IOLELEM[OPERSP] EQL DATACALL
			THEN
			BEGIN
				NEGFLG = FALSE;
				NOTFLG = FALSE;
				ARGNODE = .IOLELEM[DCALLELEM];
				IOLELEM[DCALLELEM] = (.P2SKL1DISP[.ARGNODE[OPRCLS]])(.ARGNODE);

				! Check whether the argument to FOROTS is  the
				! index of the current DO loop.  If so,  don't
				! make it an AOBJN  loop (problems with  using
				! right-half of register.

				ARGNODE = .IOLELEM[DCALLELEM];

				IF .ARGNODE EQL .DOWDP[DOINDUC]
				THEN DOWDP[DONOAOBJN] = 1;
			END;
		END;

		! Go on to next element

		IOLELEM = .IOLELEM[CLINK];

	END;	! Walk down iolist

	CSTMNT = .SAVSTMNT; 	! Restore CSTMNT

	! Walk down the iolist performing folding  of DO loops into ELISTs  is
	! not implemented in release 1 (Aug 17,1972 - SRM).

	! Walk down the  iolist, folding groups  of elements that  can form  a
	! single IOLISTCALL

	FOLDIOLST();

END;	! of SKIOLIST

END
ELUDOM