Google
 

Trailing-Edge - PDP-10 Archives - BB-H580C-SB_1981 - srt4c.doc
There are 3 other files named srt4c.doc in the archive. Click here to see a list.


SRT4C.DOC -- Changes from SORT V4B(435) to V4C(467).
June 1981






























COPYRIGHT (C) 1981 BY
DIGITAL EQUIPMENT CORPORATION, MAYNARD, MASS.


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.
SRT4C.DOC                                                       Page 2


SRT4C.DOC -- Changes from SORT V4B(435) to V4C(467).



1.0  SUMMARY

1.1  Functions

SORT is the high performance sort/merge package for the  DECsystem-10.
SORT may be run as a stand-alone sort/merge, or embedded in a COBOL or
FORTRAN program.

This release, SORT V4C(467), contains all published edits  up  to  and
including edit 467 and fully replaces SORT V4B.


1.2  Monitor

SORT runs under all supported monitors,  and  has  been  tested  under
7.01.  It has not been tested on a KA-10 cpu.

See section 4 for details of how to rebuild SORT.


1.3  Software Dependencies

The internal COBOL-68 SORT  requires  version  12A  or  later  of  the
COBOL-68 object time system, LIBOL.REL, to reside on SYS:.

The internal COBOL-74 SORT  requires  version  12A  or  later  of  the
COBOL-74 object time system, C74LIB.REL, to reside on SYS:.

The internal FORTRAN SORT requires the FORTRAN library, FORLIB.REL, to
reside on SYS:.


1.4  Relevant Documentation

SORT is documented in the following manuals:

DECsystem-10 SORT/MERGE User's Guide, AA-0997D-TB
COBOL-68 Language Reference Manual, AA-5057A-TK
COBOL-74 Language Manual, AA-5059A-TK
DECsystem-10 FORTRAN Programmer's Reference Manual, AA-0944E-TB

These may be found in Software Notebooks 8, 9, 10, and 11.
SRT4C.DOC                                                       Page 3


2.0  EXTERNAL CHANGES

The stand-alone sort no longer requires  FOROTS  to  process  floating
point keys.

The following  new  switches  have  been  added.   They  are  not  yet
documented.

/NOCRLF
This switch tells SORT that BOTH the input and the  output  files  are
fixed size ASCII records containing no carriage control characters.

/AFTER and /BEFORE 
These switches tell SORT where the carriage-control characters  go  in
relation  to  the  record.   /AFTER  is the normal way, /BEFORE is the
COBOL-74 compatible way.  These switches affect output  only  as  SORT
can  read  either  format  correctly  and  just  ignore the extraneous
cr-lfs.

/MAXTEMP
This switch specifies the maximum number of temporary files  that  can
be used during the SORT or MERGE.

All flavours of SORT have been changed to  use  extended  channels  if
7.01  is  running.   In addition the maximum number of temporary files
allowed has been raise from 15 to 26.  This  should  make  COBOL  SORT
more efficient.

If FTVM is turned on, a Virtual Memory version of SORT can  be  built.
This  version  is  not usable as a stand-alone SORT, but can be called
from FORTRAN.  This version of SORT is called FSORT to distinguish  it
from  the  regular  stand-alone SORT.  It requires that the subroutine
FORSRT be assembled and inserted into FORLIB rather  than  the  SRTFOR
version  of FORTRAN SORT.  This version will only run on 7.01 or later
monitors.  It uses the MERGE UUO to read in a  non-shareable  copy  of
FSORT when the SORT function is required.  The only difference between
FSORT and SORT is that FSORT allocates its memory with a PAGE  UUO  at
run  time.  All the power of stand-alone SORT will be available to the
FORTRAN user using this version, it does use SCAN.

The  quote  character  used  to  delimit  literal  collating  sequence
characters can now be either single or double quote, but must occur in
matched pairs.


3.0  KNOWN BUGS AND DEFICIENCIES

