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,16 @@
#define ARMAG "!<arch>\n"
#define SARMAG 8
#define ARFMAG "`\n"
struct ar_hdr {
char ar_name[16];
char ar_date[12];
char ar_uid[6];
char ar_gid[6];
char ar_mode[8];
char ar_size[10];
char ar_fmag[2];
};
#include <stdio.h>
#include <klib.h>

View File

@@ -0,0 +1,754 @@
/*
Copyright 1981
Alcyon Corporation
8474 Commerce Av.
San Diego, Ca. 92121
*/
#include <stdio.h>
#include <klib.h>
#include "machine.h"
#include "iobuf.h"
#include "cout.h"
#define BLKSIZE 512
char buff[BLKSIZE]={0};
/* flags for cp1file*/
#define IEVEN 1
#define OEVEN 2
#define WHDR 4
#define DIR 0100000
#define CHR 040000
#define BLK 020000
#define ROWN 0400
#define WOWN 0200
#define XOWN 0100
#define RGRP 040
#define WGRP 020
#define XGRP 010
#define ROTH 04
#define WOTH 02
#define XOTH 01
#define LIBMAGIC 0177545
#define LNAMLEN 14
struct lib2hdr {
char l2fname[LNAMLEN];
long l2modti;
char l2userid;
char l2gid;
short l2fimode;
long l2fsize;
short l2junk;
} libhd={0};
struct {
int f_devnum;
int f_inum;
int f_fimode;
char f_nlinks;
char f_userid;
char f_gid;
char f_size0;
int f_size1;
int f_addr[8];
long f_acti;
long f_modti;
};
short libmagic LIBMAGIC;
int rflg=0, dflg=0, xflg=0, tflg=0, vflg=0;
int uflg=0;
int pflg=0;
int areof=0;
int arfd=0;
int tempfd=0;
int aflg=0, bflg=0;
int psflg=0;
int matchflg=0;
char *psname=0;
char *arname=0,tempname[80]={0,0,0};
/************************/
#ifdef UNIX /* */
char *dname="/tmp/"; /* UNIX */
#else /* CP/M and VMS */
char *dname=""; /* Disk Name */
#endif /************************/
#ifdef UNIX /* */
char *tname="arXXXXXX"; /* Unix temp file name */
#else /* CP/M and VMS */
char *tname="ar68.tmp"; /* Temp file name */
#endif /************************/
long lseek();
long fixlong();
long filesize();
int endit();
int (*docom)()=0;
int replace();
int delete();
int extract();
int xtell();
#ifdef JUNK
long mklong();
#endif
int print();
#ifdef VAX
struct {
short loword;
short hiword;
};
#endif
#ifdef PDP11
struct {
short loword;
short hiword;
};
#endif
#ifdef MC68000
struct {
short hiword;
short loword;
};
#endif
main(argc,argv)
char **argv;
{
register char *p1, *p2;
register char **ap;
register int i;
register long l;
register long k;
long kk;
if(argc < 3) {
usage:
error("usage: ar68 drtwx[abiv][f d:] [opmod] archive obmod1 [obmod2] ... [>filespec]\n");
endit();
}
/* signal(1,endit); */
ap = &argv[1];
p1 = *ap++;
i = argc-3;
while(*p1) {
switch(*p1++) {
case 'r':
rflg++;
docom = replace;
break;
case 'a':
aflg++;
psname = *ap++;
i--;
break;
/* These options removed because they don't work!
case 'b':
case 'i':
bflg++;
i--;
psname = *ap++;
break;
*/
case 'd':
dflg++;
docom = delete;
break;
case 'x':
xflg++;
docom = extract;
break;
case 't':
tflg++;
docom = xtell;
break;
case 'w':
pflg++;
docom = print;
break;
case 'v':
vflg++;
break;
case 'f': /* Drive for temp files */
dname = *ap++; /* Set proper disk name */
break;
default:
error("invalid option flag: %c\n",*--p1);
endit();
}
}
uflg = rflg+dflg;
if((uflg+xflg+tflg+pflg) != 1) {
error("one and only one of drtwx flags required\n");
endit();
}
psflg = aflg+bflg;
if(psflg > 1) {
error("only one of abi flags allowed\n");
endit();
}
strcat (tempname,dname); /* Form 1st part of string */
strcat (tempname,tname); /* Add in file name */
#ifdef UNIX /* For UNIX, make temp file*/
mktemp(tempname);
#endif
arname = *ap++;
arfd = openar(arname,rflg);
if(i==0 && tflg) {
listall();
endit();
}
if(i<=0)
goto usage;
if( xflg == 0 ) {
if((tempfd=creat(tempname,0644,1)) < 0) {
error("cannot create %s\n",tempname);
endit();
}
if(write(tempfd,&libmagic,sizeof libmagic) != sizeof libmagic)
{
error("temp file write error\n");
endit();
}
}
while(i) {
excom(*ap++);
i--;
}
excom(0L); /*end of arg list*/
if (xflg == 0)
{
k = lseek(tempfd,0L,1); /* Fetch file size */
#ifndef UNIX
l = lseek(tempfd,0L,0); /* Rewind temp file */
if (l < 0) /* Error? */
{
printf("seek error on %s\n",tempname);
exit(-1);
}
#else
close(tempfd);
if((tempfd=open(tempname,0,1)) < 0)
{
printf("Cannot re-open %s\n",tempname);
exit(-1);
}
#endif
close(arfd); /* Close input file */
unlink(arname); /* Delete the file */
arfd=creat(arname,0666,1); /* Create the file again*/
if(arfd < 0) /* Error? */
{
printf("Unable to re-create %s -- archive is in %s\n",
arname,tempname);
exit(-1);
}
i = 1; /* Klutz */
while (i > 0 && k > 0) /* Copy the file back */
{
i = (k > BLKSIZE) ? BLKSIZE : k;
i = read(tempfd,buff,i);
if(i < 0)
{
printf("Read error on %s\n",tempname);
exit(-1);
}
else if (i > 0)
{
if(write(arfd,buff,i) != i)
{
printf("Write error on %s\n",arname);
exit (-1);
}
}
k -= i;
}
kk = 0;
write(arfd,&kk,sizeof(k)); /* Put 0 on end of file */
close (tempfd);
unlink(tempname);
}
endit();
}
openar(arp,crfl)
char *arp;
{
register i;
int ib;
if((i=open(arp,2,1)) < 0) { /*does not exist*/
areof = 1;
if((i = creat(arp,0666,1)) < 0)
{
printf("Cannot Create %s\n",arname);
exit(-1);
}
else
return(i);
}
if(read(i,&ib,sizeof libmagic) != sizeof libmagic || ib != LIBMAGIC) {
notar:
error("not archive format: %s\n",arp);
endit();
}
return(i);
}
/* execute one command -- call with filename or 0*/
excom(ap)
char *ap;
{
register char *p;
if(p=ap)
{
if(p[1] == ':') /* CP/M Drive number */
p += 2; /* Bump to file name */
}
if((p) && (matchflg==0)) { /*look thru archive for file name*/
while(areof==0 && nextar()) { /*get next ar file header*/
if(streq(p,&libhd.l2fname[0]))
break;
if(psflg && streq(psname,&libhd.l2fname[0])) {
break;
}
skcopy(uflg); /*skip or copy*/
}
}
(*docom)(ap); /*exec requested command*/
}
xtell(ap)
char *ap;
{
register char *p;
register i;
register char *p1;
if(ap==0)
endit();
if(vflg) { /*long list*/
pmode(libhd.l2fimode);
printf(" %d/%d %6ld ",libhd.l2userid,libhd.l2gid,
libhd.l2fsize);
/* p1 = ctime(&libhd.l2modti);
p1[24] = '\0';
p1 =+ 4;
printf(" %s ",p1); */
}
pfname();
skcopy(0);
}
pfname()
{
printf("%.14s\n",libhd.l2fname);
}
replace(ap)
char *ap;
{
register i;
int ifd;
register long l;
register char *p1;
if( ap == 0 ) {
if( bflg && areof == 0 ) {
l = -(sizeof libhd);
lseek(arfd,l,1);
}
cprest();
return;
}
if((ifd=open(ap,0,1)) < 0) {
error("cannot open %s\n",ap);
endit();
}
if(areof && psflg) {
error("%s not in library\n",psname);
endit();
}
if((bflg|aflg) && matchflg==0) { /*copy archive file before appending*/
if(aflg)
skcopy(1);
matchflg++;
}
p1 = (ap[1] == ':') ? ap + 2 : ap; /* Drive name */
copystr(p1,&libhd.l2fname[0],LNAMLEN);
if(areof|aflg) {
inform('a');
}
else if(bflg) {
inform('i');
}
else {
inform('r');
skcopy(0); /*skip old copy*/
}
p1 = buff;
libhd.l2modti = 0;
libhd.l2userid = 0;
libhd.l2gid = 0;
libhd.l2fimode = 0666;
libhd.l2fsize = filesize(&ifd,ap);
cp1file(ifd,tempfd,WHDR+OEVEN,ap,tempname);
close(ifd);
}
struct iobuf ssbuf={0};
long filesize(fdp,fname)
int *fdp;
char *fname;
{
struct hdr tcout;
register long size;
register short *p;
register int i;
close(*fdp);
if( fopen(fname,&ssbuf,1) < 0 )
error("cannot open %s\n",fname);
p = &tcout;
for( i = 0; i < (sizeof tcout)/2; i++ )
*p++ = getw(&ssbuf);
close(ssbuf.fildes);
if( tcout.ch_magic != MAGIC )
error("not object file: %s\n",fname);
size = tcout.ch_tsize + tcout.ch_dsize;
if( tcout.ch_rlbflg == 0 )
size =+ size;
size =+ tcout.ch_ssize;
if( (*fdp=open(fname,0,1)) < 0 )
error("cannot reopen %s\n",fname);
size =+ sizeof tcout;
#ifndef UNIX
size = ((size+3)/4)*4; /*turkey round-up to long for VAX*/
#endif
return(size);
}
struct { char byt1; char byt2; char byt3; char byt4; };
long fixlong(l)
long l;
{
long tl;
tl.byt1 = l.byt4;
tl.byt2 = l.byt3;
tl.byt3 = l.byt2;
tl.byt4 = l.byt1;
return(tl);
}
fixshort(i)
int i;
{
int ti;
ti.byt1 = i.byt2;
ti.byt2 = i.byt1;
}
delete(ap)
char *ap;
{
if(ap==0) {
cprest();
return;
}
inform('d');
skcopy(0);
}
extract(ap)
char *ap;
{
register ofd;
register long l;
register i;
if(ckafile(ap))
return;
if((ofd=creat(ap,0666)) < 0) {
error("cannot create %s\n",ap);
endit();
}
inform('x');
cp1file(arfd,ofd,IEVEN,arname,ap);
close(ofd);
}
print(ap)
char *ap;
{
if(ckafile(ap))
return;
cp1file(arfd,1,IEVEN,arname,"std output");
}
endit()
{
exit();
}
/* list all file in the library*/
listall()
{
while(nextar()) {
xtell(-1);
}
}
/*read next ar file header into libhd*/
nextar()
{
if( read(arfd,&libhd,sizeof libhd) != sizeof libhd ||
libhd.l2fname[0] == '\0' ) {
areof++;
return(0);
}
return(1);
}
/* call with cpflag=0 for skip, cpflag=1 for copy*/
skcopy(cpflag)
{
register long l;
register int i;
if(areof)
return;
l = libhd.l2fsize;
if(l&1)
l++;
if(cpflag) {
inform('c');
cp1file(arfd,tempfd,WHDR+OEVEN+IEVEN,arname,tempname);
}
else {
if(lseek(arfd,l,1) < 0) {
error("seek error on library\n");
endit();
}
}
}
#ifdef JUNK
char *mktemp(ap)
char *ap;
{
register char *p;
register i,j;
/* i = getpid(); /*process id*/
/* p = ap;
while(*p)
p++;
for(j=0; j<5; j++) {
*--p = ((i&7) + '0');
i =>> 3;
}
*/ return(ap);
}
#endif
streq(s1, s2)
char *s1, *s2;
{
register char *p1, *p2;
p1 = s1;
p2 = s2;
while(*p1++ == *p2)
if(*p2++ == 0)
return(1);
return(0);
}
int m1[] { 1, ROWN, 'r', '-' };
int m2[] { 1, WOWN, 'w', '-' };
int m3[] { 1, XOWN, 'x', '-' };
int m4[] { 1, RGRP, 'r', '-' };
int m5[] { 1, WGRP, 'w', '-' };
int m6[] { 1, XGRP, 'x', '-' };
int m7[] { 1, ROTH, 'r', '-' };
int m8[] { 1, WOTH, 'w', '-' };
int m9[] { 1, XOTH, 'x', '-' };
int *m[] { m1, m2, m3, m4, m5, m6, m7, m8, m9};
pmode(aflg1)
{
register int **mp;
for (mp = &m[0]; mp < &m[9];)
select(*mp++,aflg1);
}
select(pairp,flg)
int *pairp;
int flg;
{
register int n, *ap, f;
ap = pairp;
f = flg;
n = *ap++;
while (--n>=0 && (f&*ap++)==0)
ap++;
putchar(*ap);
}
inform(cc)
char cc;
{
if(vflg) {
putchar(cc);
putchar(' ');
pfname();
}
}
copystr(ap1,ap2,alen)
char *ap1, *ap2;
{
register char *p1, *p2;
register len;
p1 = ap1;
p2 = ap2;
len = alen;
while(len) {
if(!(*p2++ = *p1++))
break;
len--;
}
while(--len > 0)
*p2++ = '\0';
}
#ifdef JUNK
long mklong(ai1,ai2)
{
long l;
l.hiword = ai1;
l.loword = ai2;
return(l);
}
#endif
cprest()
{
while(areof==0 && nextar())
skcopy(1); /*copy rest of library*/
}
cp1file(ifd,ofd,aflags,iname,oname)
char *iname, *oname;
{
register i;
register int j;
register long l;
register flags;
flags = aflags;
if(flags&WHDR) {
if(write(ofd,&libhd,sizeof libhd) != sizeof libhd) {
iwrerr:
error("write error on %s\n",oname);
endit();
}
}
for( l = libhd.l2fsize; l > BLKSIZE; l =- BLKSIZE ) {
if((i=read(ifd,buff,BLKSIZE)) != BLKSIZE) {
irderr:
error("read error on %s\n",iname);
endit();
}
if(write(ofd,buff,BLKSIZE) != BLKSIZE) {
goto iwrerr;
}
}
if( l > 0 ) {
i = l;
if((j=read(ifd,buff,i)) != i)
goto irderr;
if(flags&OEVEN) {
if(i&1) {
buff[i] = '\0';
i++;
}
}
if(write(ofd,buff,i) != i)
goto iwrerr;
}
if(flags&IEVEN)
if(l&1)
read(ifd,buff,1);
}
ckafile(ap)
char *ap;
{
if(ap==0)
endit();
if(areof) {
error("%s not in archive file\n",ap);
return(1);
}
return(0);
}
error(x1,x2,x3,x4,x5,x6)
int x1, x2, x3, x4, x5, x6;
{
printf(x1,x2,x3,x4,x5,x6);
if( tempfd ) {
close(tempfd);
unlink(tempname);
}
exit();
}

