.rm 72 .c;Kermit-11 for RSTS, RSX11M/M Plus, RT11, P/OS and PRO/RT11 .s 2 11-Mar-85 13:31:17 Brian Nelson 02-Jun-85 12:50:32 Brian Nelson .s 1 Kermit is a protocal developed at Columbia University which has been used to implement error free packet file transfer and communications between computer systems, both mainframe to mainframe and micro to mainframe. The complete distribution of Kermit includes many CPM and MS-DOS versions and mainframe versions for TOPS-10, TOPS-20, UNIX, VMS, RSX11M/M+ and RSTS/E as well as other vendors systems. Micro versions include the Robin, Rainbow and Professional 350 as well as most other popular micro-computers. .br The complete distribution is available from Columbia University Computer Center in New York, NY. .br This document describes the RSTS/E, RSX11M/M+, RT11, TSX+, P/OS, MicroRSX and RSX11M versions developed by the author, Brian Nelson. .s 2 This is release 2.30 of Kermit-11. It requires RSTS version 7.2 or later, RSX11M v4.0 or later, or RSX11M Plus version 2.0 or later, or RT11 version 4.0 or later, or P/OS version 2.0 or PRO/RT11 version 5.1 .rm 80 .lit Minimum system requirements to assemble and link Kermit RSTS v8.0 or later, with multiple private delimiters and RMS V2 RSX11M v4.1 or later, with full duplex terminal driver and RMS V2 RSX11M+ v2.1 or later, with full duplex terminal driver and RMS V2 RT11 v5.0 or later, with multiple terminal support TSX+ v5.0 PRO/RT v5.1 with mods (see K11PRT.MAC) to the XC handler P/OS v2.0 Minimum system requirements to run Kermit RSTS v7.2 or later, with multiple private delimiters RSX11M v4.0 or later, with full duplex terminal driver RSX11M+ v2.0 or later, with full duplex terminal driver RT11 v4.0 or later, with multiple terminal support PRO/RT v5.1 with mods (see K11PRT.MAC) to the XC handler MicroRSX P/OS v2.0 TSX+ v4 .eli .rm 72 Kermit-11 will run on RSX11M version 4.0 and RSTS/E version 7.2 as long as the task was built without using RMSRES. To be able to build KERMIT on RSTS version 7.2 or RSX version 4.0 you will have to get RMSLIB.OLB and MAC.TSK from RSX v4.1 or RSTS v8.0. The need for version 2 of RMSLIB is due to the use of $SEARCH, $PARSE, $RENAME and $DELETE. The need for the newest MAC.TSK is due to the use of new directives such as _.SAVE, _.RESTORE and _.INCLUDE /filename/. .s 2 For PRO/RT11 version 5.1, please note that you MUST make two modifications to the XC handler. See K11PRT.MAC for more information. .s 1 For RSTS please note that you Do Not have to create RMS files as output. You can instead either type SET RECORD-FORMAT STREAM, modify the default in K11RMS.MAC or put the SET command in one of the following files: .lit SY:KERMIT.INI LB:[1,2]KERMIT.INI SY:[1,2]KERMIT.INI KERMIT:KERMIT.INI .eli .page .rm 72 This version of Kermit supports server mode and full wildcarding for SEND and GET. See the HELP command or the file K11HLP.RNO for further information. .br It also supports the CONNECT command, which can be used to dial out of the system and talk to another Kermit somewhere else, say to a copy of 20KERMIT. The connect command has only been tested with a VADIC 212 autodial modem. Modifications may be needed for the DF03. .page .c;Installation .s 2 RSTS version 7.2 and later .s 2 First, please note that you MUST be running RSTS version 8.0 or later with RMS11 version 2 installed on the system to be able to assemble and link Kermit. If you have version 7.2 you can run the non-resident library version of the task but you will not be able to assemble or link Kermit. In all cases the RSTS executive must have in it the sysgen optional 'multiple private delimiters'. .s 1 If you have gotten a DOS format tape with the task images on it, you can copy either K11.TSK (for use with RMSRES) or K11NRS.TSK (no RMSRES) to the system and skip to the paragraph on the HELP file. Tapes sent out by Columbia will NOT have any task images on them. See the next section on 'HEX' files. If you are running 7.2 you MUST use K11NRS.TSK. .lit PIP $KERMIT<104>/RTS:RSX=MM0:[*,*]K11.TSK PIP $KERMIT<104>/RTS:RSX=MM0:[*,*]K11NRS.TSK .eli .s 1 If you don't have the task images on tape you can compile (with F77) the program called K11HEX.FTN or use the Basic+ version called K11HEX.BAS and create the task image from the so-called 'HEX' file (either K11.HEX or K11NRS.HEX). If you are running 7.2 you MUST use K11NRS.HEX. .lit f77 k11hex=k11hex Ready tkb TKB>k11hex=k11hex,lb:f4pots/lb TKB>/ Enter Options: TKB>maxbuf=512 TKB>// Ready run k11hex Input file ? k11nrs.hex Output file ? kermit.tsk Encode or Decode ? decode all done For RSX, please make the task image contiguous as in PIP [1,54]KERMIT.TSK/CO=KERMIT.TSK For RSTS, make the task contiguous, set the protection to <104> and the rts name to RSX as in PIP [1,2]KERMIT.TSK<104>/MO:16/RTS:RSX=KERMIT.TSK K11HEX -- STOP Ready .eli Now skip to the paragraph on copying the HELP file. .s 2 .page .s 1 If you want to assemble and task build Kermit for RSTS version 8 .s 2 First, it is assumed that MAC.TSK is available via the CCL MAC. The batch control file K11ASM.E80 will assemble Kermit. You will have to edit it to remove the account number references in it. The user logical IN: must be assigned or MAC and TKB will fail. .br Once BATCH has run the control file, you will have in your account the objects for KERMIT. The next step is to task build KERMIT, using either K11.CMD or K11NRS.CMD (the former for RMSRES, the later without RMSRES). These files are TKB command files, they also reference K11.ODL and K11NRS.ODL. .lit TKB @K11 or TKB @K11NRS .eli To be able to use ONLPAT on the task, you must now run the MAKSIL system program to merge the symbol table into the task image. .s 2 The HELP file .s 2 The HELP file can be in one of several locations, Kermit will try to find it. They are: .lit LB:[1,2]K11HLP.HLP SY:[1,2]K11HLP.HLP KERMIT:K11HLP.HLP HELP:K11HLP.HLP .eli Protection .s 2 The Kermit task should have either a <104> protection code or a <234> protection code. If you don not use the <234> the SYSTEM command will not work for users. The HELP file should have a <40> on it. .page .c;Patching the distributed task images for RSTS/E .s 2 .lit ! RSTS/E Kermit optional patches ! ! Brian Nelson 30-Mar-84 09:47:07 ! ! ! Example of patching RSTS/E Kermit to disable commands based ! on user programmer number. The effect of the following ! patches is to disallow any user with a programmer number ! greater than 127 (ie, 100,221) to access the commands ! DELETE ,DIRECTORY, ERASE and RENAME. If you would like to ! do this based on project number instead you can patch ! either ...UIC+0 to be the high cutoff point instead of ! patching ...UIC+2, or you can use different project numbers ! for each command by changing the '377' (which is in octal) ! to the desired cutoff point. To restict access to the DIR ! command to users with a project (group) number less than ! (10,*), you would patch ..$DIR byte offset zero from 0 to ! 10. (the '.' is needed to force ONLPAT to use a decimal ! interpretation of the number. ! ! One thing of interest is that you can patch Kermit-11 so it ! will force speeds of 2400 baud or greater to be equivalent ! to 2400 baud. This is enabled by patching SLOWDO offset zero ! to a one. ! ! At this time the only other thing you may want to patch is ! location ..DIRP offset zero, which is by default 1. This ! value is checked against the user's project number by the ! DIRECTORY command. If the user's project number is greater ! than this number, the ppn (uic) field for the DIR command ! is zeroed, thus preventing that user from looking at the ! directory listing of ANY other account. The default is to ! restrict the use of ppn's for this command to [1,*] users ! only. The last patch here changes that to include [2,*]. ! ! ! Please note that you can ALWAYS edit K11LCL.MAC to get the ! same thing as applying these patches. ! ! ! Keep users with prog numbers > 127 from using DIR, DEL, REN and ERA. ! ! File to patch? Base address? ...UIC+2 Offset address? 0 Base Offset Old New? ?????? 000000 000000 ? 127. ?????? 000002 041000 ? ^Z Offset address? ^Z Base address? ..$DEL Offset address? -1 Base Offset Old New? ?????? 177777 120 ? ?????? 000000 000 ? 377 ?????? 000001 104 ? ^Z Offset address? ^Z Base address? ..$DIR Offset address? -1 Base Offset Old New? ?????? 177777 114 ? ?????? 000000 000 ? 377 ?????? 000001 104 ? ^Z Offset address? ^Z Base address? ..$ERA Offset address? -1 Base Offset Old New? ?????? 177777 123 ? ?????? 000000 000 ? 377 ?????? 000001 105 ? ^Z Offset address? ^Z Base address? ..$REN Offset address? -1 Base Offset Old New? ?????? 177777 115 ? ?????? 000000 000 ? 377 ?????? 000001 122 ? ^Z Offset address? ^Z Base address? ..DIRP Offset address? 0 Base Offset Old New? ?????? 000000 000001 ? 2 ?????? 000002 ?????? ? ^C .eli .page .s 1 RSX11M/M+ .s 2 If you have gotten a tape with the task images on it, you can copy K11RSX.TSK (no RMSRES) to the system and skip to the paragraph on the HELP file. .s 1 Tapes sent by Columbia will have a so-called 'HEX' file called K11RSX.HEX which is fed into the program K11HEX to create the RSX task image as follows: .lit >f77 k11hex=k11hex >tkb TKB>k11hex=k11hex,lb:[1,1]f4pots/lb TKB>/ Enter Options: TKB>maxbuf=512 TKB>// >run k11hex Input file ? k11rsx.hex Output file ? kermit.tsk Encode or Decode ? decode all done For RSX, please make the task image contiguous as in PIP [1,54]KERMIT.TSK/CO=KERMIT.TSK INS $KERMIT/TASK=...KER For RSTS, make the task contiguous, set the protection to <104> and the rts name to RSX as in PIP [1,2]KERMIT.TSK<104>/MO:16/RTS:RSX=KERMIT.TSK K11HEX -- STOP > .eli .s 2 Assembling Kermit .s 2 First, it is assumed that MAC and TKB are installed. The command file K11ASM.M41 will assemble Kermit. The user logical IN: must be assigned or MAC and TKB will fail. .lit as in: @K11ASM.M41 .eli You then task build KERMIT. The files K11RSX.CMD and K11RSX.ODL will build Kermit without RMSRES. They both have comments to show what to do to use RMSRES. .lit as in: TKB @K11RSX .eli .s 2 The HELP file .s 2 The HELP file can be in one of several locations, Kermit will try to find it. They are: .lit LB:[1,2]K11HLP.HLP SY:[1,2]K11HLP.HLP KERMIT:K11HLP.HLP HELP:K11HLP.HLP .eli .page RT11 and TSX+ (excluding the PRO/350) .s 2 This version of Kermit will run on RT11 version 4.0 or later as long as the executive has multiple terminal support generated. The use of this feature enables the user to access DZ11's as well as DL11's. If you are using XM then you should use K11XM, otherwise use K11RT4. Also, note that for version 5 systems, you can use the XL: handler. In fact, the use of the XL: handler is the only way on TSX+ to dial out of your system. This is done by giving Kermit-11 the command SET LIN XL:, assuming that the needed KMON/DCL commands have already been used to set the CSR, vector and, if applicable, the speed. On RT11, use of the XL: handler will speed file transfers up. See HELP RT11 and HELP TSX+ on Kermit. .s 2 Installation: .s 1 If the distribution has the save image K11RT4.SAV or K11XM.SAV on it, you simple copy them with the HELP file to the system volume and are ready to go. All modules linked into K11RT4.SAV and K11XM.SAV have been assembled with a prefix file called K11NHD.MAC which defines macros to simulate SOB, ASH, XOR, MUL and DIV. Thus NO eis hardware is required. It has been tested extensively on a PDT150, which does not support EIS instructions. .s 1 If the distribution does not contain the save image, you need the files K11RT4.HEX and K11HEX.FTN to generate the save image from the 'hex' file. K11HEX.FTN is a fortran program and must be compiled and linked. When this has been done, run it, setting the file K11RT4.HEX or K11XM.HEX for the input file, KERMIT.SAV for the output file and DECODE for the function. If you lack a Fortran compiler, the same thing can be done on a RSTS/E or RSX11M/M+ host and then transfered via FIT or FLX respectively to a RT11 device. .br The file K11XM.SAV is used for TSX+ with virtual overlays. Kermit-11 will determine at run time if it is running on TSX+ or RT11. To dial out from the TSX+ system, you would do s SET LINE XL: to access an external modem. See HELP TSX+ for further information. .br As of version 2.23, there is a K11HEX.MAC program. See the notes for installation for the PRO/350 on using it. .page PRO/RT11 .s 2 Transfer the file K11XM.HEX with VTCOM to the PRO/350. Also transfer the files K11HEX.MAC and K11HLP.HLP. Assemble and link K11HEX.MAC as in MACRO K11HEX and LINK K11HEX. Run K11HEX and supply it with the command line KERMIT=K11RT4 or KERMIT=K11XM, and the Kermit-11 save image will be created. Please see the comments in K11PRT.MAC for information regarding modifying the XC handler for use with Kermit. .page P/OS and MicroRSX .s 2 No provision is made for loading Kermit-11 under P/OS. You will have to use either the STEVENS PRO/KERMIT or Bob Denny's PRO Kermit to load the task image onto the PRO/350 if you lack a copy on an RX50. There is a HEX file, called K11POS.HEX, which can be run though K11HEX.FTN (or .BAS for RSTS/E w/o F77) to recreate the task image if you don't have the task image. I use the Kermit-11 version for P/OS for several reasons, mainly since I normally never leave DCL and also to take advantage of the attribute packet processing that Kermit-11 supports. It makes transfering task images and other files much simpler. Kermit-11 on MicroRSX will use the same task image, K11POS.TSK, so that it can access named directories properly. .page .c;Directory .s 2 .lit Name .Typ Size Prot Date DB1:[4,2] K11AAA.AAA 8 < 60> 04-Apr-84 K11HEX.BAS 6 < 60> 06-Apr-84 K11 .CMD 1 < 60> 30-Mar-84 K11NRS.CMD 1 < 60> 30-Mar-84 K11POS.CMD 1 < 60> 16-Aug-84 K11RSX.CMD 1 < 60> 26-Jun-84 K11XM.COM 1 < 60> 23-Oct-84 K11RT4.COM 1 < 60> 23-Oct-84 K11 .CTL 1 < 60> 23-Mar-84 K11FIL.DOC 7 < 60> 25-Jul-84 K11INS.DOC 33 < 60> 30-Oct-84 K11ASM.E80 2 < 60> 22-Oct-84 K11DAP.E80 5 < 40> 19-Mar-83 K11HEX.FTN 8 < 60> 16-Apr-84 K11HLP.HLP 102 < 60> 30-Oct-84 K11ATR.MAC 24 < 60> 22-Oct-84 K11CDF.MAC 4 < 60> 22-Oct-84 K11CMD.MAC 83 < 60> 25-Oct-84 K11CM1.MAC 9 < 60> 22-Oct-84 K11COM.MAC 13 < 60> 25-Oct-84 K11CON.MAC 38 < 60> 26-Oct-84 K11CPY.MAC 19 < 60> 22-Oct-84 K11CVT.MAC 18 < 60> 30-Oct-84 K11DAT.MAC 10 < 60> 29-Oct-84 K11DEB.MAC 16 < 60> 25-Oct-84 K11DEF.MAC 5 < 60> 22-Oct-84 K11DER.MAC 16 < 60> 22-Oct-84 K11DFH.MAC 6 < 60> 22-Oct-84 K11ERR.MAC 4 < 60> 22-Oct-84 K11ER1.MAC 9 < 60> 22-Oct-84 K11ER2.MAC 9 < 60> 22-Oct-84 K11ER3.MAC 9 < 60> 22-Oct-84 K11E80.MAC 87 < 60> 25-Oct-84 K11HEX.MAC 9 < 60> 25-Oct-84 K11HLP.MAC 21 < 60> 22-Oct-84 K11INI.MAC 32 < 60> 26-Oct-84 K11LCL.MAC 17 < 60> 22-Oct-84 K11MAC.MAC 20 < 60> 22-Oct-84 K11M41.MAC 81 < 60> 25-Oct-84 K11NHD.MAC 4 < 60> 22-Oct-84 K11PAK.MAC 95 < 60> 25-Oct-84 K11PK .MAC 73 < 60> 22-Oct-84 K11PRT.MAC 31 < 60> 30-Oct-84 K11REC.MAC 34 < 60> 24-Oct-84 K11RMS.MAC 99 < 60> 22-Oct-84 K11RTC.MAC 38 < 60> 26-Oct-84 K11RTD.MAC 37 < 60> 22-Oct-84 K11RTE.MAC 10 < 60> 22-Oct-84 K11RTT.MAC 33 < 60> 25-Oct-84 K11RTU.MAC 23 < 60> 22-Oct-84 K11RT4.MAC 56 < 60> 22-Oct-84 K11SEN.MAC 35 < 60> 26-Oct-84 K11SER.MAC 46 < 60> 25-Oct-84 K11SHO.MAC 21 < 60> 22-Oct-84 K11ST0.MAC 21 < 60> 22-Oct-84 K11ST1.MAC 24 < 60> 29-Oct-84 K11SUB.MAC 35 < 60> 22-Oct-84 K11TRA.MAC 7 < 60> 22-Oct-84 K1180S.MAC 33 < 60> 22-Oct-84 K11XM.MAP 25 < 60> 30-Oct-84 K11RT4.MAP 25 < 60> 30-Oct-84 K11ASM.M41 2 < 60> 15-Oct-84 K11DAP.M41 4 < 60> 18-Mar-84 K11 .ODL 3 < 60> 23-Oct-84 K11NRS.ODL 3 < 60> 23-Oct-84 K11POS.ODL 3 < 60> 23-Oct-84 K11RSX.ODL 3 < 60> 26-Oct-84 K11XM.OLD 33 < 60> 29-Oct-84 K11TOL.PAT 6 < 40> 26-Jun-84 K11ART.RNO 20 < 60> 07-Aug-84 K11HLP.RNO 97 < 60> 30-Oct-84 K11INS.RNO 30 < 60> 30-Oct-84 K11ASM.RT4 3 < 60> 22-Oct-84 K11GLA.XRF 8 < 60> 23-Oct-84 K11GLD.XRF 47 < 60> 23-Oct-84 K11 .HEX 420 < 60> 30-Oct-84 K11RSX.HEX 539 < 60> 30-Oct-84 K11POS.HEX 363 < 60> 30-Oct-84 K11NRS.HEX 724 < 60> 30-Oct-84 K11RT4.HEX 288 < 60> 30-Oct-84 K11XM.HEX 286 < 60> 30-Oct-84 Total of 4424 blocks in 81 files in DB1:[4,2] Name .Typ Size Prot Date DB1:[4,3] K11 .TSK 184 <104> 30-Oct-84 K11NRS.TSK 317 <104> 30-Oct-84 K11POS.TSK 159 <124> 30-Oct-84 K11RSX.TSK 236 <124> 30-Oct-84 K11XM.SAV 125 <124> 30-Oct-84 K11RT4.SAV 126 <124> 30-Oct-84 Total of 1147 blocks in 6 files in DB1:[4,3] .eli