As of Feb-80, the following deficiencies are known:

1.  SORT may give the message:

     %SRTNCS Not enough core specified

when no /CORE switch or MEMORY SIZE clause was given.  The sort should
proceed normally, however.
SRT4C.DOC                                                       Page 4


2.  Though FORTRAN SORT's calling sequence is similar  to  stand-alone
SORT's, the following differences are known:

         1.  Continuation lines (in indirect files) are not allowed.

         2.  Indirect files must be on DSK:   in  the  user's  default
         path.

         3.  File extensions must be typed explicitly.

         4.  Switches must always follow file specifications to  which
         they apply.

3.  On VM systems, COBOL SORT  destroys  pages  left  around  by  MCS,
VMDDT,  and  the page fault handler when it reduces core after a sort.
The page fault handler is not affected too  much,  however,  since  it
will be brought in again if totally wiped out.

4.  SORT and COBOL overlays do not always work together correctly.
SRT4C.DOC                                                       Page 5


4.0  INSTALLATION INSTRUCTIONS


4.1  Contents of the SORT Distribution Tape.

For details of the combined COBOL/SORT tape see COBOL.INS.

The SORT distribution tape is written in BACKUP INTERCHANGE format and
contains the complete SORT/MERGE system.  There are five save sets.

The save sets are:


1.  SORT-DOCUMENTATION

2.  SORT-SOURCE

3.  SORT-KL-BUILD

4.  SORT-KI-BUILD

5.  SORT-KA-BUILD

The SORT-DOCUMENTATION save set contains the following files:

         SORT.SD    -- directory of SORT-SOURCE save set
         SORT.KLD   -- directory of SORT-KL-BUILD save set
         SORT.KID   -- directory of SORT-KI-BUILD save set
         SORT.KAD   -- directory of SORT-KA-BUILD save set
         SORT.HLP   -- the HELP file for SORT
         SRT4C.BWR  -- the Beware file for SORT 4C
         SRT4C.DOC  -- the Doc file for SORT 4C

The SORT-SOURCE save set contains all the  source  files  required  to
build SORT.

The SORT-K*-BUILD save set contains the Rel, Log, UNV files etc.  from
the final build.
SRT4C.DOC                                                       Page 6


4.2  Instructions for Loading and Installing SORT

Mount the SORT or COBOL/SORT tape  on  logical  MTA0:   and  type  the
following commands:

R BACKUP
TAPE MTA0:
REWIND
DENSITY 1600-BPI
RESTORE SORT.HLP
REWIND
SKIP 2   !FOR KL-10
SKIP 3   !FOR KI-10
SKIP 4   !FOR KA-10
RESTORE SORT.EXE
REWIND

Then copy SORT.EXE to SYS:  (or NEW:) and SORT.HLP to HLP:.


4.3  Instructions for Building SORT

Full building instructions for SORT can be found in SORT.CTL.

To simplify the build process all logical  names  required  have  been
placed  in  a file.  If MIC were supported and worked under BATCH then
they would be in a MIC file SORT.MIC.  However, this is  not  true  so
that  they  are in a file called SORT.TEC.  If BLDSRT.CTL is SUBMITTED
and the file SORT.TEC exists then BLDSRT runs TECO to modify  SORT.CTL
by  the  contents  of  SORT.TEC to produce a new control file SORT.CTM
which it then SUBMITs, otherwise it just SUBMITs SORT.CTL.   The  user
should examine the file SORT.TEC and make appropriate changes.

To generate stand-alone SORT, load all of the SORT-SOURCE save set and
SORT.CTL and SORT.CMD from the appropriate SORT-K*-BUILD save set into
your directory, modify SORT.TEC and type:

     SUBMIT BLDSRT

If LIBOL.REL, FTDEFS.UNV and  METUNV.UNV  are  in  your  directory,  a
COBOL-68 SORT will be built and inserted into LIBOL.REL.