View File

@@ -0,0 +1,39 @@
/****************************************************************************/
/* */
/* B A S E P A G E . H */
/* ------------------- */
/* */
/* This file contains a definition of the CP/M basepage structure, */
/* b_page. */
/* */
/* NOTE: In the portable CP/M environment, it is NOT guaranteed */
/* that the location of the base page is known at link-edit time */
/* (as it is, for example, in CP/M-80 and CP/M-86.) Instead, a */
/* pointer to the current basepage is delivered by the BDOS */
/* to each new program which is run. This pointer, _base, is */
/* initialized by the C startup function (startup.s) and is */
/* available to C programs as an external. */
/* */
/* "cpm.h" MUST be '#include'd before this file */
/* */
/****************************************************************************/
struct b_page
{
BYTE *ltpa; /* Low TPA address */
BYTE *htpa; /* High TPA address */
BYTE *lcode; /* Start address of code seg*/
LONG codelen; /* Code segment length */
BYTE *ldata; /* Start address of data seg*/
LONG datalen; /* Data segment length */
BYTE *lbss; /* Start address of bss seg */
LONG bsslen; /* Bss segment length */
LONG freelen; /* Free segment length */
BYTE resvd1[20]; /* Reserved area */
struct fcb fcb2; /* Second basepage FCB */
struct fcb fcb1; /* First basepage FCB */
BYTE buff[128]; /* Default DMA buffer, */
/* command line tail */
};
extern struct b_page *_base;

View File

@@ -0,0 +1,367 @@
/****************************************************************************/
/* */
/* B D O S . H */
/* ----------- */
/* */
/* Copyright (c) 1982, Zilog Incorporated */
/* */
/* Macros defining the direct BDOS calls used by the standard CP/M */
/* utilities (ED, PIP, STAT, SET, SHOW.) Some necessary data */
/* data structures are also defined. */
/* */
/* All macros return a long value, even when the BDOS function they */
/* call does produce a return parameter. */
/* */
/* This header file can be used applications which do not require */
/* to use the C standard I/O library functions. For applications */
/* which require the library, but which wish to make use of the */
/* additional information in this file, cpm.h should be included in */
/* the source ahead of this file. The compiler flags multiple */
/* definition errors if this ordering is not observed. */
/* */
/* portab.h must always be included ahead of this file. */
/* */
/****************************************************************************/
extern long __BDOS(); /* BDOS entry point */
#define XADDR long /* 32-bit address data type */
/****************************************************************************/
/* The following BDOS calls are defined in cpm.h. Define them only if they */
/* are not defined already. */
/****************************************************************************/
#ifndef EXIT /* Find out where we stand */
/* Define if necessary */
#define EXIT 0 /* Exit to BDOS */
#define CONOUT 2 /* Direct console output */
#define LSTOUT 5 /* Direct list device output*/
#define CONIO 6 /* Direct console I/O */
#define CONBUF 10 /* Read console buffer */
#define OPEN 15 /* OPEN a disk file */
#define CLOSE 16 /* Close a disk file */
#define DELETE 19 /* Delete a disk file */
#define CREATE 22 /* Create a disk file */
#define SETDMA 26 /* Set DMA address */
#define B_READ 33 /* Read Random record */
#define B_WRITE 34 /* Write Random record */
#define FILSIZ 35 /* Compute File Size */
#define SETMSC 44 /* Set Multi-Sector Count */
#endif
/****************************************************************************/
/* The following BDOS calls are not defined in cpm.h */
/****************************************************************************/
#define CONIN 1 /* Single char I/P with echo*/
#define READER 3 /* Paper tape input */
#define PUNCH 4 /* Paper tape output */
#define GET_IOB 7 /* Get I/O byte */
#define SET_IOB 8 /* Set I/O byte */
#define PRINT 9 /* Print $-terminated line */
#define CONSTAT 11 /* Check if I/P char waiting*/
#define VERSION 12 /* Return version number */
#define RS_DISK 13 /* Reset disk system */
#define SEL_DISK 14 /* Select disk */
#define SRCH_1ST 17 /* Search 1st filename match*/
#define SRCH_NEXT 18 /* Search next match */
#define S_READ 20 /* Sequential read from file*/
#define S_WRITE 21 /* Sequential write to file */
#define RENAME 23 /* Rename a file */
#define RET_LOGIN 24 /* Return login vector */
#define RET_CDISK 25 /* Return current disk */
#define GET_ALLOC 27 /* Get allocation vector */
#define WR_PROTD 28 /* Write protect disk */
#define GET_RO 29 /* Get read-only vector */
#define SET_ATT 30 /* Set file attributes */
#define GET_DPB 31 /* Get disk parameters */
#define GSET_UCODE 32 /* Get/set user code */
#define SET_RAND 36 /* Set random record */
#define RS_DRIVE 37 /* Reset disk specified drv */
/* 38, 39 not used */
#define B_WRZF 40 /* Write random, zero fill */
/* 41 - 43 not used */
#define RET_ERRORS 45 /* Set error return mode */
#define GET_DFS 46 /* Get free disk space */
#define CHAIN 47 /* Chain to program via CCP */
#define FLUSH 48 /* Flush buffers to disk */
#define GSET_SCB 49 /* Get/set system control bk*/
#define BIOS_CALL 50 /* Direct call to BIOS */
/* 51 - 58 not used */
#define PROG_LOAD 59 /* Program load */
/* 60 unused */
#define SET_EXV 61 /* Set exception vector */
#define SET_SUP 62 /* Set supervisor state */
#define SET_LABEL 100 /* Set directory label */
#define GET_LABEL 101 /* Get directory label */
#define GET_XFCB 102 /* Get extended FCB */
#define SET_XFCB 103 /* Set extended FCB */
#define COND_LST 161 /* Conditionally attach LST:*/
/****************************************************************************/
/* The macros themselves... */
/****************************************************************************/
#define _conin() (__BDOS(CONIN, (long) 0))
#define _conout(a) (__BDOS(CONOUT, (long) (a)))
#define _reader() (__BDOS(READER, (long) 0))
#define _punch(a) (__BDOS(PUNCH, (long) (a)))
#define _lstout(a) (__BDOS(LSTOUT, (long) (a)))
#define _conio(a) (__BDOS(CONIO, (long) (a)))
#define _get_iob() (__BDOS(GET_IOB, (long) 0))
#define _set_iob(a) (__BDOS(SET_IOB, (long) (a)))
#define _print(a) (__BDOS(PRINT, (long) (a)))
#define _conbuf(a) (__BDOS(CONBUF, (long) (a)))
#define _constat() (__BDOS(CONSTAT, (long) 0))
#define _version() (__BDOS(VERSION, (long) 0))
#define _rs_disk(a) (__BDOS(RS_DISK, (long) (a)))
#define _sel_disk(a) (__BDOS(SEL_DISK, (long) (a)))
#define _open(a) (__BDOS(OPEN, (long) (a)))
#define _close(a) (__BDOS(CLOSE, (long) (a)))
#define _srch_1st(a) (__BDOS(SRCH_1ST, (long) (a)))
#define _srch_next() (__BDOS(SRCH_NEXT, (long) 0))
#define _delete(a) (__BDOS(DELETE, (long) (a)))
#define _s_read(a) (__BDOS(S_READ, (long) (a)))
#define _s_write(a) (__BDOS(S_WRITE, (long) (a)))
#define _create(a) (__BDOS(CREATE, (long) (a)))
#define _rename(a) (__BDOS(RENAME, (long) (a)))
#define _ret_login() (__BDOS(RET_LOGIN, (long) 0))
#define _ret_cdisk() (__BDOS(RET_CDISK, (long) 0))
#define _setdma(a) (__BDOS(SETDMA, (long) (a)))
#define _get_alloc() (__BDOS(GET_ALLOC, (long) 0))
#define _wr_protd() (__BDOS(WR_PROTD, (long) 0))
#define _get_ro() (__BDOS(GET_RO, (long) 0))
#define _set_att(a) (__BDOS(SET_ATT, (long) (a)))
/* _get_dpb has parameter in*/
/* some implementations */
/* of CP/M but not others */
/* This macro suitable only */
/* for former */
#define _get_dpb(a) (__BDOS(GET_DPB, (long) (a)))
/* This one handles latter */
#define _get_dpa() (__BDOS(GET_DPB, (long) 0))
#define _gset_ucode(a) (__BDOS(GSET_UCODE, (long) (a)))
#define _b_read(a) (__BDOS(B_READ, (long) (a)))
#define _b_write(a) (__BDOS(B_WRITE, (long) (a)))
#define _filsiz(a) (__BDOS(FILSIZ, (long) (a)))
#define _set_rand(a) (__BDOS(SET_RAND, (long) (a)))
#define _rs_drive(a) (__BDOS(RS_DRIVE, (long) (a)))
#define _b_wrzf(a) (__BDOS(B_WRZF, (long) (a)))
#define _setmsc(a) (__BDOS(SETMSC, (long) (a)))
#define _ret_errors(a) (__BDOS(RET_ERRORS, (long) (a)))
#define _get_dfs(a) (__BDOS(GET_DFS, (long) (a)))
#define _chain() (__BDOS(CHAIN, (long) 0))
#define _flush() (__BDOS(FLUSH, (long) 0))
#define _gset_scb(a) (__BDOS(GSET_SCB, (long) (a)))
#define _bios_call(a) (__BDOS(BIOS_CALL, (long) (a)))
#define _prog_load(a) (__BDOS(PROG_LOAD, (long) (a)))
#define _set_exv(a) (__BDOS(SET_EXV, (long) (a)))
#define _set_sup(a) (__BDOS(SET_SUP, (long) 0))
#define _get_label(a) (__BDOS(GET_LABEL, (long) (a)))
#define _set_label(a) (__BDOS(SET_LABEL, (long) (a)))
#define _get_xfcb(a) (__BDOS(GET_XFCB, (long) (a)))
#define _set_xfcb(a) (__BDOS(SET_XFCB, (long) (a)))
#define _cond_lst() (__BDOS(COND_LST, (long) 0))
/****************************************************************************/
/* BIOS calls, for use in conjunction with BDOS call 50 & struct bios_parms */
/****************************************************************************/
#define _INIT 0 /* Cold start */
#define _WARM 1 /* Warm start */
#define _CONST 2 /* Console status */
#define _CONIN 3 /* Read console character */
#define _CONOUT 4 /* Write console character */
#define _LIST 5 /* Write listing character */
#define _PUNCH 6 /* Write punch character */
#define _READER 7 /* Read tape character */
#define _HOME 8 /* Move to track 0 */
#define _SELDSK 9 /* Select disk drive */
#define _SETTRK 10 /* Set track number */
#define _SETSEC 11 /* Set sector number */
#define _SETDMA 12 /* Set DMA address */
#define _READ 13 /* Read selected sector */
#define _WRITE 14 /* Write selected sector */
#define _LISTST 15 /* Return list status */
#define _GETMRT 16 /* Get memory region table */
/* address */
#define _GETIOB 17 /* Get IOBYTE value */
#define _SETIOB 18 /* Set IOBYTE value */
#define _FLUSH 19 /* Flush buffers */
#define _SETEXC 20 /* Set exception vector */
/****************************************************************************/
/* FCB structure is defined in cpm.h. Define it here only if it is not */
/* defined already. Declare some useful values at the same time. */
/****************************************************************************/
#ifndef SECSIZ /* Not already declared? */
struct fcbtab /* File control block */
{ /* */
BYTE drive; /* Disk drive field */
BYTE fname[8]; /* File name */
BYTE ftype[3]; /* File type */
BYTE extent; /* Current extent number */
BYTE s1,s2; /* "system reserved" */
BYTE reccnt; /* Record counter */
BYTE resvd[16]; /* More "system reserved" */
LONG record; /* Note -- we overlap the */
/* current record field to */
/* make this useful. */
};
#define fcb fcbtab /* A useful synonym */
#define SECSIZ 128 /* size of CP/M sector */
#define _MAXSXFR 1 /* max # sectors xferrable */
#define _MAXSHFT 12 /* shift right BDOS rtn val */
#endif
/****************************************************************************/
/* Data structures not defined in cpm.h */
/****************************************************************************/
struct dpbs /* Disk parameter block */
{
UWORD spt; /* Sectors per track */
BYTE bls; /* Block shift factor */
BYTE bms; /* Block mask */
BYTE exm; /* Extent mark */
/* BYTE filler; *** Pad to align words ***/
UWORD mxa; /* Maximum allocation (blks)*/
UWORD dmx; /* Max directory entries */
UWORD dbl; /* Directory alloc. map */
UWORD cks; /* Directory checksum */
UWORD ofs; /* Track offset from track 0*/
};
struct bios_parm /* BIOS parameters for BDOS */
{ /* call 50 */
UWORD req; /* BIOS request code */
LONG p1; /* First parameter */
LONG p2; /* Second parameter */
};
struct scbs /* System control block */
{
BYTE resvd_1[6]; /* Reserved for system use */
BYTE u_flags[4]; /* Utility flags */
BYTE d_flags[4]; /* Display flags */
BYTE clp_flags[2]; /* Command Line Proc flags */
UWORD p_error; /* Program error return code*/
BYTE resvd_2[8]; /* Reserved for system use */
BYTE con_w; /* Console width */
BYTE con_c; /* Console column */
BYTE con_l; /* Console page length */
BYTE resvd_3[5]; /* Reserved for system use */
UWORD conin_r; /* CONIN redirection flag */
UWORD conout_r; /* CONOUT redirection flag */
UWORD auxin_r; /* AUXIN redirection flag */
UWORD auxout_r; /* AUXOUT redirection flag */
UWORD lstout_r; /* LSTOUT redirection flag */
BYTE resvd_4[2]; /* Reserved for system use */
BOOLEAN ctl_h_a; /* Backspace active */
BOOLEAN rubout_a; /* Rubout active */
BYTE resvd_5[2]; /* Reserved for system use */
UWORD c_xlate; /* Console translate func. */
UWORD con_m; /* Console mode (raw/cooked)*/
UWORD buff_a; /* 128 byte buffer available*/
BYTE o_delim; /* Output delimiter */
BOOLEAN lo_flag; /* List output flag */
BYTE resvd_6[2]; /* Reserved for system use */
UWORD d_m_a; /* Current DMA address */
BYTE disk_no; /* Current disk */
BYTE bdos_info[2]; /* BDOS variable info */
BYTE resvd_7[3]; /* Reserved for system use */
BYTE user_no; /* Current user number */
BYTE resvd_8[6]; /* Reserved for system use */
BYTE bdos_mode; /* BDOS error mode */
BYTE c_chain[4]; /* Current search chain */
BYTE tmp_drv; /* Drive for temporary files*/
BYTE resvd_9[7]; /* Reserved for system use */
BYTE date_s[5]; /* Date stamp */
BYTE error_jmp[3]; /* Error jump */
UWORD cmb_a; /* Common memory base addr */
UWORD bdos_ent; /* BDOS entry point */
};
struct scbpb /* SCB parameter block */
{
BYTE off; /* Index to data in SCB */
BYTE op; /* Operation: 0xff Set byte */
/* 0xfe Set word */
/* else Get word */
UWORD val; /* Byte/word value to be set*/
};
#define SET_BYTE 0xff
#define SET_WORD 0xfe
#define GET 0
/****************************************************************************/
/* HILO must be defined for the Z8000. Undefine it first, in case cpm.h */
/* has already defined it. The tagless structures defining byte ordering */
/* which are declared in cpm.h are not redeclared here (the use of members */
/* of tagless structures to define offsets is an obsolete feature of the C */
/* language.) */
/****************************************************************************/
#undef HILO
#define HILO

