Digital Research
This commit is contained in:
2020-11-06 18:50:37 +01:00
parent 621ed8ccaf
commit 31738079c4
8481 changed files with 1888323 additions and 0 deletions

View File

@@ -0,0 +1,239 @@
.title ^^CP/M-68K Cross Software for VMS
.nofill
.bl 4
.c
CP/M-68K Cross Software for VMS
.c
-------------------------------
.bl 2
.c
Revision 01.04
.c
--------------
.bl 2
.c
August 28, 1983
.c
---------------
.bl 12
.c
Digital Research, Inc
.c
P.O. Box 579
.c
Pacific Grove, CA 93950
.c
(408) 649-3896
.c
TWX 910 360 5001
.bl 4
.c
************************
.c
* Company Confidential *
.c
************************
.bl 4
.fill
Note: This document contains Digital Research proprietary information, and
must not be copied or distributed for any purpose whatsoever, without prior
written permission of Digital Research, Inc.
.bl 2
Address Comments to: Steve Williams, x6082
.subtitle Introduction
.page
.hl 1 Introduction
.i 5
This document describes the installation and execution procedures for the
Digital Research 68000 cross development software for VAX/VMS. This software
includes the C compiler, assembler, linker, archiver, symbol table print
utility, object module size utility, and S-Record conversion utility. These
tools execute in much the same fashion as they do under CP/M-68K, as
documented in the CP/M-68K Programmer's Guide.
.subtitle Installation Procedures
.hl 1 Installation Procedures
.i 5
The tools are distributed on a 9-track FLX format mag tape (either 800 or
1600 bpi is available). To bring up the software on VMS, perform the
following steps:
.ls
.le;Login to a valid account.
.le;Create directories for four ersatz devices: "bin:" (.exe files), "com:"
(command files), "lib:" (library files), and "cpm:"
(CP/M-68K files).
.le;Enter VMS "ASSIGN" commands for these directories in LOGIN.COM,
e.g:
.bl 1
.nofill
$ assign drb0:[c.bin] bin:
$ assign drb0:[c.com] com:
$ assign drb0:[c.lib] lib:
$ assign drb0:[c.cpm] cpm:
.bl 1
.fill
Note that the full path name must be specified.
.le;Perform the above assignments manually, re-login or re-execute LOGIN.COM
to make the device names valid.
.le;Read the tape as follows:
.bl 1
.nofill
$ allocate mt:
$ mount mt:/foreign
$ set def lib:
$ mcr flx /rs=mt:[1,1]*.*/do/im
$ mcr flx /rs=mt:[1,2]*.*/do
$ set def bin:
$ mcr flx /rs=mt:[1,3]*.*/do
$ set def cpm:
$ mcr flx /rs=mt:[1,4]*.*/do/im
$ mcr flx /rs=mt:[1,5]*.*/do
$ set def com:
$ mcr flx /rs=mt:[1,6]*.*/do
$ _@install
$ dismount mt:
$ deallocate mt:
.fill
.bl 1
You may need to replace the "mt:" device name above with a different device
name, depending on the type of tape drive you have. Consult your system
administrator for details.
.le;Add the statements in the file "xlogin.com" to LOGIN.COM so that the
proper command definitions are performed at login time.
.els
Once the above steps have been performed, the software is ready to use on
VMS.
.subtitle Operating Instructions
.hl 1 Operating Instructions
.i 5
The following sections describe how to run the installed cross software on
VMS.
.hl 2 C compilation
.i 5
A C compilation is performed using the 'c68' command as follows:
.bl 1
.i 8
$ c68 file
.bl 1
The ".c" extension is implied and must not be specified. The 'c68' command
is extremely similar to the 'C' SUBMIT file on CP/M-68K.
Default floating point format is Motorola FFP using the "c68" command.
The "ce68" command causes the compiler to use IEEE format floating point
numbers.
.hl 2 Assembly
.i 5
The assembler is invoked in exactly the same manner as on CP/M-68K. The
output (listing and errors) can be redirected to a file or device using the
">filename" construct. A sample command is:
.bl 1
.i 8
$ as68 -l -u -p file.s >file.lis
.bl 1
This command assembles "file.s" and places the object in "file.o". The
listing is output to "file.lis". All assembler options valid under CP/M-68K
may be used on VMS as well.
.hl 2 Linking
.i 5
The LO68 program is used with the same options and command line syntax as on
CP/M-68K. For example,
.bl 1
.i 5
$ lo68 -r -o file.rel file1.o file2.o
.bl 1
links "file1.o" with "file2.o", creating "file.rel", a relocatable format
file.
.bl 1
.i 5
C programs are linked using the "clink" command, as with CP/M-68K:
.bl 1
.i 5
$ clink file1
.bl 1
This links "file1.o" with the C runtime software to produce "file1.rel", a
relocatable format 68000 load module.
Separately compiled modules may be linked in the following way:
.bl 1
.i 5
$ clink file1 file2 file3 file4 ...
.bl 1
All of the object files are linked to produce "file1.rel". A limit of 9 such
files is imposed by the command file.
.bl 1
.i 5
The "clink" command procedure assumes that the program being linked does not
use floating point. To link a program using FFP floating point, use
"clinkf" instead of "clink". IEEE floating point programs (those compiled
with the "ce68" command) are linked using "clinke".
.hl 2 Archive Files
.i 5
The CP/M-68K archive program (AR68) can be used under VMS exactly in the same
fashion as under CP/M-68K. For example, to create a library file:
.bl 1
.i 8
$ ar68 r lib a.o b.o c.o
.bl 1
This command creates a library called "lib" containing the three files "a.o",
"b.o", and "c.o".
.subtitle Building CP/M-68K
.hl 1 Building CP/M-68K
.i 5
Using the VAX cross tools to build CP/M-68K is similar to building the
operating system on CP/M. You link the BIOS with CPMLIB to produce a
relocatable image file (CPM.REL). Use the RELOC utility to create the
absolute load image (CPM.SYS). The CP/M-68K SUBMIT files "LCPM.SUB" and
"RELCPM.SUB" have been adapted to VMS procedure files to make this process
easier.
.bl 1
.i 5
For example, to create the EXORmacs distribution system, use the following
sequence of commands:
.bl 1
.nofill
.lm +8
$ set def cpm:
$ _@normbios !Create "bios.o"
$ _@lcpm !Create "cpm.rel"
$ _@relcpm 15000 !Create CPM.SYS at 15000 hex.
.lm -8
.fill
.bl 1
The boot loader for CP/M-68K is generated in a similar fashion, as documented
in the CP/M-68K System Guide.
.subtitle File Transfer Techniques
.hl 1 File Transfer Techniques
.hl 2 S-records
.i 5
The normal method of transferring files to a 68000 target is via Motorola
S-records. The SENDC68 program converts a load module file from binary format
to S-record format. The command syntax for this program is:
.bl 1
.i 8
SENDC68 [-] file.68k >file.sr
.bl 1
Where "file.68k" is an absolute format CP/M-68K load module, and "file.sr"
is the created S-record file. This form of the load module may be created
using the linker "-t" switch or the reloc utility. The RELCPM command used
in the CP/M-68K generation procedure generates an absolute file.
The "-" option specifies that S-records are
not to be created for the ".bss" segment. The default is to create S-records
that zero all locations in the ".bss".
.bl 1
.i 5
The resulting S-record file may be downloaded via the VMS "TYPE" command into
a target system with a PROM debugger, such as the MACSbug program on the
EXORmacs.
.hl 2 Other Transfer Techniques
.i 5
Other techniques such as binary download utilities or CP/M file transfer
utilities may be used to transfer CP/M-68K load modules to the 68000 target.
When such a technique is used, the bytes in the file must be swapped, and
the words of all longword quantities in the load module header must be
swapped. Library modules may not be transferred using this technique without
extensive rearrangement of the headers. The symbol table in object and
load module files will have the symbol names byte swapped in this type of
transfer.
.hl 1 Trademarks
.i 5
VAX, VMS, and FLX are trademarks of Digital Equipment Corporation. EXORmacs,
and MACSbug are trademarks of Motorola, Inc. CP/M-68K is a trademark of
Digital Research, Inc.