If C74LIB.REL, FTDEFS.UNV and METUNV.UNV  are  in  your  directory,  a
COBOL-74 SORT will be built and inserted into C74LIB.REL.

If FORLIB.REL is in your directory, a FORTRAN SORT will be  built  and
inserted into FORLIB.REL.

To build only a COBOL-68 SORT type:

     SUBMIT SORT/TIME:0:20:00/TAG:COBOL


To build only a COBOL-74 SORT type:
SRT4C.DOC                                                       Page 7


     SUBMIT SORT/TIME:0:20:00/TAG:CBL74


To build only a FORTRAN SORT type:

     SUBMIT SORT/TIME:0:20:00/TAG:FORTRA


To build only a Virtual memory FORTRAN SORT type:

     SUBMIT SORT/TIME:0:20:00/TAG:FSORT

The following table contains  the  assembly  switches,  their  default
value, location and intended use.

  Assembly   Default  Defined    Use when Switch has
  Switch     Value    in module  a non-zero value
  ------------------------------------------------------------------
  FTOPS20    0        SRTPRM     Build SORT for a DECSYSTEM-20
  FTKL10     0        SRTPRM     Use KL instructions (BIS etc.)
  FTKI10     0        SRTPRM     Use KI instructions (DMOVE etc.)
  FTDEBUG    0        SRTPRM     Debugging aids and additional info
  FTCOBOL    1        SRTCBL     Build SORT for COBOL
  FTFORTRAN  0        SRTCBL     Building COBOL, so turn off FORTRAN
  FTFORTRAN  1        SRTFOR     Build SORT for FORTRAN
  FTCOBOL    0        SRTFOR     Building FORTRAN, so turn off COBOL
  FTVM       0        SRTPRM     Build  a  Virtual  Memory  SORT   for
  FORTRAN
SRT4C.DOC                                                       Page 8


5.0  INTERNAL CHANGES

The sources of SORT consist of:

SRTVER.MAC  An optional file containing feature test switch settings.
SRTPRM.MAC  The common parameter definitions
SRTSTA.MAC  The common stand-alone code
SRTSCN.MAC  The interface to SCAN
SRTUUO.MAC  DECsystem-10 specific code
SRTCMP.MAC  The comparison generator
SRTFLT.MAC  The floating point code
SORT.MAC    The common algorithms

In addition the COBOL SORT has:
SRTCBL.MAC  The interface for COBOL

and the FORTRAN SORT has:
SRTCER.MAC  Standard error message routines.
SRTFOR.MAC  The non-V/M FORTRAN interface.
FORSRT.MAC  The FORTRAN interface to the V/M FSORT.


Several changes have been made to SORT to  take  advantage  of  future
releases   of   the   operating   systems.   Although  SORT  will  run
successfully with all currently  supported  operating  systems,  these
changes  may  have  some  slight  impact on performance and size.  The
largest change is edit [C20] which  will  make  it  possible  for  the
stand-alone and FORTRAN SORT to run in a non-zero section with Release
5 of TOPS-20.  This change was mostly to clean up  the  left  half  of
index  registers,  however  it is a rather large patch.  Other changes
were to TOPS-10 specific code to take advantage of  extended  channels
in 7.01, and big disk buffers in 7.02.


The following edits were made to SORT as a result of bugs found:

436  Official edit number for edit CCC of version 4B.

437  Fix TOPS-20 bug with SIXBIT unblocked files,  SRTJFO  and  SRTCCF
     errors.

440  Fix fixed EBCDIC with odd number of bytes in file.

441  Fix reformatted buffer pool memory allocation.

442  Fix problem with EBCDIC record descriptor word corruption.

443  Eliminate  sequence  number  overflow   warning   (%SRTSNO)   and
     associated instability.

444 Fix a TOPS-20 bug in which SOUT garbages output containing nulls.

445 Fix a TOPS-10 bug caused by not clearing .RBALC in ENTER block.