View File

@@ -0,0 +1,13 @@
#define HDSIZE (sizeof couthd) /**.o file header size*/
struct hdr {
short ch_magic; /*c.out magic number 060016 = $600E*/
long ch_tsize; /*text size*/
long ch_dsize; /*data size*/
long ch_bsize; /*bss size*/
long ch_ssize; /*symbol table size*/
long ch_stksize; /*stack size*/
long ch_entry; /*entry point*/
short ch_rlbflg; /*relocation bits suppressed flag*/
} couthd={0};
#define MAGIC 0x601a /* bra .+26 instruction*/

View File

@@ -0,0 +1,163 @@
/****************************************************************************/
/* */
/* C P M . H */
/* --------- */
/* Copyright 1982 by Digital Research Inc. All rights reserved. */
/* */
/* Edits: */
/* */
/* 25-June-83 sw Add user number to file "fd" structure. */
/* */
/* This file contains CP/M specific definitions for the CP/M */
/* C Run Time Library. */
/* This file is intended only for inclusion with those functions */
/* dealing directly with the BDOS, as well as any function which */
/* has hardware dependent code (byte storage order, for instance). */
/* */
/* <portab.h> must be included BEFORE this file. */
/* */
/****************************************************************************/
/*
* CP/M FCB definition
*/
struct fcbtab /****************************/
{ /* */
BYTE drive; /* Disk drive field */
BYTE fname[8]; /* File name */
BYTE ftype[3]; /* File type */
BYTE extent; /* Current extent number */
BYTE s1,s2; /* "system reserved" */
BYTE reccnt; /* Record counter */
BYTE resvd[16]; /* More "system reserved" */
LONG record; /* Note -- we overlap the */
/* current record field to */
/* make this useful. */
}; /****************************/
#define SECSIZ 128 /* size of CP/M sector */
#define _MAXSXFR 1 /* max # sectors xferrable */
#define _MAXSHFT 12 /* shift right BDOS rtn val */
/* to obtain nsecs on err */
/****************************/
/****************************************************************************/
/* */
/* Channel Control Block (CCB) */
/* */
/* One CCB is allocated (statically) for each of the 16 possible open */
/* files under C (including STDIN, STDOUT, STDERR). Permanent data */
/* regarding the channel is kept here. */
/* */
/* */
/****************************************************************************/
struct ccb /************************************/
{ /* */
WORD flags; /*sw Flags byte */
BYTE user; /*sw User # */
BYTE chan; /* Channel number being used */
LONG offset; /* File offset word (bytes) */
LONG sector; /* Sector currently in buffer */
LONG hiwater; /* High water mark */
struct fcbtab fcb; /* File FCB (may have TTY info)*/
BYTE buffer[SECSIZ]; /* Read/write buffer */
}; /************************************/
#define MAXCCBS 16 /* Maximum # CC Blocks */
extern struct ccb _fds[MAXCCBS]; /* Declare storage */
#define FD struct ccb /* FD Type definition */
/************************************/
/* Flags word bit definitions */
/************************************/
#define OPENED 0x01 /* Channel is OPEN */
#define ISTTY 0x02 /* Channel open to TTT */
#define ISLPT 0x04 /* Channel open to LPT */
#define ISREAD 0x08 /* Channel open readonly */
#define ISASCII 0x10 /* ASCII file attached */
#define ATEOF 0x20 /* End of file encountered */
#define DIRTY 0x40 /* Buffer needs writing */
#define ISSPTTY 0x80 /* Special tty info */
#define ISAUX 0x100 /*sw Auxiliary device */
/************************************/
#define READ 0 /* Read mode parameter for open */
#define WRITE 1 /* Write mode */
/* CCB manipulation macros *************************************/
#define _getccb(i) (&_fds[i]) /* Get CCB addr */
/* Error handling *************************************/
EXTERN WORD errno; /* error place for assigning */
EXTERN WORD __cpmrv; /* the last BDOS return value */
EXTERN WORD _errcpm; /* place to save __cpmrv */
#define RETERR(val,err) {errno=(err);_errcpm=__cpmrv;return(val);}
/************************************/
/****************************************************************************/
/* */
/* B D O S F u n c t i o n D e f i n i t i o n s */
/* ------------------------------------------------- */
/* */
/* Following are BDOS function definitions used by the C runtime */
/* library. */
/* */
/****************************************************************************/
/****************************/
#define EXIT 0 /* Exit to BDOS */
#define CONOUT 2 /* Direct console output */
#define LSTOUT 5 /* Direct list device output*/
#define CONIO 6 /* Direct console I/O */
#define CONBUF 10 /* Read console buffer */
#define OPEN 15 /* OPEN a disk file */
#define CLOSE 16 /* Close a disk file */
#define DELETE 19 /* Delete a disk file */
#define CREATE 22 /* Create a disk file */
#define SETDMA 26 /* Set DMA address */
#define USER 32 /*sw Get / set user number */
#define B_READ 33 /* Read Random record */
#define B_WRITE 34 /* Write Random record */
#define FILSIZ 35 /* Compute File Size */
#define SETMSC 44 /* Set Multi-Sector Count */
#define SETVEC 61 /* Set exception vector */
/****************************/
/****************************************************************************/
/* Other CP/M definitions */
/****************************************************************************/
#define TERM "CON:" /* Console file name */
#define LIST "LST:" /* List device file name */
#define EOFCHAR 0x1a /* End of file character-^Z */
/****************************/
/****************************************************************************/
/* Hardware dependencies */
/****************************************************************************/
#define HILO /* used when bytes stored */
/* Hi,Lo */
/****************************/
#ifdef HILO /* Hi/Lo storage used in */
struct { /* 68K */
BYTE lbhihi; /* Use this for accessing */
BYTE lbhilo; /* ordered bytes in 32 bit*/
BYTE lblohi; /* LONG qtys. */
BYTE lblolo; /* */
}; /* */
struct { /* Use this for accessing */
WORD lwhi; /* ordered words in 32 bit*/
WORD lwlo; /* LONG qtys. */
}; /* */
#else /****************************/
struct { /* Lo/Hi storage use on */
BYTE lblolo; /* PDP-11, VAX, 8086,... */
BYTE lblohi; /* */
BYTE lbhilo; /* */
BYTE lbhihi; /* */
}; /* */
struct { /* */
WORD lwlo; /* */
WORD lwhi; /* */
}; /* */
#endif /****************************/
/*************************** end of cpm.h ***********************************/

View File

@@ -0,0 +1,39 @@
/**************************************************************************
* CTYPE.H - macros to classify ASCII-coded integers by table lookup.
*
*
* Note: Integer args are undefined for all int values > 127,
* except for macro 'isascii()'.
* Assumes:
* User will link with standard library functions.
* Compiler can handle declarator initializers and
* '#defines' with parameters.
***************************************************************************/
/* Define bit patterns for character classes */
#define __c 01
#define __p 02
#define __d 04
#define __u 010
#define __l 020
#define __s 040
#define __cs 041
#define __ps 042
#ifndef CTYPE
extern char __atab[];
#endif
#define isascii(ch) ((ch) < 0200)
#define isalpha(ch) (__atab[ch] & (__u | __l))
#define isupper(ch) (__atab[ch] & __u)
#define islower(ch) (__atab[ch] & __l)
#define isdigit(ch) (__atab[ch] & __d)
#define isalnum(ch) (__atab[ch] & (__u | __l | __d))
#define isspace(ch) (__atab[ch] & __s)
#define ispunct(ch) (__atab[ch] & __p)
#define isprint(ch) (__atab[ch] & (__u | __l | __d | __p))
#define iscntrl(ch) (__atab[ch] & __c)
#define tolower(ch) (isupper(ch) ? (ch)-'A'+'a' : (ch) )
#define toupper(ch) (islower(ch) ? (ch)-'a'+'A' : (ch) )
#define toascii(ch) ((ch) & 0177)

View File

@@ -0,0 +1,41 @@
e:vax AR.H r
e:vax AR68.C r
e:vax BASEPAGE.H r
e:vax BDOS.H r
e:vax COUT.H r
e:vax CPM.H r
e:vax CTYPE.H r
e:vax DOWN.SUB r
e:vax DUMP.C r
e:vax ERRNO.H r
e:vax FIND.C r
e:vax IOBUF.H r
e:vax KLIB.H r
e:vax LIBFIX.C r
e:vax LINK.COM r
e:vax LIST.COM r
e:vax LO68.C r
e:vax LO68.H r
e:vax LO68INIT.C r
e:vax MACHINE.11 r
e:vax MACHINE.68K r
e:vax MACHINE.H r
e:vax MACHINE.VAX r
e:vax MAKE.SUB r
e:vax N.C r
e:vax NM68.C r
e:vax NUXI.C r
e:vax PORTAB.H r
e:vax PRTOBJ.C r
e:vax RELOC.C r
e:vax SEND10.SUB r
e:vax SENDC68.C r
e:vax SENDC68.H r
e:vax SETJMP.H r
e:vax SGTTY.H r
e:vax SIGNAL.H r
e:vax SIZE68.C r
e:vax STDIO.H r
e:vax VMAKE.COM r
e:vax VSEND.COM r
e:vax XER.COM r

View File

@@ -0,0 +1,46 @@
Directory _DRB0:[STEVE.CPM68K.V102.LO68]
AR.H;1
AR68.C;1
BASEPAGE.H;1
BDOS.H;1
COUT.H;1
CPM.H;1
CTYPE.H;1
DOWN.SUB;1
DUMP.C;1
ERRNO.H;1
FIND.C;1
IOBUF.H;1
KLIB.H;1
LIBFIX.C;1
LINK.COM;2
LIST.COM;3
LO68.C;2
LO68.H;1
LO68INIT.C;1
MACHINE.11;1
MACHINE.68K;1
MACHINE.H;12
MACHINE.VAX;1
MAKE.SUB;2
N.C;1
NM68.C;1
NUXI.C;1
PORTAB.H;1
PRTOBJ.C;1
RELOC.C;1
SEND10.SUB;1
SENDC68.C;3
SENDC68.H;1
SETJMP.H;1
SGTTY.H;1
SIGNAL.H;1
SIZE68.C;1
STDIO.H;1
VMAKE.COM;9
VSEND.COM;3
XER.COM;1
Total of 41 files.

View File

@@ -0,0 +1,135 @@
/*
* Kludge hex dump routine for 68K
*/
#include <stdio.h>
#include <cpm.h>
#include "machine.h"
#include <ctype.h>
main(argc,argv)
int argc;
char **argv;
{
char buffer[128]; /* Sector buffer */
int sector; /* Sector number */
long filaddr; /* File address */
int offset; /* Sector Offset */
register i,j,k,l,m; /* Temps. */
int fd; /* File descriptor */
if(argc < 2 || argc > 3) /* Only 1 file, please! */
{
printf("Usage: dump [-shhhhhh] file\n");
exit();
}
i = 1;
filaddr= 0; /* Zero file address */
if(*argv[1] == '-')
{
decode(argv[1],&filaddr); /* Get hex file addr */
i=2;
}
if((fd=openb(argv[i],READ)) < 0) /* Try to open file */
{
printf("Unable to open \"%s\"\n",argv[i]);
exit();
}
sector = filaddr >> 7; /* Zero sector count */
filaddr &= ~15; /* Round request down */
lseek(fd,filaddr,0); /* Do the seek */
m = (128 - (filaddr & 127)); /* # bytes in sector */
while((l=read(fd,buffer,m)) > 0) /* Until EOF */
{
l = (l + 15) / 16; /* Number of lines */
offset = filaddr & 127; /* Starting Offset */
for(i=0; i<l; i++) /* 8 lines / sector */
{
printf("%04x %02x (%06lx): ",sector,offset,filaddr);
for(j=0; j<16; j++) /* 16 bytes / line */
{
#ifdef VAX
printf(" %02x%02x",(buffer[i*16+j+1])&0xff,
(buffer[i*16+j]&0xff));
#endif
#ifdef PDP11
printf(" %02x%02x",(buffer[i*16+j+1])&0xff,
(buffer[i*16+j])&0xff);
#endif
#ifdef MC68000
printf(" %02x%02x",(buffer[i*16+j])&0xff,
(buffer[i*16+j+1]&0xff));
#endif
j++;
}
printf(" *");
for(j=0; j<16; j++) /* Now ASCII */
{
k = buffer[i*16+j] & 0x7f;
if ((k < ' ') || (k == 0x7f)) k= '.';
printf("%c",k);
}
printf("*\n");
filaddr += 16; /* Bump up file address*/
offset += 16; /* and offset */
}
sector++; /* Increment sector count*/
m = 128; /* # bytes to read next */
for(j=0; j<128; j++)
buffer[j] = 0;
}
printf("\n*** E O F ***\n");
}
/****************************************************************************/
/* */
/* D e c o d e F u n c t i o n */
/* ------------------------------ */
/* */
/* Routine "decode" is called to process the relocation base argument */
/* from the command line. */
/* */
/* Calling sequence: */
/* */
/* ret = decode(string,&address); */
/* */
/* Where: */
/* string -> argument string (usually argv[1]) */
/* &address -> long word to receive converted value */
/* */
/* ret = 0 if successful conversion */
/* = -1 if anything amiss */
/* */
/****************************************************************************/
WORD decode(string,addr) /* */
/* */
REG BYTE *string; /* -> Command argument */
LONG *addr; /* = return value */
{ /****************************/
REG LONG a; /* Temp return value */
REG BYTE c; /* Temp character */
/* */
if(*string++ != '-' || *string++ != 's')/* Check for valid switch */
return(FAILURE); /* quit if NFG */
/* */
a = 0; /* Zero out accumulator */
/* */
while(*string) /* Until no more chars */
{ /* */
c = toupper(*string) & 0177; /* Pick up next char */
if (c >= '0' && c <= '9') /* Digit */
a = (a << 4) + c - '0'; /* Un-ASCIIfy */
else if (c >= 'A' && c <= 'F') /* Hex */
a = (a << 4) + c - 'A'+ 10; /* Un-ASCIIfy */
else /* Bad character */
return(FAILURE); /* So long, sucker!! */
string++; /* Increment pointer */
} /* */
*addr = a; /* Store result */
return(SUCCESS); /* Return all ok */
} /****************************/