446 Fix a bug which garbaged COMP-3 key extraction.
SRT4C.DOC                                                       Page 9


447 Fix the /NOCREATE bit in TOPS-10 GENSTR routine.

450 Allow explicit ALPHANUMERIC keys with EBCDIC.

451 Not required in SORT 4C (part of edit C18).

452 Not required in SORT 4C.

453 Make TOPS-20 HELP command look in HLP:  instead of SYS:.

454 On TOPS-20 don't clear MRGSW (in CLRANS) after setting it.

455 Save T4 in ERRRTI (see also C28).

456 Not required in SORT 4C.

457 Allow TOPS-20 SORT to CONTINUE  after  "?QUOTA  EXCEEDED  OR  DISK
     FULL" message.

460 Build the collating table (COLBUF) correctly for SIXBIT files when
     the user specifies his own collating sequence.

461 Correct the calculation of MINKEY when there are extracted keys.

462 First character of a collating sequence specified  in  a  file  is
     lost.

463 On TOPS-20 close the TAKE and LOG files when SORT exits if a  TAKE
     file was being processed.

464 On TOPS-20 fix edit 457 to put out "$" before  the  error  message
     for batch.
         Also fix the continue after PMAP failure so  that  pages  are
     not lost.

465 On TOPS-20 fix the calculation of the number of bytes  written  to
     the output file.

466 Not required in SORT 4C.

467 Allow the space character to be specified using the quote facility
     in an alternate collating sequence file.

C01  The magnetic tape switches /PARITY, /DENSITY, and /INDUSTRY  were
     scanned,  but  never  used  on  TOPS-20.   This meant that EBCDIC
     magnetic tapes were not read or written in a way compatible  with
     COBOL.   Changes  were made to SORT-10/20 to utilize these switch
     values in a similar manner to the /REWIND and /UNLOAD switches.

C02  The fastest (least CPU and elapsed time) technique for doing  I/O
     to  magnetic  tapes  on  TOPS-20  is  the DUMPI/DUMPO JSYS's.  To
     properly use these JSYS's, double buffered, non-blocking  I/O  is
     required.   This  is  more complicated than the normal SINR/SOUTR
     JSYS's, because it is the responsibility on the user  program  to
     keep  track  of  which buffer is being filled and which buffer is
SRT4C.DOC                                                      Page 10


     being emptied.  SORT-20 was not doing this properly.

C03  The processing of End-Of-File on magnetic tape was not being done
     correctly.   On  input,  the  last  block  was  causing errors on
     TOPS-20, and on output, the last block contained junk at the  end
     for both TOPS-10 and TOPS-20.

C04  File names typed in lower case were not being converted to SIXBIT
     magnetic tape labels properly.

C05  Since magnetic tape buffers are often larger than a  page,  under
     certain  conditions  when  SORT-20  went to open the output file,
     there was not enough room left.  The  default  MEMORY  allocation
     subroutines were corrected for this oversight.

C06  Many problems existed with magnetic tape blocking factors:
     EBCDIC requires an 8-bit byte on magnetic tape and a  9-bit  byte
     everywhere else.  SORT-20 was just totally ignoring this fact.
     The record and block header words for variable length EBCDIC were
     not taken into account when calculating block sizes.
     The test to suppress padding between blocks for the  first  block
     was faulty.
     Various other small bugs existed in these areas.

C07  The code to deal with magnetic tape  End-Of-Tape  processing  did
     not  work  under  all  circumstances.   Also, when reading back a
     multi-tape file, the  reel  numbers  were  not  checked  properly
     causing erroneous error messages.

C08  The code to deal with labeling of magnetic  tapes  did  not  work
     except  under  rare  situations  on TOPS-20.  There were numerous
     problems:
     Dumping the last buffer, writing EOF marks, writing  labels,  and
     closing the files were not accomplished in the correct order.
     The code to deal with short buffers did not work at all.
     Also, when a EOF is read or written, the DUMPI/DUMPO  JSYS's  are
     re-synchronized   with   the   buffers.   This  was  not  handled
     correctly.

C09  Since COBOL defaults /BLOCKED:1 and /INDUSTRY for EBCDIC magnetic
     tapes, SORT-10/20 needed this feature also.

C10  SORT-20 sometimes created a TAKE command log file  and  sometimes
     did  not,  when  no log file specification was made.  SORT-20 was
     corrected to never write a TAKE command log file  unless  one  is
     explicitly requested.

C11  To allow merges on multiple files from a single magnetic tape,  a
     /POSITION  switch  was  implemented.   The /REWIND switch used in
     conjunction with the /POSITION switch allows  for  absolute  file
     addressing.

C12  Since magnetic tape auto-labeling  was  comming  to  TOPS-20  (in
     Release  4),  support  for  this  new  TOPS-20  feature  would be
     required.  SORT-10 already supported auto-labeled magnetic tapes.
SRT4C.DOC                                                      Page 11


     However, there are three levels of auto-labeling on TOPS-20:
     A system without auto-labeling
     An unlabeled tape on an auto-labeling system
     A labeled tape on an auto-labeling system.

C13  FOROTS version 6 will be released in the near future.   This  new
     version of FOROTS works significantly differently from version 5.
     The stand-alone version of  SORT-10/20  merged  FOROTS  into  its
     memory  and used FOROTS for floating point number interpretation.
     This tied SORT and FORTRAN  together.   However,  the  techniques
     used to initialize FOROTS will no longer work for the new version
     of FOROTS.  Furthermore, when  SORT  is  called  from  a  FORTRAN
     program, SORT-10/20 uses the FOROTS memory management subroutines
     to allocate and deallocate memory.   These  subroutines  allocate
     memory  in  a very different manner in the new version of FOROTS.
     FOROTS used to allocate new memory at .JBFF.  This meant  that  a
     block  of  memory allocated by FOROTS could be expanded if no new
     memory was allocated after it.  However, in the  new  version  of
     FOROTS,  memory  is  allocated  just  below  the  high segment of
     FOROTS.  The last block of memory  can  no  longer  be  expanded.
     These  major  revisions  to  FOROTS  require  major  revisions to
     SORT-10/20.
     First, the FLIRT subroutine in FOROTS which  interprets  floating
     point  numbers  was  rewritten  to  become  part  of  SORT-10/20.
     Second,  many  changes  were  made  to  redesign  SORT's   memory
     management.   This redesign cleaned up many potential problems in
     SORT-10/20.  The following restrictions were strictly adhered to.
     All  memory management is done by two routines.  No references to
     the Job Data Area are allowed except for  defaulting  the  memory
     usage  in  the  standalone  versions  of  SORT-10/20 and in these
     memory management subroutines.  FOROTS and LIBOL  are  called  by
     these  memory  management  subroutines  for the FORTRAN and COBOL
     versions of SORT-10/20.

C14  In the past  MACRO-10/20  had  been  unable  to  handle  negative
     relocations  properly.   To  circumvent this problem, inefficient
     code was written in SORT-10.  Since  this  restriction  was  been
     eliminated in MACRO, the code in SORT-10 was corrected.

C15  The code in SORT-10 used to determine which structures should  be
     used  by  default  for  temporary  files  did  not work properly.
     SORT-10  attempted  to  used   write-locked   and   create-locked
     structures.

C16  In SORT-20 the ALPHANUMERIC key modifier  for  EBCDIC  was  being
     rejected, even though, if no modifier was specified, ALPHANUMERIC
     was assumed.

C17  Blocked DSK files were  hastily  added  to  SORT-20.   The  logic
     behind  the  code  had  many  holes.   This  code  needed  to  be
     rewritten.