View File

@@ -0,0 +1,45 @@
/*
* errno.h - error codes
*/
#define EPERM 1
#define ENOENT 2
#define ESRCH 3
#define EINTR 4
#define EIO 5
#define ENXIO 6
#define E2BIG 7
#define ENOEXEC 8
#define EBADF 9
#define ECHILD 10
#define EAGAIN 11
#define ENOMEM 12
#define EACCES 13
#define EFAULT 14
#define ENOTBLK 15
#define EBUSY 16
#define EEXIST 17
#define EXDEV 18
#define ENODEV 19
#define ENOTDIR 20
#define EISDIR 21
#define EINVAL 22
#define ENFILE 23
#define EMFILE 24
#define ENOTTY 25
#define ETXTBSY 26
#define EFBIG 27
#define ENOSPC 28
#define ESPIPE 29
#define EROFS 30
#define EMLINK 31
#define EPIPE 32
/* math software */
#define EDOM 33
#define ERANGE 34
/* hereafter is available to CP/M specials */
#define ENODSPC 35
/****** end of errno.h ******/

View File

@@ -0,0 +1,241 @@
/****************************************************************************
*
* C R U N T I M E G R E P R O U T I N E
* -------------------------------------------
* Copyright 1983 by Digital Research Inc. All rights reserved.
*
* The routine "grep" searches for an ascii character pattern in
* a series of files. "Grep" allows the following options:
*
* OPTION FUNCTION
* ------ --------
* -v Print only lines not matching the pattern
* -c Print only a count of the lines
* -n Print with line numbers
* -s Write out the sector number in which the pattern was found
* -l Write out a list of the files in which the pattern was found
* -y Do not distinguish between upper & lower case
*
* Calling Sequence:
*
* grep(options,expression,files);
*
* Where:
*
* options Is a pointer to a string of options
* expression Is a pointer to the search pattern
* files Is an array of pointers to filenames
*
*****************************************************************************/
/****************************/
/* INCLUDE FILES */
/****************************/
#include <stdio.h> /* standard I/O library */
#include <portab.h> /* CP/M portability defines */
#include <ctype.h> /* char type definitions */
/****************************/
/* GLOBAL VARIABLES */
/****************************/
GLOBAL BYTE __match = TRUE; /* Print Matching lines only*/
GLOBAL BYTE __count = FALSE; /* Just count the lines */
GLOBAL BYTE __num = FALSE; /* Print line #'s */
GLOBAL BYTE __sector = FALSE; /* Display the sector */
GLOBAL BYTE __list = FALSE; /* Display only a file list */
GLOBAL BYTE __nocase = FALSE; /* Distinguish between cases*/
GLOBAL FILE *fstream; /* file stream ptr */
GLOBAL BYTE line[129]; /* line buffer */
GLOBAL BYTE line1[129]; /* Temp line buffer */
GLOBAL BYTE first = TRUE; /* used on the list option */
GLOBAL UWORD numfound = 0; /* number of lines found */
/****************************/
/* FUNCTIONS */
/****************************/
FILE *fopenb(); /* returns a ptr to a file */
/****************************/
/* MAIN */
main(argc,argv) /* Entry point */
WORD argc; /* = # args */
BYTE **argv; /* -> args */
{ /****************************/
BYTE *options; /* Option pointer */
BYTE *expression; /* -> expression */
BYTE **files; /* -> files */
/* */
if(argc < 2) /* Must have at least 2 */
{ /* */
usage: printf("Usage: find [-options] pattern files\n");
exit(); /* */
} /****************************/
/* */
options = "-ny"; /* Set up option */
if(*argv[1] == '-') /* Options specified? */
{ /* */
options = argv[1]; /* Yes, use them */
if(argc < 3) goto usage; /* check for valid args */
expression = argv[2]; /* -> Pattern */
files = &argv[3]; /* -> file list */
} /****************************/
else { /* No options */
expression = argv[1]; /* Expression */
files = &argv[2]; /* file list */
} /****************************/
return(grep(options,expression,files)); /* Call the real function */
} /* */
/****************************/
grep(options,expression,files) /* */
REG BYTE *options; /* option list */
REG BYTE *expression; /* pattern to search for */
BYTE *files[]; /* array of files */
{ /* */
REG BYTE *p; /* temp pointer */
REG UWORD patt_cnt; /* pattern counter */
REG UWORD char_cnt; /* character count */
REG UWORD line_cnt; /* line count */
REG UWORD i; /* counter */
UWORD length; /* length of pattern */
BYTE found; /* set if pattern is found */
/* */
/* */
if(*options != '-') /* Legal option list? */
{ /* */
fprintf(stderr,"FIND--Illegal option list: %s\n",options); /* */
exit(-1); /* Just quit */
} /****************************/
while(*options) /* if found ........ */
{ /* */
switch(*++options) /* */
{ /* */
case 'v' : __match = FALSE; /* print non-matching lines */
break; /* */
case 'c' : __count = TRUE; /* print a count of lines */
break; /* */
case 'n' : __num = TRUE; /* number the lines */
break; /* */
case 's' : __sector= TRUE; /* print sector number */
break; /* */
case 'l' : __list = TRUE; /* list the files */
break; /* */
case 'y' : __nocase= TRUE; /* no case distinction */
/*break;*/ /* */
} /* */
} /* */
/****************************/
if(__list) /* list option has priority */
{ /* over these..... */
__count = FALSE; /* */
__num = FALSE; /* */
__sector = FALSE; /* */
} /* */
else /* */
if(__count) /* count option has priority*/
{ /* over these..... */
__num = FALSE; /* */
__sector = FALSE; /* */
} /* */
else /* */
if(__num) /* num option has priority */
__sector = FALSE; /* over the sector option */
if(__nocase) /* if no case destinction */
{ /* */
p = expression; /* */
while(*p) /* change expression to */
{ /* */
*p = toupper(*p); /* upper case letters */
p++; /* */
} /* */
} /* */
length = strlen(expression); /* count the characters in */
/* the pattern to match */
while(*files) /* search all the files */
{ /* */
if((fstream = fopenb(*files,"r")) != NULL)/*try to open the file */
{ /* */
char_cnt = 0; /* initialize char count */
line_cnt = 0; /* initialize line # count */
numfound = 0; /* initialize # found */
first = TRUE; /* initialize for list */
if(!__list && !__count) /* if these options are not */
{ /* ON then print the file- */
printf("\nFILE: %s\n",*files); /* name before each search */
printf("----\n"); /* */
} /* */
while(!feof(fstream)) /* go until end of file */
{ /* */
found = FALSE; patt_cnt = 0; /* */
p = expression; /* */
for(i=0;i<129;i++) /* Zap out the buffers */
line[i]=line1[i]=0; /* */
fgets(line1,129,fstream); /* read a line */
/****************************/
for(i = 0;line1[i];i++) /* */
if(__nocase) /* Translate? */
line[i] = toupper(line1[i]);/* */
else /* Don't translate */
line[i] = line1[i]; /* Just copy */
/****************************/
i = 0; /* */
while(line[i]) /* scan until a NULL */
{ /* */
char_cnt++; /* bump the char count */
if(line[i] == *p) /* check pattern */
{ /* */
p++; /* look for next char */
patt_cnt++; /* we found a character */
if(patt_cnt == length) /* Have we found the end ? */
{ /* */
found = TRUE; /* set a flag */
p = expression; /* */
patt_cnt = 0; /* */
} /* */
} /* */
else /* */
{ /* */
p = expression; /* reset the pattern ptr */
patt_cnt = 0; /* start the count over */
} /* */
i++; /* check next character */
} /* */
line[i-1] = NULL; /* mask out extra LF */
line_cnt++; /* bump the line count */
prtline(found,char_cnt,line_cnt,files);/*then print routine */
} /* */
if(__count) /* is count option ON ? */
printf("\n%s: %d",*files,numfound);/*print a count of # fnd */
} /* */
fclose(fstream); /* Close the file */
files++; /* go to next file */
} /* */
} /****************************/
/* PRINT ROUTINE */
prtline(found,char_cnt,line_cnt,files) /****************************/
BYTE found; /* does line contain pattern*/
UWORD char_cnt; /* number of chars searched */
UWORD line_cnt; /* number of lines searched */
BYTE *files[]; /* current file */
{ /****************************/
if((__match && found) || /* have we a line ? */
(!__match && !found)) /* */
{ /* */
numfound++; /* count the # lines found */
if(__count) return; /* nothing to do */
if(__list) /* if the list option */
{ /* */
if(first) /* FIRST pattern found ? */
printf("\n%s",*files); /* print the filename */
first = FALSE; /* turn off flag */
return; /* and return.. */
} /* */
if(__sector) /* do we print the sector# ?*/
{ /* */
printf("\n%d",char_cnt/128);/* divide count by 128 */
return; /* */
} /* */
if(__num) /* do we print a line # ? */
{ /* */
printf("%5d: ",line_cnt); /* */
} /* otherwise..... */
fputs(line1,stdout); /* just print the line */
} /* */
} /****************************/

View File

@@ -0,0 +1,6 @@
struct iobuf{
int fildes;
int nunused;
char *xfree;
char buff[512];
};

View File

@@ -0,0 +1,23 @@
/*
* This file defines procedure names used by the assembler, compiler,
* etc. to be the names used in this library.
*
* (In case you haven't guessed, the "k" in "klib" stands for:
*
* K L U D G E !)
*/
#define creat xcreat
#define open xopen
#define fopen xfopen
#define getc xgetc
#define getw xgetw
#define fcreat xfcreat
#define putw xputw
#define strcmp xstrcmp
#define index xindex
#define strcpy xstrcpy
/*
* Defining the names in this manner allows using the V7 UNIX library
* to run the asinine V6 calls in the Alcyon software.
*
*/

View File

@@ -0,0 +1,111 @@
/*
* Fix library files on CP/M - 68k
*/
#define LNAMLEN 14
#define LIBMAGIC 0177545
struct lib2hdr {
char fname[LNAMLEN]; /* Original file name */
long modti; /* Modification (unused) */
char userid; /* User id */
char gid;
short fimode;
long fsize; /* file size (Swap words here */
short junk; /* Unused */
} header;
struct {
short hiword; /* PDP-11 is */
short loword; /* backwards */
};
long lseek();
main(argc,argv)
int argc;
char **argv;
{
short i,j; /* Temps */
long seekaddr; /* Seek pointer */
long writeaddr; /* Write seek pointer */
short fd; /* File descriptor for I/O */
short ofd; /* File descriptor for output */
short magic; /* Lib magic word */
char buffer[30000]; /* I/O Buffer for file */
if(argc != 3)
{
printf ("File count wrong\n");
exit();
}
if((fd=open(argv[1],0,1)) < 0)
{
printf("Open failure on %s\n",argv[1]);
exit();
}
if((ofd=creat(argv[2],1,1)) < 0)
{
printf("Cannot create %s\n",argv[2]);
exit();
}
if(read(fd,&magic,2) != 2)
{
printf("Read error\n");
exit();
}
if(magic != LIBMAGIC)
{
printf("Not archive format: %s\n",argv[1]);
exit();
}
if(write(ofd,&magic,2) != 2)
{
printf("Write error\n");
exit();
}
while(1)
{
if(read(fd,&header,(sizeof header)-2) != (sizeof header)-2)
{
printf("Read error at file offset %lx\n",writeaddr);
exit();
}
for(i=0; i<LNAMLEN; i+=2)
{
j = header.fname[i];
header.fname[i] = header.fname[i+1];
header.fname[i+1] = j;
}
header.modti = 0L;
header.userid = 0;
header.gid = 0;
header.fimode = 0777;
header.junk = 0;
printf("File %14s: %ld bytes\n",&header.fname[0],header.fsize);
if(write(ofd,&header,(sizeof header)) != (sizeof header))
{
printf("Write error\n");
exit();
}
if(header.fsize > 30000)
{
printf("File size error\n");
exit();
}
if(read(fd,&buffer[0],header.fsize.loword) != header.fsize.loword)
{
printf("Read error\n");
exit();
}
if(write(ofd,&buffer[0],header.fsize.loword) != header.fsize.loword)
{
printf("Write error\n");
exit();
}
}
}

View File

@@ -0,0 +1,12 @@
$ linker
$ set noon
$ !
$ ! lo68 and utilities build file for VMS
$ !
$ clink lo68,lo68init,lib:klib/lib lo68
$ clink dump dump
$ clink nm68,lib:klib/lib nm68
$ clink prtobj,lo68init,lib:klib/lib prtobj
$ clink reloc reloc
$ clink sendc68,lib:klib/lib sendc68
$ clink size68,lib:klib/lib size68

View File