C18  In version 7.02 of TOPS-10 a new feature  is  being  added  which
     will  allow  disk  buffers  to  be  larger  than  one disk block.
     Initial tests indicate that SORT-10 can  be  made  to  run  in  a
SRT4C.DOC                                                      Page 12


     smaller elapsed time if this new feature is utilized.

C19  TOPS-10 7.01 allows a user program  to  have  more  than  16  I/O
     channels,  however  they can only be used by the FILOP.  UUO.  As
     much code as possible is being converted now  to  use  the  6.03A
     supported  functions.   The  release of SORT-10 after 6.03A is no
     longer  supported  will  use  26  extended   channels   for   the
     intermediate files.  This should improve COBOL SORT time and free
     some channels for the COBOL program.

C20 Clean up code to allow SORT to run in a non-zero memory section in
     the future.

C21 Fix memory reallocation bug in SORT-10.

C22 Fix problem  with  unlabeled  magnetic  tapes  through  MOUNTR  in
     SORT-20.

C23 Fix problem with determining high segment size in SORT-10.

C24 Fix problem with Physical Limit 0 in SORT-10.

C25 Add Support for new PULSAR label types in SORT-10.

C26 Fix bug concerning .TMP files and no UFDs in SORT-10.

C27 Renamed to edit 444.

C28 Fix record truncation on input destroying ACs.

C29 Fix default memory for SORT-10 on KI's and KL's

N01 Some minor code bumming.

N02 Give error message if not enought input files for MERGE.

N03 Change the .LINK pseudo-op number to avoid conflict with  COBOL-74
     /R.

N04 Fix COBOL SORT on KA-10 to assemble correctly again.

N05 Give file  not  found  message  as  early  as  possible  to  avoid
     unnecessary memory expansion.

N06 Reset CORSTK if an error occurs in SCAN (TOPS-10 only).

N07 Fix edit C29 to work for COBOL SORT (TOPS-10 only).

N08 More fixes to DEFCOR to account for VMDDT and V/M limits  (TOPS-10
     only).

N09 Fix calculation of number of temp  files  on  TOPS-10.   This  was
     wrong if an internal merge was required.

N10 Delete FTCOL feature test switch, the code is always generated.
SRT4C.DOC                                                      Page 13


N11 Add switches NOCRLF, AFTER, and BEFORE.

N12 If TOPS-10 7-series monitor use FILOP.s for all I/O operations.

N13 On TOPS-20 don't turn on page creation interupt if RMS  turned  it
     off.

N14 On TOPS-10 bypass protection check if job is [1,2] or JACCT.

N15 Fix read from NUL:  device on TOPS-20.

N16 Fix bug with very large keys using more than FTEXSX space.

N17 Use extended channels if TOPS-10 7.01.

N18 Fix bad sort for SIXBIT key /K:n:3 where n is a multiple of 6.

N19 Return /ERROR-CODE in 3 ASCII  characters  rather  than  6  SIXBIT
     ones.

N20 On TOPS-10 increase  number  of  temp  files  to  26  if  extended
     channels available.

N21 On TOPS-10 put segmentation back the way  it  was,  put  new  code
     under FTVM conditional.

N22 On TOPS-10 fix default core allocation "off by  one"  bug  causing
     not enough core error.

N23 Make SORT with double precision COMP keys work again.

N24 Make FILOP.  DELETE work in  both  7.01  and  7.02  (problem  with
     FO.UOC bit).

N25 Allow either " or  '  to  delimit  quoted  characters  in  literal
     collating sequence.

N26 On TOPS-20 fix bug with multiple input files on magtape.

N27 Fix memory allocation in SORT for very large FORTRAN programs.



The following edits were mode to FORSRT.MAC:

  5 Clean up code to allow SORT to run in a non-zero memory section on
     TOPS20.

  6 More non-zero section code for TOPS-20.



6.0  SUGGESTIONS
SRT4C.DOC                                                      Page 14


None.



[End of SRT4C.DOC]