@@ -0,0 +1,84 @@
$ num
AR68.C
AR68.lis
$ num
DUMP.C
DUMP.lis
$ num
FIND.C
FIND.lis
$ num
LIBFIX.C
LIBFIX.lis
$ num
LO68.C
LO68.lis
$ num
LO68INIT.C
LO68INIT.lis
$ num
N.C
N.lis
$ num
NM68.C
NM68.lis
$ num
NUXI.C
NUXI.lis
$ num
PRTOBJ.C
PRTOBJ.lis
$ num
RELOC.C
RELOC.lis
$ num
SENDC68.C
SENDC68.lis
$ num
SIZE68.C
SIZE68.lis
$ num
BASEPAGE.H
BASEPAGE.lst
$ num
BDOS.H
BDOS.lst
$ num
COUT.H
COUT.lst
$ num
CPM.H
CPM.lst
$ num
CTYPE.H
CTYPE.lst
$ num
ERRNO.H
ERRNO.lst
$ num
IOBUF.H
IOBUF.lst
$ num
KLIB.H
KLIB.lst
$ num
LO68.H
LO68.lst
$ num
MACHINE.H
MACHINE.lst
$ num
SENDC68.H
SENDC68.lst
$ num
SETJMP.H
SETJMP.lst
$ num
SGTTY.H
SGTTY.lst
$ num
SIGNAL.H
SIGNAL.lst
$ num
STDIO.H
STDIO.lst

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,199 @@
/*
Copyright 1981
Alcyon Corporation
8474 Commerce Av.
San Diego, Ca. 92121
*/
#include <stdio.h>
#include <klib.h>
#include "machine.h"
/* format of a symbol entry in the main table*/
#define SEEKREL 1 /*relative seek flag*/
#define SYNAMLEN 8
struct symtab {
char name[SYNAMLEN]; /*symbol name*/
short flags; /*bit flags*/
long vl1; /*symbol value*/
char *tlnk; /*table link*/
};
struct symtab *symptr;
#define OSTSIZE 14 /*entry length on object file without tlnk*/
/* flags for symbols*/
# define SYDF 0100000 /*defined*/
# define SYEQ 0040000 /*equated*/
# define SYGL 0020000 /*global - entry or external*/
# define SYER 0010000 /*equated register*/
# define SYXR 0004000 /*external reference*/
# define SYDA 0002000 /*DATA based relocatable*/
# define SYTX 0001000 /*TEXT based relocatable*/
# define SYBS 0000400 /*BSS based relocatable*/
struct irts {
char *irle; /*ptr to last entry in chain*/
char *irfe; /*ptr to first entry in chain*/
};
#ifdef VAX
struct {
short loword;
short hiword;
};
#endif
#ifdef PDP11
struct {
short loword;
short hiword;
};
#endif
#ifdef MC68000
struct {
short hiword;
short loword;
};
#endif
/* parameters that define the main table*/
#define SZMT 300 /*initial size of the main table*/
/*must be large enough to initialize*/
#define ICRSZMT 100 /*add to main table when run out*/
int cszmt; /*current size of main table*/
char *bmte; /*beginning of main table*/
char *emte; /*end of main table*/
/*initial reference table for externals*/
# define SZIRT 64
char *eirt[SZIRT];
char *saveirt[SZIRT];
/*initial reference table for globals*/
char *girt[SZIRT];
char *savgirt[SZIRT];
char **pirt;
char *lmte; /*last entry in main table*/
char *savlmte;
#define AREGLO 8
#define AREGHI 15
/* relocation bit definitions:*/
#define RBMASK 07 /*tells type of relocation*/
#define INSABS 7 /*first word of instr -- absolute*/
#define DABS 0 /*data word absolute*/
#define TRELOC 2 /* TEXT relocatable*/
#define DRELOC 1 /* DATA relocatable*/
#define BRELOC 3 /* BSS relocatable*/
#define EXTVAR 4 /* ref to external variable*/
#define LUPPER 5 /* upper word of long*/
#define EXTREL 6 /* relative mode on external variable*/
#define BUFSIZE 512
struct buf{
int fildes;
int nunused;
char *xfree;
char buff[512];
};
struct buf ibuf;
struct buf tbuf;
struct buf obuf;
struct buf rbuf;
struct buf rtbuf;
struct buf rdbuf;
int sflag; /*remove symbol table*/
long textbase;
long database;
long bssbase;
long textsize;
long datasize;
long bsssize;
long stacksize;
long textstart;
long datastart;
long bssstart;
char *ifilname; /*points to name of current input file*/
#define NFILE 256 /*max # files we can process*/
char *fsymp[NFILE]; /*points to first symbol for each .o file*/
char **firstsym; /*points to entry in fsymp*/
int extmatch; /*matched an external in a library entry*/
int noload; /*dont load this lib file flag*/
#define NLIB 16 /*max # libraries to process*/
int lbfictr[NLIB]; /*counts files loaded from one library*/
int *libfctr; /*points to lbfictr*/
long lbfioff[NFILE]; /*each file offset in library*/
long *libptr; /*points to lbfioff*/
#define LIB1MAGIC 0177555
#define LIB2MAGIC 0xffffff65
#define LIB1HDSIZE 16
#define LIB2HDSIZE 26
struct libhdr {
char l1fname[8];
long l1modti;
char l1userid;
char l1fimode;
short l1fsize;
};
struct lib2hdr {
char l2fname[14];
long l2modti;
char l2userid;
char l2gid;
short l2fimode;
long l2fsize;
short l2junk;
} *lib2hd;
#define ARMAG "!<arch>\n"
#define SARMAG 8
#define ARFMAG "`\n"
struct ar_hdr {
char ar_name[16];
char ar_date[12];
char ar_uid[6];
char ar_gid[6];
char ar_mode[8];
char ar_size[10];
char ar_fmag[2];
} lib3_hdr;
#define LIB3MAGIC 0x3c21
#define LIB3HDSIZE (sizeof lib3_hdr)
int libhdsize;
long libhd[20]; /*length is max lib head size*/
int undflg;
char dafnc;
int pass2;
long stlen;
int Xflag;
int Dflag;
int Bflag;
int Zflag;
struct symtab *etextptr;
struct symtab *edataptr;
struct symtab *endptr;
char *lastdup;
char rtfnc;
char rdfnc;
int saverbits;

View File

@@ -0,0 +1,185 @@
/*
Copyright 1981
Alcyon Corporation
8474 Commerce Av.
San Diego, Ca. 92121
*/
/* format of a symbol entry in the main table*/
#define SEEKREL 1 /*relative seek flag*/
#define SYNAMLEN 8
struct symtab {
char name[SYNAMLEN]; /*symbol name*/
short flags; /*bit flags*/
long vl1; /*symbol value*/
char *tlnk; /*table link*/
};
struct symtab *symptr =0;
#define OSTSIZE 14
/*entry length on object file without tlnk*/
/* flags for symbols*/
# define SYDF 0100000 /*defined*/
# define SYEQ 0040000 /*equated*/
# define SYGL 0020000 /*global - entry or external*/
# define SYER 0010000 /*equated register*/
# define SYXR 0004000 /*external reference*/
# define SYDA 0002000 /*DATA based relocatable*/
# define SYTX 0001000 /*TEXT based relocatable*/
# define SYBS 0000400 /*BSS based relocatable*/
struct irts {
char *irle; /*ptr to last entry in chain*/
char *irfe; /*ptr to first entry in chain*/
};
struct {
short loword;
short hiword;
};
/* parameters that define the main table*/
#define SZMT 300 /*initial size of the main table*/
/*must be large enough to initialize*/
#define ICRSZMT 100 /*add to main table when run out*/
int cszmt =0;
char *bmte =0;
char *emte =0;
/*initial reference table for externals*/
# define SZIRT 64
char *eirt[SZIRT] ={0};
char *saveirt[SZIRT] ={0};
/*initial reference table for globals*/
char *girt[SZIRT] ={0};
char *savgirt[SZIRT] ={0};
char **pirt =0;
char *lmte =0;
char *savlmte =0;
#define AREGLO 8
#define AREGHI 15
/* relocation bit definitions:*/
#define RBMASK 07 /*tells type of relocation*/
#define INSABS 7 /*first word of instr -- absolute*/
#define DABS 0 /*data word absolute*/
#define TRELOC 2 /* TEXT relocatable*/
#define DRELOC 1 /* DATA relocatable*/
#define BRELOC 3 /* BSS relocatable*/
#define EXTVAR 4 /* ref to external variable*/
#define LUPPER 5 /* upper word of long*/
#define EXTREL 6 /* relative mode on external variable*/
#define BUFSIZE 512
struct buf{
int fildes;
int nunused;
char *xfree;
char buff[512];
};
struct buf ibuf ={0};
struct buf tbuf ={0};
struct buf obuf ={0};
struct buf rbuf ={0};
struct buf rtbuf ={0};
struct buf rdbuf ={0};
int sflag =0;
long textbase =0;
long database =0;
long bssbase =0;
long textsize =0;
long datasize=0;
long bsssize =0;
long stacksize =0;
long textstart =0;
long datastart =0;
long bssstart =0;
char *ifilname =0;
#define NFILE 256 /*max # files we can process*/
char *fsymp[NFILE] ={0};
char **firstsym =0;
int extmatch =0;
int noload =0;
#define NLIB 16 /*max # libraries to process*/
int lbfictr[NLIB] ={0};
int *libfctr =0;
long lbfioff[NFILE] ={0};
long *libptr =0;
#define LIB1MAGIC 0177555
#define LIB2MAGIC 0177545
#define LIB1HDSIZE 16
#define LIB2HDSIZE 26
struct libhdr {
char l1fname[8];
long l1modti;
char l1userid;
char l1fimode;
int l1fsize;
};
struct lib2hdr {
char l2fname[14];
long l2modti;
char l2userid;
char l2gid;
int l2fimode;
long l2fsize;
};
#define ARMAG "!<arch>\n"
#define SARMAG 8
#define ARFMAG "`\n"
struct ar_hdr {
char ar_name[16];
char ar_date[12];
char ar_uid[6];
char ar_gid[6];
char ar_mode[8];
char ar_size[10];
char ar_fmag[2];
} lib3_hdr ={0};
#define LIB3MAGIC 0x3c21
#define LIB3HDSIZE (sizeof lib3_hdr)
int libhdsize =0;
long libhd[20] ={0};
int undflg =0;
char dafnc =0;
int pass2 =0;
long stlen =0;
int Xflag =0;
int Dflag =0;
int Bflag =0;
int Zflag =0;
struct symtab *etextptr =0;
struct symtab *edataptr =0;
struct symtab *endptr =0;
char *lastdup =0;
char rtfnc =0;
char rdfnc =0;
int saverbits =0;

View File

@@ -0,0 +1,10 @@
/*
* Use this file to determine what kind of machine you want the
* Alcyon stuff to run on ....
*/
/*#define MC68000 1*/ /* 68000 version */
/*#define VAX 1*/ /* VAX Version */
#define PDP11 1 /* PDP-11 Version*/
/*#define CPM 1*/ /* CP/M Operating System*/
#define UNIX 1 /* UNIX Operating System*/
/*#define VMS 1*/ /* VMS Operating System*/

View File

@@ -0,0 +1,10 @@
/*
* Use this file to determine what kind of machine you want the
* Alcyon stuff to run on ....
*/
#define MC68000 1 /* 68000 version */
/*#define VAX 1*/ /* VAX Version */
/*#define PDP11 1*/ /* PDP-11 Version*/
#define CPM 1 /* CP/M Operating System*/
/*#define UNIX 1*/ /* UNIX Operating System*/
/*#define VMS 1*/ /* VMS Operating System*/

View File

@@ -0,0 +1,10 @@
/*
* Use this file to determine what kind of machine you want the
* Alcyon stuff to run on ....
*/
#define MC68000 1 /* 68000 version */
/*#define VAX 1*/ /* VAX Version */
/*#define PDP11 1*/ /* PDP-11 Version*/
#define CPM 1 /* CP/M Operating System*/
/*#define UNIX 1*/ /* UNIX Operating System*/
/*#define VMS 1*/ /* VMS Operating System*/

View File

@@ -0,0 +1,10 @@
/*
* Use this file to determine what kind of machine you want the
* Alcyon stuff to run on ....
*/
/*#define MC68000 1*/ /* 68000 version */
#define VAX 1 /* VAX Version */
/*#define PDP11 1*/ /* PDP-11 Version*/
/*#define CPM 1*/ /* CP/M Operating System*/
/*#define UNIX 1*/ /* UNIX Operating System*/
#define VMS 1 /* VMS Operating System*/

View File

@@ -0,0 +1,98 @@
$1stat machine.h=rw
$1pip machine.h=machine.68k
$1cp68 -i 0$1 ar68.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic ar68.s -l
$1as68 -s 0$1 -f $1 -l -u ar68.s
era $1x.i
era $1x.ic
era $1x.st
era ar68.s
$1cp68 -i 0$1 lo68.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic lo68.s -l
$1as68 -s 0$1 -f $1 -l -u lo68.s
era $1x.i
era $1x.ic
era $1x.st
era lo68.s
$1cp68 -i 0$1 dump.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic dump.s -l
$1as68 -s 0$1 -f $1 -l -u dump.s
era $1x.i
era $1x.ic
era $1x.st
era dump.s
$1cp68 -i 0$1 nm68.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic nm68.s -l
$1as68 -s 0$1 -f $1 -l -u nm68.s
era $1x.i
era $1x.ic
era $1x.st
era nm68.s
$1cp68 -i 0$1 prtobj.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic prtobj.s -l
$1as68 -s 0$1 -f $1 -l -u prtobj.s
era $1x.i
era $1x.ic
era $1x.st
era prtobj.s
$1cp68 -i 0$1 reloc.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic reloc.s -l
$1as68 -s 0$1 -f $1 -l -u reloc.s
era $1x.i
era $1x.ic
era $1x.st
era reloc.s
$1cp68 -i 0$1 sendc68.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic sendc68.s -l
$1as68 -s 0$1 -f $1 -l -u sendc68.s
era $1x.i
era $1x.ic
era $1x.st
era sendc68.s
$1cp68 -i 0$1 size68.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic size68.s -l
$1as68 -s 0$1 -f $1 -l -u size68.s
era $1x.i
era $1x.ic
era $1x.st
era size68.s
$1cp68 -i 0$1 find.c $1x.i
$1c068 $1x.i $1x.ic $1x.st
$1c168 $1x.ic find.s -l
$1as68 -s 0$1 -f $1 -l -u find.s
era $1x.i
era $1x.ic
era $1x.st
era find.s
$1lo68 -f $1 -r -unofloat -s -o lo68.rel 0$1s.o lo68.o 0$1lib6.a 0$1clib
$1lo68 -f $1 -r -unofloat -s -o ar68.rel 0$1s.o ar68.o 0$1lib6.a 0$1clib
$1lo68 -f $1 -r -unofloat -s -o dump.rel 0$1s.o dump.o 0$1clib
$1lo68 -f $1 -r -unofloat -s -o nm68.rel 0$1s.o nm68.o 0$1lib6.a 0$1clib
$1lo68 -f $1 -r -unofloat -s -o prtobj.rel 0$1s.o prtobj.o 0$1lib6.a 0$1clib
$1lo68 -f $1 -r -unofloat -s -o reloc.rel 0$1s.o reloc.o 0$1clib
$1lo68 -f $1 -r -unofloat -s -o sendc68.rel 0$1s.o sendc68.o 0$1lib6.a 0$1clib
$1lo68 -f $1 -r -unofloat -s -o size68.rel 0$1s.o size68.o 0$1lib6.a 0$1clib
$1lo68 -f $1 -r -unofloat -s -o find.rel 0$1w.o find.o 0$1clib
era *.o
user 11!make $1

View File

@@ -0,0 +1,114 @@
#include "cout.h"
#include "sendc68.h"
#define MAGIC1 MAGIC+1
int hdsize=0;
int loctr=0;
int pflg=0;
int syno=0;
int symflg;
extern int fout;
long lseek();
main(argc,argv)
char **argv;
{
long l,l1;
register i,j,k;
if(argc<2) {
printf("Usage: nm68 objectfile\n");
exit();
}
hdsize = HDSIZE;
fout = dup(1);
i = 1;
openfile(argv[i]);
l = couthd.ch_tsize+couthd.ch_dsize+hdsize;
lseek(ibuf.fildes,l,0);
ibuf.nunused = 0;
l1 = couthd.ch_ssize;
syno = 0;
while(l1) {
syno++;
for(i=0; i<8; i++) /* Print Symbol name*/
{
k = getc(&ibuf) & 0377;
if (k < ' ') k = ' '; /* Filter ctrl chars*/
putchar(k);
}
putchar((char)'\t');
j = getw(&ibuf); /*flags*/
l.hiword = getw(&ibuf);
l.loword = getw(&ibuf);
printf("%8lx",l);
prtflags(j);
l1 -= OSTSIZE;
}
myflush();
}
prtflags(af)
{
register f;
f = af;
if(f&SYEQ)
printf(" equ");
if(f&SYGL)
printf(" global");
if(f&SYER)
printf(" reg");
if(f&SYXR)
printf(" external");
if(f&SYDA)
printf(" data");
else if(f&SYTX)
printf(" text");
else if(f&SYBS)
printf(" bss");
else
printf(" abs");
putchar((char)'\n');
}
openfile(ap)
char *ap;
{
register char *p;
p = ap;
if((ibuf.fildes=fopen(p,&ibuf,1)) < 0) {
printf("unable to open %s\n",p);
exit();
}
ifilname = p; /*point to current file name for error msgs*/
if(read(ibuf.fildes,&couthd,2) != 2) {
printf("read error on file: %s\n",ifilname);
exit();
}
ibuf.nunused = 0;
lseek(ibuf.fildes,0L,0);
readhdr(); /*read file header*/
}
readhdr()
{
register int i;
register short *p;
p = &couthd;
for(i=0; i<HDSIZE/2; i++)
*p++ = getw(&ibuf);
if(couthd.ch_magic != MAGIC) {
if(couthd.ch_magic==MAGIC1) {
hdsize =+ 8;
}
else {
printf("file format error: %s\n",ifilname);
exit();
}
}
}

View File

@@ -0,0 +1,116 @@
#include <stdio.h>
#include <klib.h>
#include "cout.h"
#include "sendc68.h"
#define MAGIC1 MAGIC+1
int hdsize=0;
int loctr=0;
int pflg=0;
int syno=0;
int symflg;
extern int fout;
long lseek();
main(argc,argv)
char **argv;
{
long l,l1;
register i,j,k;
if(argc<2) {
printf("Usage: nm68 objectfile\n");
exit();
}
hdsize = HDSIZE;
fout = dup(1);
i = 1;
openfile(argv[i]);
l = couthd.ch_tsize+couthd.ch_dsize+hdsize;
lseek(ibuf.fildes,l,0);
ibuf.nunused = 0;
l1 = couthd.ch_ssize;
syno = 0;
while(l1) {
syno++;
for(i=0; i<8; i++) /* Print Symbol name*/
{
k = getc(&ibuf) & 0377;
if (k < ' ') k = ' '; /* Filter ctrl chars*/
putchar(k);
}
putchar((char)'\t');
j = getw(&ibuf); /*flags*/
l.hiword = getw(&ibuf);
l.loword = getw(&ibuf);
printf("%8lx",l);
prtflags(j);
l1 -= OSTSIZE;
}
}
prtflags(af)
{
register f;
f = af;
if(f&SYEQ)
printf(" equ");
if(f&SYGL)
printf(" global");
if(f&SYER)
printf(" reg");
if(f&SYXR)
printf(" external");
if(f&SYDA)
printf(" data");
else if(f&SYTX)
printf(" text");
else if(f&SYBS)
printf(" bss");
else
printf(" abs");
putchar((char)'\n');
}
openfile(ap)
char *ap;
{
register char *p;
p = ap;
if((ibuf.fildes=fopen(p,&ibuf,1)) < 0) {
printf("unable to open %s\n",p);
exit();
}
ifilname = p; /*point to current file name for error msgs*/
if(read(ibuf.fildes,&couthd,2) != 2) {
printf("read error on file: %s\n",ifilname);
exit();
}
ibuf.nunused = 0;
lseek(ibuf.fildes,0L,0);
readhdr(); /*read file header*/
}
readhdr()
{
register int i;
register short *p;
p = &couthd;
for(i=0; i<HDSIZE/2; i++)
*p++ = getw(&ibuf);
if(couthd.ch_magic != MAGIC) {
if(couthd.ch_magic==MAGIC1) {
hdsize =+ 8;
}
else {
printf("file format error: %s\n",ifilname);
exit();
}
}
}

View File

@@ -0,0 +1,76 @@
#include "cout.h"
long lseek();
main(argc,argv)
int argc;
char **argv;
{
register i,j,c,d;
long symseek; /* Symbol table seek addr */
int symlength; /* Symbol length (bytes) */
char symbuf[30000]; /* Symbol table buffer */
int fd; /* File descriptor */
if((fd=open(argv[1],2,1)) < 0) /* Open input file */
{
printf("Cannot open %s\n",argv[1]); /* Can't */
exit(); /* Just quit */
} /****************************/
if((i=read(fd,&couthd,HDSIZE)) != HDSIZE) /* Read file header */
{ /* Can't */
printf("Header read error\n"); /* Print message */
exit(); /* Then quit */
} /****************************/
symseek=couthd.ch_tsize+couthd.ch_dsize+HDSIZE;
if(couthd.ch_magic != MAGIC)
{
if(couthd.ch_magic == (MAGIC+1))
{
symseek += 8;
}
else
{
printf("File format error\n");
exit();
}
}
symlength = lseek(fd,symseek,0); /* Seek to sym begin */
if(symlength != symseek) /* OK? */
{
printf("Seek error\n"); /*No, quit */
exit(); /* */
}
symlength = couthd.ch_ssize; /* Fetch symbol length */
if(read(fd,&symbuf[0],symlength) != symlength)
{
printf("Symbol table read error\n");
}
for(i=0; i < symlength; i+=14)
{
for(j=0; j < 8; j+=2)
{
c = symbuf[j+i];
d = symbuf[j+i+1];
symbuf[j+i] = d;
symbuf[j+i+1] = c;
}
}
if(lseek(fd,symseek,0) != symseek)
{
printf("Seek error\n");
exit();
}
if(write(fd,&symbuf[0],symlength) != symlength)
{
printf("Symbol table write error\n");
exit();
}
close(fd);
exit(0);
}

View File

@@ -0,0 +1,54 @@
/*****************************************************************************
*
* C P / M C R U N T I M E L I B H E A D E R F I L E
* -------------------------------------------------------------
* Copyright 1982 by Digital Research Inc. All rights reserved.
*
* This is an include file for assisting the user to write portable
* programs for C.
*
*****************************************************************************/
#define ALCYON 1 /* using Alcyon compiler */
/*
* Standard type definitions
*/
/***************************/
#define BYTE char /* Signed byte */
#define BOOLEAN char /* 2 valued (true/false) */
#define WORD short /* Signed word (16 bits) */
#define UWORD unsigned int /* unsigned word */
#define LONG long /* signed long (32 bits) */
#define ULONG unsigned long /* Unsigned long */
#define REG register /* register variable */
#define LOCAL auto /* Local var on 68000 */
#define EXTERN extern /* External variable */
#define MLOCAL static /* Local to module */
#define GLOBAL /**/ /* Global variable */
#define VOID /**/ /* Void function return */
#define DEFAULT int /* Default size */
#define FLOAT float /* Floating point */
#define DOUBLE double /* Double precision */
/***************************/
#ifdef ALCYON
#define UBYTE char
#else
#define UBYTE unsigned char /* Unsigned byte */
#endif
/****************************************************************************/
/* Miscellaneous Definitions: */
/****************************************************************************/
#define FAILURE (-1) /* Function failure return val */
#define SUCCESS (0) /* Function success return val */
#define YES 1 /* "TRUE" */
#define NO 0 /* "FALSE" */
#define FOREVER for(;;) /* Infinite loop declaration */
#define NULL 0 /* Null pointer value */
#define ZERO 0 /* Zero value */
#define EOF (-1) /* EOF Value */
#define TRUE (1) /* Function TRUE value */
#define FALSE (0) /* Function FALSE value */
/*************************** end of portab.h ********************************/

View File

@@ -0,0 +1,183 @@
#include "cout.h"
#include "lo68.h"
#define LIBMAGIC 0177545
int loctr=0;
int pflg=0;
int syno=0;
int symflg=0;
extern int fout;
char *reloc[] {
"DABS",
"DRELOC",
"TRELOC",
"BRELOC",
"EXTVAR",
"LUPPER",
"NOTUSED",
"INSABS" };
long lseek();
main(argc,argv)
char **argv;
{
long l,l1;
register i,j;
if(argc<2) {
printf("Usage: prtobj [-] objectfile\n");
exit();
}
fout = dup(1);
i = 1;
if(*argv[1] == '-') {
i++;
symflg++;
}
pass2 = 1;
openfile(argv[i]);
if(couthd.ch_rlbflg == 0) { /*relocation bits there*/
l = couthd.ch_tsize+couthd.ch_dsize+couthd.ch_ssize+HDSIZE; /*ptr to relocation bits*/
longseek(l,&rbuf,0);
}
printf("file name: %s\n",argv[i]);
l = couthd.ch_tsize;
printf("text size = %9ld = %08lx hex\n",l,l);
l = couthd.ch_dsize;
printf("data size = %9ld = %08lx hex\n",l,l);
l = couthd.ch_bsize;
printf("bss size = %9ld = %08lx hex\n",l,l);
l = couthd.ch_ssize;
printf("symbol size = %9ld = %08lx hex\n",l,l);
l = couthd.ch_stksize;
printf("stack size = %9ld = %08lx hex\n",l,l);
loctr = couthd.ch_entry;
printf("entry point = %9ld = %08lx hex\n",loctr,loctr);
if(symflg) {
l = couthd.ch_tsize+couthd.ch_dsize+HDSIZE;
longseek(l,&ibuf,0);
goto dosyms;
}
l1 = couthd.ch_tsize;
printf("TEXT:\n");
mloop:
for(l=0; l<l1; l=+ 2) {
i = getw(&ibuf);
if(couthd.ch_rlbflg==0)
j = getw(&rbuf);
else
j = DABS;
printf("%08x %04x %s",loctr,((int)i)&0xffff,reloc[j&7]);
if((j&7) == EXTVAR)
printf(" ext# %5d\n",(j>>3)&017777);
else
putchar('\n');
loctr =+ 2;
}
if(pflg==0) {
printf("\nDATA:\n");
l1 = couthd.ch_dsize;
pflg++;
goto mloop;
}
dosyms:
printf("\nSYMBOLS:\n");
l1 = couthd.ch_ssize;
syno = 0;
while(l1) {
printf("%4d ",syno);
syno++;
for(i=0; i<8; i++)
putchar((int)getc(&ibuf)); /*symbol name*/
putchar((int)'\t');
j = getw(&ibuf); /*flags*/
l.hiword = getw(&ibuf);
l.loword = getw(&ibuf);
printf("%04x%04x",((int)l.hiword)&0xffff,
((int)l.loword)&0xffff);
prtflags(j);
l1 =- OSTSIZE;
}
}
prtflags(af)
{
register f;
f = af;
if(f&SYEQ)
printf(" equ");
if(f&SYGL)
printf(" global");
if(f&SYER)
printf(" equreg");
if(f&SYXR)
printf(" external");
if(f&SYDA)
printf(" data");
else if(f&SYTX)
printf(" text");
else if(f&SYBS)
printf(" bss");
else
printf(" abs");
putchar((int)'\n');
}
openfile(ap)
char *ap;
{
register char *p;
p = ap;
if((ibuf.fildes=open(p,0,1)) < 0) {
printf("unable to open %s\n",p);
exit();
}
ifilname = p; /*point to current file name for error msgs*/
if(read(ibuf.fildes,&couthd,2) != 2) {
printf("read error on file: %s\n",ifilname);
exit();
}
ibuf.nunused = 0;
if(couthd.ch_magic != LIBMAGIC) {
lseek(ibuf.fildes,0L,0);
readhdr(); /*read file header*/
}
if(pass2) { /*need file descrptr for reloc bits*/
rbuf.fildes = open(p,0,1);
rbuf.nunused = 0;
}
}
readhdr()
{
register int i;
register short *p;
p = &couthd;
for(i=0; i<HDSIZE/2; i++)
*p++ = getw(&ibuf);
if(couthd.ch_magic != MAGIC) {
printf("file format error: %s\n",ifilname);
exit();
}
}
longseek(al,bp,pn)
long al;
struct buf *bp;
{
long lseek();
if(lseek(bp->fildes,al,pn) < 0)
{
printf("Seek error on %s\n",ifilname);
exit();
}
bp->nunused = 0; /*input buff empty*/
}

View File

@@ -0,0 +1,434 @@
/****************************************************************************/
/* */
/* R e l o c P r o g r a m */
/* ------------------------- */
/* */
/* This program is used to relocate an Alcyon format load module into */
/* an absolute module using the minimum disk space possible. The */
/* relocation information, symbol table, and trailing zeros in the */
/* data segment are deleted. */
/* */
/* Invokation: */
/* */
/* A>reloc -bhhhhhh in.68k out.68k */
/* */
/* Where: */
/* hhhhhh Is the desired new base address (TPA + 100) in hex */
/* in.68k Is the input file */
/* out.68k Is the output file */
/* */
/****************************************************************************/
#include <stdio.h>
#include <ctype.h>
/****************************************************************************/
/* */
/* The following code defines the organization of a "long" variable on */
/* either the VAX (11) or 68000. This allows us to use "getw" on the */
/* separate parts of the long and to recombine them for 32-bit */
/* arithmetic operations. */
/* */
/****************************************************************************/
#include "machine.h"
#ifdef UNIX
#include <portab.h>
#endif
#ifdef VAX /****************************/
struct { /* low word first on VAX */
WORD loword; /* */
WORD hiword; /* */
}; /****************************/
#endif
#ifdef PDP11 /****************************/
struct { /* low word first on PDP11 */
WORD loword; /* */
WORD hiword; /* */
}; /****************************/
#endif
#ifdef MC68000 /****************************/
struct { /* */
WORD hiword; /* High word first on 68K */
WORD loword; /* */
}; /****************************/
#endif
#ifdef UNIX /****************************/
#define fopenb fopen /* Not in UNIX library */
#endif /****************************/
/****************************************************************************/
/* */
/* Relocation bit definitions */
/* */
/* Note that this program is intended only for load module files. Any */
/* references to external symbols or relative references are illegal. */
/* */
/****************************************************************************/
/* */
#define DABS 0 /* Data absolute */
#define DRELOC 1 /* Data segment relative */
#define TRELOC 2 /* Text segment relative */
#define BRELOC 3 /* BSS segment relative */
#define EXTVAL 4 /* External variable */
#define LUPPER 5 /* Upper word of long */
#define EXTREL 6 /* External relative symbol */
#define INSABS 7 /* 1st word of instruction */
/****************************/
/****************************************************************************/
/* */
/* G l o b a l D a t a */
/* */
/****************************************************************************/
/* */
BYTE *ifname=0; /* -> Input filename */
BYTE *ofname=0; /* -> Output filename */
LONG base=0; /* New relocation base */
FILE *fopenb(); /* File open procedure */
LONG ftell(); /* File offset procedure */
#ifdef CPM /* Only defined with CP/M */
EXTERN BYTE _start; /* Start of program */
#endif /* */
/****************************/
#include "cout.h" /* Output header area */
/****************************/
/****************************************************************************/
/* */
/* M a i n P r o c e d u r e */
/* --------------------------- */
/* */
/* Here we get things started: */
/* */
/* 1). Get relocation base */
/* 2). Open input and output files */
/* 3). Determine data area (new) size */
/* */
/* Any errors here are fatal, and cause program termination. */
/* */
/****************************************************************************/
VOID main(argc,argv)
/****************************/
DEFAULT argc; /* Int var from RTL startup */
BYTE **argv; /* -> Arg strings */
{ /****************************/
REG LONG i,l; /* Temps */
REG FILE *ifp,*ofp,*rfp; /* File pointers */
/* */
if(argc != 4 && argc != 3) /* Gotta have right format */
usage(); /* Print out nasty message */
/****************************/
if(argc == 4) /* "-bxxxx" form */
{ /****************************/
if(decode(argv[1], &base) == FAILURE) /* Convert to binary */
{ /* */
printf("Illegal option: %s\n", /* Print offending option */
argv[1]); /* */
usage(); /* Print reminder messages */
} /****************************/
ifname = argv[2]; /* -> Input file name */
ofname = argv[3]; /* -> Output file name */
} else /* Default form */
{ /* */
#ifdef CPM /* On CP/M, */
base = &_start; /* Use start of reloc itself*/
#else /****************************/
base = 0x500; /* 500H is default */
#endif /* */
ifname = argv[1]; /* -> Input filename */
ofname = argv[2]; /* -> Output filename */
} /****************************/
/* */
if((base & 1) != 0) /* In range? */
{ /* no */
printf("Illegal base address=%lx\n", /* print */
base); /* message */
exit(-1); /* And quit */
} /****************************/
/* */
if((ifp=fopenb(ifname,"r")) == NULL) /* Try to open input */
{ /* */
printf("Cannot open %s\n",ifname); /* Complain */
exit(-1); /* & quit */
} /****************************/
/* */
if((ofp=fopenb(ofname,"w")) == NULL) /* Try to create output */
{ /* */
printf("Cannot create %s\n",ifname); /* Complain */
exit(-1); /* & quit */
} /****************************/
/****************************************************************************/
/* */
/* Now read the file header and compute the new data segment size ... */
/* */
/****************************************************************************/
/* */
i = fread(&couthd,1,(sizeof couthd), /* Do the read */
ifp); /* */
if(i != (sizeof couthd)) /* Did it work?? */
{ /* */
printf("Read error on %s\n",ifname); /* No, complain */
exit(-1); /* and quit */
} /****************************/
/* */
if(couthd.ch_magic != MAGIC) /* Valid file? */
{ /* */
printf("File format error: %s\n", /* Print nasty message */
ifname); /* */
exit(-1); /* Quit */
} /****************************/
/* */
l = couthd.ch_tsize + sizeof couthd; /* Seek address for data */
fseek(ifp,l,0); /* Seek to data start */
/* */
i = couthd.ch_dsize; /* Fetch data size */
l = ftell(ifp); /* l <= new data end addr */
/* */
while (i > 0) /* Until all data examined */
{ /* */
if(getw(ifp) != 0) /* This data word = 0? */
l = ftell(ifp); /* No, record seek address */
i -= 2; /* Down count */
} /****************************/
/****************************************************************************/
/* */
/* Open the file a second time, and perform the proper seeks to align */
/* one copy of the open file to the beginning of the text segment, and */
/* the other copy to the beginning of the relocation information */
/* */
/****************************************************************************/
/* */
if((rfp=fopenb(ifname,"r")) == NULL) /* Try to open again */
{ /* */
printf("Cannot re-open %s\n",ifname); /* Print nasty message */
exit(-1); /* and quit */
} /****************************/
fseek(ifp,(LONG)(sizeof couthd),0); /* Seek to text beginning */
fseek(rfp,(LONG)(sizeof couthd) + /* Seek to */
couthd.ch_tsize+couthd.ch_dsize + /* relocation */
couthd.ch_ssize, 0); /* info*/
/****************************/
reloc(ifp,rfp,ofp,l); /* Do relocation */
} /****************************/
/****************************************************************************/
/* */
/* U s a g e F u n c t i o n */
/* --------------------------- */
/* */
/* Routine "usage" is used to print out an error message when the */
/* program is invoked in an improper manner. */
/* */
/* Calling Sequence: */
/* */
/* usage(); */
/* */
/* No return is made, "exit()" is called to go back to the O/S. */
/* */
/****************************************************************************/
VOID usage()
{
printf("Usage: reloc [-bhhhhhh] input output\n");
printf(" where: hhhhhh is new base address\n");
printf(" (TPA+100 is default base address)\n");
printf(" input is relocatable file\n");
printf(" output is absolute file\n");
exit(-1);
}
/****************************************************************************/
/* */
/* D e c o d e F u n c t i o n */
/* ------------------------------ */
/* */
/* Routine "decode" is called to process the relocation base argument */
/* from the command line. */
/* */
/* Calling sequence: */
/* */
/* ret = decode(string,&address); */
/* */
/* Where: */
/* string -> argument string (usually argv[1]) */
/* &address -> long word to receive converted value */
/* */
/* ret = 0 if successful conversion */
/* = -1 if anything amiss */
/* */
/****************************************************************************/
WORD decode(string,addr) /* */
/* */
REG BYTE *string; /* -> Command argument */
LONG *addr; /* = return value */
{ /****************************/
REG LONG a; /* Temp return value */
REG BYTE c; /* Temp character */
/* */
if(*string++ != '-' || *string++ != 'b')/* Check for valid switch */
return(FAILURE); /* quit if NFG */
/* */
a = 0; /* Zero out accumulator */
/* */
while(*string) /* Until no more chars */
{ /* */
c = *string & 0177; /* Pick up next char */
if (c >= '0' && c <= '9') /* Digit */
a = (a << 4) + c - '0'; /* Un-ASCIIfy */
else if (c >= 'A' && c <= 'F') /* Hex */
a = (a << 4) + c - 'A'+ 10; /* Un-ASCIIfy */
else if (c >= 'a' && c <= 'f') /* Lower case hex */
a = (a << 4) + c - 'a'+ 10; /* Un-ASCII it */
else /* Bad character */
return(FAILURE); /* So long, sucker!! */
string++; /* Increment pointer */
} /* */
*addr = a; /* Store result */
return(SUCCESS); /* Return all ok */
} /****************************/
/****************************************************************************/
/* */
/* R e l o c F u n c t i o n */
/* --------------------------- */
/* */
/* Function "reloc" is called to perform the relocation operation and */
/* write the output file simultaneously. */
/* */
/* Calling Sequence: */
/* */
/* reloc(ifp,rfp,ofp,length); */
/* */
/* Where: */
/* */
/* ifp Is the input stream pointer (positioned at text) */
/* rfp Is a stream pointer positioned at relocation bits */
/* ofp Is a stream pointer for the output file */
/* length Is the total length of the output file */
/* */
/****************************************************************************/
VOID reloc(ifp,rfp,ofp,length) /* */
/* */
REG FILE *ifp; /* -> Text information */
REG FILE *rfp; /* -> Relocation info */
REG FILE *ofp; /* -> Output file */
LONG length; /* = # bytes in the file */
{ /****************************/
struct hdr x; /* Duplicate header */
REG LONG bytes; /* File offset */
LONG j; /* Temp for long relocation */
REG WORD r; /* Relocation word */
REG WORD k; /* Temp data word */
WORD longf; /* Long relocation flag */
WORD z; /* Temp for error codes */
LONG bias; /* Relocation bias */
/* */
bias = base - couthd.ch_entry; /* Compute relocation bias */
/* */
/************************************************* */
/* */
/* Prepare and write the new file header in structure "x". */
/* */
/************************************************* */
/* */
x.ch_magic = MAGIC; /* Magic word */
x.ch_tsize = couthd.ch_tsize; /* Text size */
j = sizeof couthd + couthd.ch_tsize + /* Compute number of bytes */
couthd.ch_dsize - length; /* moved from data to bss */
x.ch_dsize = couthd.ch_dsize - j; /* New data size */
x.ch_bsize = couthd.ch_bsize + j; /* New bss size */
x.ch_ssize = 0; /* No symbols */
x.ch_stksize = 0; /* No stack */
x.ch_entry = base; /* New base address */
x.ch_rlbflg = -1; /* No relocation bits */
/****************************/
if(fwrite(&x,1,sizeof x,ofp) != /* Do the write */
sizeof x) /* */
{ /* Here if failed */
printf("Write error on %s\n",ofname); /* print message */
exit(-1); /* Quit */
} /****************************/
/****************************************************************************/
/* */
/* Here begins the actual file relocation procedure. Read a word */
/* from the relocation bits and from the file together. If long, */
/* read another word from each. Perform indicated relocation. */
/* */
/****************************************************************************/
/* */
bytes = 0; /* No bytes written yet ... */
length -= sizeof(couthd); /* Just program, please... */
while (bytes < length) /* until we are done */
{ /****************************/
k = getw(ifp); /* get next text/data word */
r = getw(rfp); /* get next relocation word */
/****************************/
if ((r & ~7) != 0) /* Check for validity */
badrel(r,bytes); /* Not valid, quit */
/* */
if(r == LUPPER) /* Doing a long? */
{ /* */
j.hiword = k; /* Yes, get another word */
j.loword = getw(ifp); /* From both */
r = getw(rfp); /* streams */
longf = 2; /* Set flag */
} /****************************/
else /* Not a long */
{ /* */
j.loword = k; /* Put in low order word */
j.hiword = 0; /* Make top part 0 */
longf = 0; /* Clear flag */
} /****************************/
switch (r) /* Now do indicated reloc */
{ /* */
case TRELOC: /* If relocatable, */
case DRELOC: /* relocate */
case BRELOC: /* */
j += bias; /* Add in bias */
case DABS: /* If not relocatable, */
case INSABS: /* don't */
break; /****************************/
default: /* Any others illegal */
badrel(r,bytes); /* Print message */
} /****************************/
if(longf == 0 && j.hiword !=0) /* 16-bit overflow? */
{ /* */
printf("16-bit overflow at %ld\n", /* Print out message */
bytes); /* with offset */
exit(-1); /* */
} /****************************/
if(longf != 0) /* Long? */
putw(j.hiword,ofp); /* yes, output high */
#ifndef UNIX /* A bug in UNIX RTL!! */
if((z=putw(j.loword,ofp)) != j.loword) /* Check for write error */
{ /* */
printf("Write error on %s ",ofname); /* Had one, */
printf("Offset = %lx data= %x err =%x\n", /* */
bytes,j.loword,z); /* Print out message */
exit(-1); /* & quit */
} /****************************/
#else /* Just output and pray... */
putw(j.loword,ofp); /* Output low word */
#endif /****************************/
bytes += 2 + longf; /* Increment byte count */
/* */
} /* End while loop */
} /* End reloc procedure */
/****************************/
VOID badrel(r,offset) /* Print bad reloc message */
/* */
WORD r; /* Relocation bits */
LONG offset; /* File offset */
{ /****************************/
printf("Illegal reloc = %x at %lx\n", /* Print error message */
r,offset); /* */
exit(-1); /* quit */
} /****************************/

View File

@@ -0,0 +1,36 @@
E:SEND STDIO.H
E:SEND MACHINE.H
E:SEND AR68.C
E:SEND DUMP.C
E:SEND GREP.C
E:SEND LIBFIX.C
E:SEND LO68.C
E:SEND LO68INIT.C
E:SEND NM68.C
E:SEND NUXI.C
E:SEND PRTOBJ.C
E:SEND RELOC.C
E:SEND SENDC68.C
E:SEND SIZE68.C
E:SEND TEST.C
E:SEND AR.H
E:SEND COUT.H
E:SEND IOBUF.H
E:SEND LO68.H
E:SEND SENDC68.H
E:SEND MAKE.SUB
E:SEND MACHINE.11
E:SEND MACHINE.68K
E:SEND MACHINE.VAX
E:SEND N.C
E:SEND BASEPAGE.H
E:SEND SGTTY.H
E:SEND SETJMP.H
E:SEND SIGNAL.H
E:SEND CTYPE.H
E:SEND ERRNO.H
E:SEND PORTAB.H
E:SEND CPM.H
E:SEND KLIB.H
E:SEND BDOS.H
E:SEND SEND10.SUB

View File

@@ -0,0 +1,213 @@
#include <stdio.h>
#include <klib.h>
#include "cout.h"
#include "sendc68.h"
/* this program reads a c.out format binary file and converts*/
/* it to the absolute ASCII load format acceptable by MACSBUG*/
/* and then sends it down the standard output file*/
#define MAGIC1 MAGIC+1
long lseek();
long datastart=0;
long bssstart=0;
long loctr=0;
extern int fout;
int pflg=0;
#define RBLEN 32 /*number of bytes per S1 record*/
int bcnt=RBLEN;
char cksum=0;
int syno=0;
char *ofn=0;
int ofd=0;
int noclear=0;
main(argc,argv)
char **argv;
{
long l,l1;
register i,j;
if(argc < 2 || argc > 3) {
usage();
}
i = 1;
if(*argv[1] == '-') {
noclear++;
i++;
}
openfile(argv[i++]);
if(argc>i) {
usage();
}
else {
ofd = dup(1); /*standard output file*/
}
fout = ofd; /*use buffered output*/
l1 = couthd.ch_tsize;
loctr = couthd.ch_entry;
mloop:
for(l=0; l<l1; l=+ 2) {
i = getw(&ibuf);
outword(i);
loctr =+ 2;
}
if(couthd.ch_magic==MAGIC1) {
while(bcnt != RBLEN) /*fill out the last S1 buffer*/
outword(0);
loctr = datastart;
}
l1 = couthd.ch_dsize;
for(l=0; l<l1; l=+ 2) {
i = getw(&ibuf);
outword(i);
loctr =+ 2;
}
if(noclear==0) {
if(couthd.ch_magic==MAGIC1) {
while(bcnt != RBLEN) /*fill out the last S1 buffer*/
outword(0);
loctr = bssstart;
}
l1 = couthd.ch_bsize; /*size of bss*/
while(l1 > 0) {
outword(0); /*clear the bss*/
l1 =- 2;
loctr =+ 2;
}
}
while(bcnt != RBLEN) /*fill out the last S1 buffer*/
outword(0);
printf("S9030000FC\n");
}
openfile(ap)
char *ap;
{
register char *p;
p = ap;
if((ibuf.fildes=open(p,0,1)) < 0) {
printf("unable to open %s\n",p);
exit();
}
ifilname = p; /*point to current file name for error msgs*/
if(read(ibuf.fildes,&couthd,2) != 2) {
printf("read error on file: %s\n",ifilname);
exit();
}
ibuf.nunused = 0;
lseek(ibuf.fildes,0L,0);
readhdr(); /*read file header*/
}
readhdr()
{
register int i;
register short *p;
p = &couthd;
for(i=0; i<HDSIZE/2; i++)
*p++ = getw(&ibuf);
if(couthd.ch_magic != MAGIC) {
if(couthd.ch_magic==MAGIC1) {
#ifdef VAX
datastart.loword = getw(&ibuf);
datastart.hiword = getw(&ibuf);
bssstart.loword = getw(&ibuf);
bssstart.hiword = getw(&ibuf);
#endif
#ifdef PDP11
datastart.loword = getw(&ibuf);
datastart.hiword = getw(&ibuf);
bssstart.loword = getw(&ibuf);
bssstart.hiword = getw(&ibuf);
#endif
#ifdef MC68000
datastart.hiword = getw(&ibuf);
datastart.loword = getw(&ibuf);
bssstart.hiword = getw(&ibuf);
bssstart.loword = getw(&ibuf);
#endif
}
else {
printf("file format error: %s\n",ifilname);
exit();
}
}
}
longseek(al,bp,pn)
long al;
struct buf *bp;
{
if(lseek(bp->fildes,al,0) < 0) {
printf("seek error on file %s\n",ifilname);
exit();
}
bp->nunused = 0; /*input buff empty*/
}
outword(i)
register i;
{
if(bcnt==RBLEN) { /*beginning of record*/
cksum = 0;
if(loctr.hiword) {
printf("S2");
hexby(RBLEN+4);
hexby(loctr.hiword);
}
else {
printf("S1");
hexby(RBLEN+3); /*byte count*/
}
hexwd(loctr.loword);
}
hexwd(i);
bcnt =- 2;
if(bcnt==0) {
hexby(-cksum-1);
putchar('\n');
bcnt = RBLEN;
}
}
hexwd(i)
{
hexby((i>>8)&0xff);
hexby(i&0xff);
}
hexby(c)
{
cksum =+ c;
outhex((c>>4)&017);
outhex(c&017);
}
outhex(x)
{
if(x>=0 && x<=9)
putchar(x+'0');
else if(x>=10 && x<=15)
putchar(x-10+'A');
else
exit();
}
usage()
{
printf("Usage: sendc68 [-] commandfile [>outputfile]\n");
exit();
}

View File

@@ -0,0 +1,87 @@
/* format of a symbol entry in the main table*/
#include "machine.h"
#define SEEKREL 1 /*relative seek flag*/
#define OSTSIZE 14 /*symbol table entry length on object file*/
/* without table link*/
# define STESIZE 18 /*byte length of symbol table entry*/
struct symtab {
char name[8]; /*symbol name*/
short flags; /*bit flags*/
long vl1; /*symbol value*/
char *tlnk; /*table link*/
};
struct symtab *symptr;
/* flags for symbols*/
# define SYDF 0100000 /*defined*/
# define SYEQ 0040000 /*equated*/
# define SYGL 0020000 /*global - entry or external*/
# define SYER 0010000 /*equated register*/
# define SYXR 0004000 /*external reference*/
# define SYDA 0002000 /*DATA based relocatable*/
# define SYTX 0001000 /*TEXT based relocatable*/
# define SYBS 0000400 /*BSS based relocatable*/
struct irts {
char *irle; /*ptr to last entry in chain*/
char *irfe; /*ptr to first entry in chain*/
};
#ifdef VAX
struct {
short loword;
short hiword;
};
#endif
#ifdef PDP11
struct {
short loword;
short hiword;
};
#endif
#ifdef MC68000
struct {
short hiword;
short loword;
};
#endif
#ifdef VAX
struct {
char lobyte;
char hibyte;
};
#endif
#ifdef PDP11
struct {
char lobyte;
char hibyte;
};
#endif
#ifdef MC68000
struct {
char hibyte;
char lobyte;
};
#endif
/* relocation bit definitions:*/
#define RBMASK 07 /*tells type of relocation*/
#define INSABS 7 /*first word of instr -- absolute*/
#define DABS 0 /*data word absolute*/
#define TRELOC 2 /* TEXT relocatable*/
#define DRELOC 1 /* DATA relocatable*/
#define BRELOC 3 /* BSS relocatable*/
#define EXTVAR 4 /* ref to external variable*/
#define LUPPER 5 /* upper word of long*/
struct buf{
int fildes;
int nunused;
char *xfree;
char buff[512];
};
struct buf ibuf={0};
char *ifilname=0;

View File

@@ -0,0 +1,35 @@
/****************************************************************************/
/* */
/* L o n g j u m p H e a d e r F i l e */
/* --------------------------------------- */
/* */
/* Copyright 1982 by Digital Research. All rights reserved. */
/* */
/* Long jumps on the 68K are implemented as follows: */
/* */
/* 1). Routine "setjmp" is called to setup a special */
/* buffer for return. The return address, stack */
/* pointer and frame pointer are saved. This allows */
/* the calling program to do the proper number of */
/* "pops". */
/* */
/* 2). At some later time, the procedure "longjmp" is */
/* called. The programmer sees a return from the */
/* previous "setjmp" as the result. */
/* */
/* Calling sequence: */
/* */
/* #include <setjmp.h> (definitions) */
/* jmp_buf env; (define a buffer for saved stuff) */
/* */
/* setjmp(env); */
/* a: */
/* */
/* longjmp(env,val); */
/* */
/* Setjmp returns a WORD of 0 on first call, and "val" on the */
/* subsequent "longjmp" call. The longjmp call causes execution to */
/* resume at "a:" above. */
/* */
/****************************************************************************/
typedef LONG jmp_buf[3];

View File

@@ -0,0 +1,14 @@
/* sgtty.h - tty control information */
/* Note reduced contents for CP/M implementation... */
struct sgttyb{
char sg_ispeed; /* ignored */
char sg_ospeed; /* ignored */
char sg_erase; /* ignored */
char sg_kill; /* ignored */
int sg_flags;
};
#define RAW 0000040
#define CRMOD 0000020
#define ECHO 0000010
#define LCASE 0000004
#define CBREAK 0000002

View File

@@ -0,0 +1,32 @@
/****************************************************************************/
/* */
/* S i g n a l H e a d e r F i l e */
/* ----------------------------------- */
/* */
/* Copyright 1982 by Digital Research, Inc. All rights reserved. */
/* */
/* Define the "signal" arguments, so anyone using the function will */
/* not get compile-time errors. Some functions are not implemented. */
/* */
/****************************************************************************/
#define NSIG 16 /* 16 simulated signals */
#define SIGHUP 1 /* Hangup */
#define SIGINT 2 /* Interrupt (^C) */
#define SIGQUIT 3 /* Quit signal */
#define SIGILL 4 /* Illegal Instruction trap */
#define SIGTRAP 5 /* Trace Trap */
#define SIGIOT 6 /* IOT instruction (on PDP-11) */
#define SIGEMT 7 /* EMT instruction (TRAP on 68k) */
#define SIGFPE 8 /* Floating point exception */
#define SIGKILL 9 /* Kill (cannot be intercepted) */
#define SIGBUS 10 /* BUSERR (non-ex memory reference) */
#define SIGSEGV 11 /* Segmentation (MMU) violation */
#define SIGSYS 12 /* Bad argument to system call */
#define SIGPIPE 13 /* Write on a broken pipe */
#define SIGALRM 14 /* Alarm clock (what a name!) */
#define SIGTERM 15 /* Software termination signal */
/************************************/
#define BADSIG (-1L) /* Error return */
#define SIG_DFL (0L) /* Default action on signal call */
#define SIG_IGN (1L) /* Ignore */
/************************************/

View File

@@ -0,0 +1,105 @@
#include <stdio.h>
#include <klib.h>
#include "cout.h"
#define MAGIC1 MAGIC+1
int fd=0;
char *fn = {"c.out"};
main(argc,argv)
char **argv;
{
register i,j;
long l;
i = 1;
if(argc<2)
goto dodef;
for(i=1; i<argc; i++) {
fn = argv[i];
dodef:
if((fd=open(fn,0,1)) < 0) {
printf("unable to open %s\n",fn);
exit();
}
if((j=read(fd,&couthd,HDSIZE)) != HDSIZE) {
printf("read error on %s\n",fn);
exit();
}
if(couthd.ch_magic!=MAGIC && couthd.ch_magic!=MAGIC1) {
printf("File format error: %s\n",fn);
exit();
}
printf("%s:",fn);
l = couthd.ch_tsize+couthd.ch_dsize+couthd.ch_bsize;
ldec(couthd.ch_tsize);
putchar('+');
ldec(couthd.ch_dsize);
putchar('+');
ldec(couthd.ch_bsize);
putchar('=');
ldec(l);
printf(" (");
lhex(l);
printf(" ) stack size = ");
ldec(couthd.ch_stksize);
putchar('\n');
if(couthd.ch_magic == MAGIC1) {
read(fd,&l,4);
printf("data start=");
lhex(l);
read(fd,&l,4);
printf(" bss start=");
lhex(l);
putchar('\n');
}
}
}
char ostr[80] = {0};
lhex(al)
long al;
{
register i;
register char *p;
register j;
p = &ostr[80];
*--p = 0;
for(i=0; i<8; i++) {
j = al&017;
if(j<10)
j =+ '0';
else
j =+ 'A'-10;
*--p = j;
al =>> 4;
if(al == 0)
break;
}
printf("%s",p);
}
ldec(al)
long al;
{
register i;
register char *p;
register j;
p = &ostr[80];
*--p = 0;
for(i=0; i<10; i++) {
j = al%10;
j =+ '0';
*--p = j;
al =/ 10;
if(al == 0)
break;
}
printf("%s",p);
}

View File

@@ -0,0 +1,68 @@
/*****************************************************************************
*
* C P / M C H E A D E R F I L E
* -----------------------------------
* Copyright 1982 by Digital Research Inc. All rights reserved.
*
* This is the standard include file for the CP/M C Run Time Library.
*
*****************************************************************************/
/* */
#include <portab.h> /* Portability Definitions */
/* */
/****************************************************************************
* Stream I/O File Definitions
*****************************************************************************/
#define BUFSIZ 512 /* Standard (ascii) buf size */
#define MAXFILES 16 /* Max # open files ( < 32 ) */
struct _iobuf { /* */
WORD _fd; /* file descriptor for low level io */
WORD _flag; /* stream info flags */
BYTE *_base; /* base of buffer */
BYTE *_ptr; /* current r/w pointer */
WORD _cnt; /* # chars to be read/have been wrt */
}; /* */
#ifndef FILE /* conditionally include: */
extern struct _iobuf _iob[MAXFILES]; /* an array of this info */
#define FILE struct _iobuf /* stream definition */
#endif /************************************/
/* flag byte definition */
#define _IOREAD 0x01 /* readable file */
#define _IOWRT 0x02 /* writeable file */
#define _IOABUF 0x04 /* alloc'd buffer */
#define _IONBUF 0x08 /* no buffer */
#define _IOERR 0x10 /* error has occurred */
#define _IOEOF 0x20 /* EOF has occurred */
#define _IOLBUF 0x40 /* handle as line buffer */
#define _IOSTRI 0x80 /* this stream is really a string */
#define _IOASCI 0x100 /* this was opened as an ascii file */
/************************************/
#define stdin (&_iob[0]) /* standard input stream */
#define stdout (&_iob[1]) /* " output " */
#define stderr (&_iob[2]) /* " error " */
/************************************/
#define clearerr(p) ((p)->_flag & ~_IOERR) /* clear error flag */
#define feof(p) ((p)->_flag & _IOEOF) /* EOF encountered on stream */
#define ferror(p) ((p)->_flag & _IOERR) /* error encountered on stream */
#define fileno(p) ((p)->_fd) /* get stream's file descriptor */
#define getchar() getc(stdin) /* get char from stdin */
#define putchar(c) putc(c,stdout) /* put char to stdout */
#define putc fputc
#define getc fgetc
/****************************************************************************/
/* */
/* M A C R O S */
/* ----------- */
/* */
/* Define some stuff as macros .... */
/* */
/****************************************************************************/
#define abs(x) ((x) < 0 ? -(x) : (x)) /* Absolute value function */
#define max(x,y) (((x) > (y)) ? (x) : (y)) /* Max function */
#define min(x,y) (((x) < (y)) ? (x) : (y)) /* Min function */
/*************************** end of stdio.h *********************************/

View File

@@ -0,0 +1,24 @@
$ linker
$ set noon
$ !
$ ! lo68 and utilities build file for VMS
$ !
$ copy machine.vax machine.h
$ purge machine.h
$ cx ar68
$ cx lo68
$ cx lo68init
$ cx dump
$ cx nm68
$ cx prtobj
$ cx reloc
$ cx sendc68
$ cx size68
$ clink ar68,lib:klib/lib ar68
$ clink lo68,lo68init,lib:klib/lib lo68
$ clink dump dump
$ clink nm68,lib:klib/lib nm68
$ clink prtobj,lo68init,lib:klib/lib prtobj
$ clink reloc reloc
$ clink sendc68,lib:klib/lib sendc68
$ clink size68,lib:klib/lib size68

View File

@@ -0,0 +1,39 @@
$ set noon
$ vsend AR.H
$ vsend AR68.C
$ vsend BASEPAGE.H
$ vsend BDOS.H
$ vsend COUT.H
$ vsend CPM.H
$ vsend CTYPE.H
$ vsend DUMP.C
$ vsend ERRNO.H
$ vsend FIND.C
$ vsend IOBUF.H
$ vsend KLIB.H
$ vsend LIBFIX.C
$ vsend LINK.COM
$ vsend LO68.C
$ vsend LO68.H
$ vsend LO68INIT.C
$ vsend MACHINE.11
$ vsend MACHINE.68K
$ vsend MACHINE.H
$ vsend MACHINE.VAX
$ vsend MAKE.SUB
$ vsend N.C
$ vsend NM68.C
$ vsend NUXI.C
$ vsend PORTAB.H
$ vsend PRTOBJ.C
$ vsend RELOC.C
$ vsend SEND10.SUB
$ vsend SENDC68.C
$ vsend SENDC68.H
$ vsend SETJMP.H
$ vsend SGTTY.H
$ vsend SIGNAL.H
$ vsend SIZE68.C
$ vsend STDIO.H
$ vsend VMAKE.COM
$ vsend done

View File

@@ -0,0 +1,28 @@
$ xer AR68.LIS
$ xer DUMP.LIS
$ xer FIND.LIS
$ xer LIBFIX.LIS
$ xer LO68.LIS
$ xer LO68INIT.LIS
$ xer N.LIS
$ xer NM68.LIS
$ xer NUXI.LIS
$ xer PRTOBJ.LIS
$ xer RELOC.LIS
$ xer SENDC68.LIS
$ xer SIZE68.LIS
$ xer BASEPAGE.LST
$ xer BDOS.LST
$ xer COUT.LST
$ xer CPM.LST
$ xer CTYPE.LST
$ xer ERRNO.LST
$ xer IOBUF.LST
$ xer KLIB.LST
$ xer LO68.LST
$ xer MACHINE.LST
$ xer SENDC68.LST
$ xer SETJMP.LST
$ xer SGTTY.LST
$ xer SIGNAL.LST
$ xer STDIO.LST