John Aycock's aic7770 sequencer code and assembler. There is currently
a discussion going on about removing this code from the burden of the GPL, but it won't happen before Beta, and this code should be tested before release. Supports 27/2842 class adaptec cards and is almost capable of supporting aic7870 based adapters (294X series cards). It does not support Wide controllers or the second channel on Twin boards although I have work in progress on getting both channels and running. I have also added a few performance improvements to this version that give us approximately a 25% boost over the original driver. These patches have been submitted to the author. Obtained from: Linux aic7770 driver (John Aycock - aycock@cpsc.ucalgary.ca)
This commit is contained in:
parent
1009cfb08b
commit
8dba66dc81
1064
sys/dev/aic7xxx/aic7xxx.seq
Normal file
1064
sys/dev/aic7xxx/aic7xxx.seq
Normal file
File diff suppressed because it is too large
Load Diff
54
sys/dev/aic7xxx/aic7xxx_asm.1
Normal file
54
sys/dev/aic7xxx/aic7xxx_asm.1
Normal file
@ -0,0 +1,54 @@
|
||||
.\" Copyright (c) 1994
|
||||
.\" Justin T. Gibbs. All rights reserved.
|
||||
.\"
|
||||
.\" Redistribution and use in source and binary forms, with or without
|
||||
.\" modification, are permitted provided that the following conditions
|
||||
.\" are met:
|
||||
.\" 1. Redistributions of source code must retain the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer.
|
||||
.\" 2. Redistributions in binary form must reproduce the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer in the
|
||||
.\" documentation and/or other materials provided with the distribution.
|
||||
.\" 3. All advertising materials mentioning features or use of this software
|
||||
.\" must display the following acknowledgement:
|
||||
.\" This product includes software developed by Justin T. Gibbs.
|
||||
.\" 4. The name of Justin T. Gibbs may not be used to endorse or promote
|
||||
.\" products derived from this software without specific prior written
|
||||
.\" permission.
|
||||
.\"
|
||||
.\" THIS SOFTWARE IS PROVIDED BY JUSTIN T. GIBBS ``AS IS'' AND
|
||||
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
.\" SUCH DAMAGE.
|
||||
.\"
|
||||
.\" @(#)aic7770.1 11/15/94
|
||||
.\"
|
||||
.Dd November 11, 1994
|
||||
.Dt AIC7770 1
|
||||
.Os BSD 4
|
||||
.Sh NAME
|
||||
.Nm aic7770
|
||||
.Nd aic7770 SCSI controller assembler
|
||||
.Sh SYNOPSIS
|
||||
.Nm aic7770
|
||||
.Op Fl o destination
|
||||
.Ar source-file
|
||||
.Sh DESCRIPTION
|
||||
.Ar Source-file
|
||||
is a file containing Aic7770 compatible assembly code. The output of the
|
||||
assembler defaults to
|
||||
.Ar a.out
|
||||
but can be optionally redirected to
|
||||
.Ar destination.
|
||||
.Pp
|
||||
.Sh AUTHOR
|
||||
This aic7770 compiler was written by John Aycock (aycock@cpsc.ucalgary.ca) and
|
||||
is subject to the GNU Public License.
|
||||
|
584
sys/dev/aic7xxx/aic7xxx_asm.c
Normal file
584
sys/dev/aic7xxx/aic7xxx_asm.c
Normal file
@ -0,0 +1,584 @@
|
||||
/*
|
||||
* Adaptec 274x device driver for Linux.
|
||||
* Copyright (c) 1994 The University of Calgary Department of Computer Science.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* Comments are started by `#' and continue to the end of the line; lines
|
||||
* may be of the form:
|
||||
*
|
||||
* <label>*
|
||||
* <label>* <undef-sym> = <value>
|
||||
* <label>* <opcode> <operand>*
|
||||
*
|
||||
* A <label> is an <undef-sym> ending in a colon. Spaces, tabs, and commas
|
||||
* are token separators.
|
||||
*/
|
||||
|
||||
/* #define _POSIX_SOURCE 1 */
|
||||
#define _POSIX_C_SOURCE 2
|
||||
|
||||
#include <ctype.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#define MEMORY 512 /* 2^9 29-bit words */
|
||||
#define MAXLINE 1024
|
||||
#define MAXTOKEN 32
|
||||
#define ADOTOUT "a.out"
|
||||
#define NOVALUE -1
|
||||
|
||||
/*
|
||||
* AIC-7770 register definitions
|
||||
*/
|
||||
#define R_SINDEX 0x65
|
||||
#define R_ALLONES 0x69
|
||||
#define R_ALLZEROS 0x6a
|
||||
#define R_NONE 0x6a
|
||||
|
||||
static
|
||||
char sccsid[] =
|
||||
"@(#)aic7770.c 1.10 94/07/22 jda";
|
||||
|
||||
int debug;
|
||||
int lineno, LC;
|
||||
char *filename;
|
||||
FILE *ifp, *ofp;
|
||||
unsigned char M[MEMORY][4];
|
||||
|
||||
void error(char *s)
|
||||
{
|
||||
fprintf(stderr, "%s: %s at line %d\n", filename, s, lineno);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
void *Malloc(size_t size)
|
||||
{
|
||||
void *p = malloc(size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
void *Realloc(void *ptr, size_t size)
|
||||
{
|
||||
void *p = realloc(ptr, size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
char *Strdup(char *s)
|
||||
{
|
||||
char *p = (char *)Malloc(strlen(s) + 1);
|
||||
strcpy(p, s);
|
||||
return(p);
|
||||
}
|
||||
|
||||
typedef struct sym_t {
|
||||
struct sym_t *next; /* MUST BE FIRST */
|
||||
char *name;
|
||||
int value;
|
||||
int npatch, *patch;
|
||||
} sym_t;
|
||||
|
||||
sym_t *head;
|
||||
|
||||
void define(char *name, int value)
|
||||
{
|
||||
sym_t *p, *q;
|
||||
|
||||
for (p = head, q = (sym_t *)&head; p; p = p->next) {
|
||||
if (!strcmp(p->name, name))
|
||||
error("redefined symbol");
|
||||
q = p;
|
||||
}
|
||||
|
||||
p = q->next = (sym_t *)Malloc(sizeof(sym_t));
|
||||
p->next = NULL;
|
||||
p->name = Strdup(name);
|
||||
p->value = value;
|
||||
p->npatch = 0;
|
||||
p->patch = NULL;
|
||||
|
||||
if (debug) {
|
||||
fprintf(stderr, "\"%s\" ", p->name);
|
||||
if (p->value != NOVALUE)
|
||||
fprintf(stderr, "defined as 0x%x\n", p->value);
|
||||
else
|
||||
fprintf(stderr, "undefined\n");
|
||||
}
|
||||
}
|
||||
|
||||
sym_t *lookup(char *name)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next)
|
||||
if (!strcmp(p->name, name))
|
||||
return(p);
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
void patch(sym_t *p, int location)
|
||||
{
|
||||
p->npatch += 1;
|
||||
p->patch = (int *)Realloc(p->patch, p->npatch * sizeof(int *));
|
||||
|
||||
p->patch[p->npatch - 1] = location;
|
||||
}
|
||||
|
||||
void backpatch(void)
|
||||
{
|
||||
int i;
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next) {
|
||||
|
||||
if (p->value == NOVALUE) {
|
||||
fprintf(stderr,
|
||||
"%s: undefined symbol \"%s\"\n",
|
||||
filename, p->name);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (p->npatch) {
|
||||
if (debug)
|
||||
fprintf(stderr,
|
||||
"\"%s\" (0x%x) patched at",
|
||||
p->name, p->value);
|
||||
|
||||
for (i = 0; i < p->npatch; i++) {
|
||||
M[p->patch[i]][0] &= ~1;
|
||||
M[p->patch[i]][0] |= ((p->value >> 8) & 1);
|
||||
M[p->patch[i]][1] = p->value & 0xff;
|
||||
|
||||
if (debug)
|
||||
fprintf(stderr, " 0x%x", p->patch[i]);
|
||||
}
|
||||
|
||||
if (debug)
|
||||
fputc('\n', stderr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Output words in byte-reversed order (least significant first)
|
||||
* since the sequencer RAM is loaded that way.
|
||||
*/
|
||||
void output(FILE *fp)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < LC; i++)
|
||||
fprintf(fp, "\t0x%02x, 0x%02x, 0x%02x, 0x%02x,\n",
|
||||
M[i][3],
|
||||
M[i][2],
|
||||
M[i][1],
|
||||
M[i][0]);
|
||||
}
|
||||
|
||||
char **getl(int *n)
|
||||
{
|
||||
int i;
|
||||
char *p;
|
||||
static char buf[MAXLINE];
|
||||
static char *a[MAXTOKEN];
|
||||
|
||||
i = 0;
|
||||
|
||||
while (fgets(buf, sizeof(buf), ifp)) {
|
||||
|
||||
lineno += 1;
|
||||
|
||||
if (buf[strlen(buf)-1] != '\n')
|
||||
error("line too long");
|
||||
|
||||
p = strchr(buf, '#');
|
||||
if (p)
|
||||
*p = '\0';
|
||||
|
||||
for (p = strtok(buf, ", \t\n"); p; p = strtok(NULL, ", \t\n"))
|
||||
if (i < MAXTOKEN-1)
|
||||
a[i++] = p;
|
||||
else
|
||||
error("too many tokens");
|
||||
if (i) {
|
||||
*n = i;
|
||||
return(a);
|
||||
}
|
||||
}
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
#define A 0x8000 /* `A'ccumulator ok */
|
||||
#define I 0x4000 /* use as immediate value */
|
||||
#define SL 0x2000 /* shift left */
|
||||
#define SR 0x1000 /* shift right */
|
||||
#define RL 0x0800 /* rotate left */
|
||||
#define RR 0x0400 /* rotate right */
|
||||
#define LO 0x8000 /* lookup: ori-{jmp,jc,jnc,call} */
|
||||
#define LA 0x4000 /* lookup: and-{jz,jnz} */
|
||||
#define LX 0x2000 /* lookup: xor-{je,jne} */
|
||||
#define NA -1 /* not applicable */
|
||||
|
||||
struct {
|
||||
char *name;
|
||||
int n; /* number of operands, including opcode */
|
||||
unsigned int op; /* immediate or L?|pos_from_0 */
|
||||
unsigned int dest; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int src; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int imm; /* pos_from_0, A|pos_from_0, or I|immediate */
|
||||
unsigned int addr; /* NA or pos_from_0 */
|
||||
int fmt; /* instruction format - 1, 2, or 3 */
|
||||
} instr[] = {
|
||||
/*
|
||||
* N OP DEST SRC IMM ADDR FMT
|
||||
*/
|
||||
"mov", 3, 1, 1, 2, I|0xff, NA, 1,
|
||||
"mov", 4, LO|2, NA, 1, I|0, 3, 3,
|
||||
"mvi", 3, 0, 1, I|R_ALLZEROS, A|2, NA, 1,
|
||||
"mvi", 4, LO|2, NA, I|R_ALLZEROS, 1, 3, 3,
|
||||
"not", 2, 2, 1, 1, I|0xff, NA, 1,
|
||||
"not", 3, 2, 1, 2, I|0xff, NA, 1,
|
||||
"and", 3, 1, 1, 1, A|2, NA, 1,
|
||||
"and", 4, 1, 1, 3, A|2, NA, 1,
|
||||
"or", 3, 0, 1, 1, A|2, NA, 1,
|
||||
"or", 4, 0, 1, 3, A|2, NA, 1,
|
||||
"or", 5, LO|3, NA, 1, 2, 4, 3,
|
||||
"xor", 3, 2, 1, 1, A|2, NA, 1,
|
||||
"xor", 4, 2, 1, 3, A|2, NA, 1,
|
||||
"nop", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"inc", 2, 3, 1, 1, I|1, NA, 1,
|
||||
"inc", 3, 3, 1, 2, I|1, NA, 1,
|
||||
"dec", 2, 3, 1, 1, I|0xff, NA, 1,
|
||||
"dec", 3, 3, 1, 2, I|0xff, NA, 1,
|
||||
"jmp", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jnc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"call", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"test", 5, LA|3, NA, 1, A|2, 4, 3,
|
||||
"cmp", 5, LX|3, NA, 1, A|2, 4, 3,
|
||||
"ret", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"clc", 1, 3, I|R_NONE, I|R_ALLZEROS, I|1, NA, 1,
|
||||
"clc", 4, 3, 2, I|R_ALLZEROS, A|3, NA, 1,
|
||||
"stc", 1, 3, I|R_NONE, I|R_ALLONES, I|1, NA, 1,
|
||||
"stc", 2, 3, 1, I|R_ALLONES, I|1, NA, 1,
|
||||
"add", 3, 3, 1, 1, A|2, NA, 1,
|
||||
"add", 4, 3, 1, 3, A|2, NA, 1,
|
||||
"adc", 3, 4, 1, 1, A|2, NA, 1,
|
||||
"adc", 4, 4, 1, 3, A|2, NA, 1,
|
||||
"shl", 3, 5, 1, 1, SL|2, NA, 2,
|
||||
"shl", 4, 5, 1, 2, SL|3, NA, 2,
|
||||
"shr", 3, 5, 1, 1, SR|2, NA, 2,
|
||||
"shr", 4, 5, 1, 2, SR|3, NA, 2,
|
||||
"rol", 3, 5, 1, 1, RL|2, NA, 2,
|
||||
"rol", 4, 5, 1, 2, RL|3, NA, 2,
|
||||
"ror", 3, 5, 1, 1, RR|2, NA, 2,
|
||||
"ror", 4, 5, 1, 2, RR|3, NA, 2,
|
||||
/*
|
||||
* Extensions (note also that mvi allows A)
|
||||
*/
|
||||
"clr", 2, 1, 1, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
0
|
||||
};
|
||||
|
||||
int eval_operand(char **a, int spec)
|
||||
{
|
||||
int i;
|
||||
unsigned int want = spec & (LO|LA|LX);
|
||||
|
||||
static struct {
|
||||
unsigned int what;
|
||||
char *name;
|
||||
int value;
|
||||
} jmptab[] = {
|
||||
LO, "jmp", 8,
|
||||
LO, "jc", 9,
|
||||
LO, "jnc", 10,
|
||||
LO, "call", 11,
|
||||
LA, "jz", 15,
|
||||
LA, "jnz", 13,
|
||||
LX, "je", 14,
|
||||
LX, "jne", 12,
|
||||
};
|
||||
|
||||
spec &= ~(LO|LA|LX);
|
||||
|
||||
for (i = 0; i < sizeof(jmptab)/sizeof(jmptab[0]); i++)
|
||||
if (jmptab[i].what == want &&
|
||||
!strcmp(jmptab[i].name, a[spec]))
|
||||
{
|
||||
return(jmptab[i].value);
|
||||
}
|
||||
|
||||
if (want)
|
||||
error("invalid jump");
|
||||
|
||||
return(spec); /* "case 0" - no flags set */
|
||||
}
|
||||
|
||||
int eval_sdi(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
unsigned val;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
|
||||
switch (spec & (A|I|SL|SR|RL|RR)) {
|
||||
case SL:
|
||||
case SR:
|
||||
case RL:
|
||||
case RR:
|
||||
if (isdigit(*a[spec &~ (SL|SR|RL|RR)]))
|
||||
val = strtol(a[spec &~ (SL|SR|RL|RR)], NULL, 0);
|
||||
else {
|
||||
p = lookup(a[spec &~ (SL|SR|RL|RR)]);
|
||||
if (!p)
|
||||
error("undefined symbol used");
|
||||
val = p->value;
|
||||
}
|
||||
|
||||
switch (spec & (SL|SR|RL|RR)) { /* blech */
|
||||
case SL:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(val % 8));
|
||||
case SR:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(1 << 3) |
|
||||
((8 - (val % 8)) % 8));
|
||||
case RL:
|
||||
return(val % 8);
|
||||
case RR:
|
||||
return((8 - (val % 8)) % 8);
|
||||
}
|
||||
case I:
|
||||
return(spec &~ I);
|
||||
case A:
|
||||
/*
|
||||
* An immediate field of zero selects
|
||||
* the accumulator. Vigorously object
|
||||
* if zero is given otherwise - it's
|
||||
* most likely an error.
|
||||
*/
|
||||
spec &= ~A;
|
||||
if (!strcmp("A", a[spec]))
|
||||
return(0);
|
||||
if (isdigit(*a[spec]) &&
|
||||
strtol(a[spec], NULL, 0) == 0)
|
||||
{
|
||||
error("immediate value of zero selects accumulator");
|
||||
}
|
||||
/* falls through */
|
||||
case 0:
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
p = lookup(a[spec]);
|
||||
if (p)
|
||||
return(p->value);
|
||||
error("undefined symbol used");
|
||||
}
|
||||
|
||||
return(NA); /* shut the compiler up */
|
||||
}
|
||||
|
||||
int eval_addr(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
|
||||
p = lookup(a[spec]);
|
||||
|
||||
if (p) {
|
||||
if (p->value != NOVALUE)
|
||||
return(p->value);
|
||||
patch(p, LC);
|
||||
} else {
|
||||
define(a[spec], NOVALUE);
|
||||
p = lookup(a[spec]);
|
||||
patch(p, LC);
|
||||
}
|
||||
|
||||
return(NA); /* will be patched in later */
|
||||
}
|
||||
|
||||
int crack(char **a, int n)
|
||||
{
|
||||
int i;
|
||||
int I_imm, I_addr;
|
||||
int I_op, I_dest, I_src, I_ret;
|
||||
|
||||
/*
|
||||
* Check for "ret" at the end of the line; remove
|
||||
* it unless it's "ret" alone - we still want to
|
||||
* look it up in the table.
|
||||
*/
|
||||
I_ret = (strcmp(a[n-1], "ret") ? 0 : !0);
|
||||
if (I_ret && n > 1)
|
||||
n -= 1;
|
||||
|
||||
for (i = 0; instr[i].name; i++) {
|
||||
/*
|
||||
* Look for match in table given constraints,
|
||||
* currently just the name and the number of
|
||||
* operands.
|
||||
*/
|
||||
if (!strcmp(instr[i].name, *a) && instr[i].n == n)
|
||||
break;
|
||||
}
|
||||
if (!instr[i].name)
|
||||
error("unknown opcode or wrong number of operands");
|
||||
|
||||
I_op = eval_operand(a, instr[i].op);
|
||||
I_src = eval_sdi(a, instr[i].src);
|
||||
I_imm = eval_sdi(a, instr[i].imm);
|
||||
I_dest = eval_sdi(a, instr[i].dest);
|
||||
I_addr = eval_addr(a, instr[i].addr);
|
||||
|
||||
switch (instr[i].fmt) {
|
||||
case 1:
|
||||
case 2:
|
||||
M[LC][0] = (I_op << 1) | I_ret;
|
||||
M[LC][1] = I_dest;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
case 3:
|
||||
if (I_ret)
|
||||
error("illegal use of \"ret\"");
|
||||
M[LC][0] = (I_op << 1) | ((I_addr >> 8) & 1);
|
||||
M[LC][1] = I_addr & 0xff;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
}
|
||||
|
||||
return(1); /* no two-byte instructions yet */
|
||||
}
|
||||
|
||||
#undef SL
|
||||
#undef SR
|
||||
#undef RL
|
||||
#undef RR
|
||||
#undef LX
|
||||
#undef LA
|
||||
#undef LO
|
||||
#undef I
|
||||
#undef A
|
||||
|
||||
void assemble(void)
|
||||
{
|
||||
int n;
|
||||
char **a;
|
||||
sym_t *p;
|
||||
|
||||
while ((a = getl(&n))) {
|
||||
|
||||
while (a[0][strlen(*a)-1] == ':') {
|
||||
a[0][strlen(*a)-1] = '\0';
|
||||
p = lookup(*a);
|
||||
if (p)
|
||||
p->value = LC;
|
||||
else
|
||||
define(*a, LC);
|
||||
a += 1;
|
||||
n -= 1;
|
||||
}
|
||||
|
||||
if (!n) /* line was all labels */
|
||||
continue;
|
||||
|
||||
if (n == 3 && !strcmp("VERSION", *a))
|
||||
fprintf(ofp, "#define %s \"%s\"\n", a[1], a[2]);
|
||||
else {
|
||||
if (n == 3 && !strcmp("=", a[1]))
|
||||
define(*a, strtol(a[2], NULL, 0));
|
||||
else
|
||||
LC += crack(a, n);
|
||||
}
|
||||
}
|
||||
|
||||
backpatch();
|
||||
output(ofp);
|
||||
|
||||
if (debug)
|
||||
output(stderr);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ((c = getopt(argc, argv, "dho:")) != EOF) {
|
||||
switch (c) {
|
||||
case 'd':
|
||||
debug = !0;
|
||||
break;
|
||||
case 'o':
|
||||
ofp = fopen(optarg, "w");
|
||||
if (!ofp) {
|
||||
perror(optarg);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
break;
|
||||
case 'h':
|
||||
printf("usage: %s [-d] [-ooutput] input\n", *argv);
|
||||
exit(EXIT_SUCCESS);
|
||||
case NULL:
|
||||
/*
|
||||
* An impossible option to shut the compiler
|
||||
* up about sccsid[].
|
||||
*/
|
||||
exit((int)sccsid);
|
||||
default:
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
if (argc - optind != 1) {
|
||||
fprintf(stderr, "%s: must have one input file\n", *argv);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
filename = argv[optind];
|
||||
|
||||
ifp = fopen(filename, "r");
|
||||
if (!ifp) {
|
||||
perror(filename);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (!ofp) {
|
||||
ofp = fopen(ADOTOUT, "w");
|
||||
if (!ofp) {
|
||||
perror(ADOTOUT);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
assemble();
|
||||
exit(EXIT_SUCCESS);
|
||||
}
|
584
sys/dev/aic7xxx/aicasm.c
Normal file
584
sys/dev/aic7xxx/aicasm.c
Normal file
@ -0,0 +1,584 @@
|
||||
/*
|
||||
* Adaptec 274x device driver for Linux.
|
||||
* Copyright (c) 1994 The University of Calgary Department of Computer Science.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* Comments are started by `#' and continue to the end of the line; lines
|
||||
* may be of the form:
|
||||
*
|
||||
* <label>*
|
||||
* <label>* <undef-sym> = <value>
|
||||
* <label>* <opcode> <operand>*
|
||||
*
|
||||
* A <label> is an <undef-sym> ending in a colon. Spaces, tabs, and commas
|
||||
* are token separators.
|
||||
*/
|
||||
|
||||
/* #define _POSIX_SOURCE 1 */
|
||||
#define _POSIX_C_SOURCE 2
|
||||
|
||||
#include <ctype.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#define MEMORY 512 /* 2^9 29-bit words */
|
||||
#define MAXLINE 1024
|
||||
#define MAXTOKEN 32
|
||||
#define ADOTOUT "a.out"
|
||||
#define NOVALUE -1
|
||||
|
||||
/*
|
||||
* AIC-7770 register definitions
|
||||
*/
|
||||
#define R_SINDEX 0x65
|
||||
#define R_ALLONES 0x69
|
||||
#define R_ALLZEROS 0x6a
|
||||
#define R_NONE 0x6a
|
||||
|
||||
static
|
||||
char sccsid[] =
|
||||
"@(#)aic7770.c 1.10 94/07/22 jda";
|
||||
|
||||
int debug;
|
||||
int lineno, LC;
|
||||
char *filename;
|
||||
FILE *ifp, *ofp;
|
||||
unsigned char M[MEMORY][4];
|
||||
|
||||
void error(char *s)
|
||||
{
|
||||
fprintf(stderr, "%s: %s at line %d\n", filename, s, lineno);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
void *Malloc(size_t size)
|
||||
{
|
||||
void *p = malloc(size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
void *Realloc(void *ptr, size_t size)
|
||||
{
|
||||
void *p = realloc(ptr, size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
char *Strdup(char *s)
|
||||
{
|
||||
char *p = (char *)Malloc(strlen(s) + 1);
|
||||
strcpy(p, s);
|
||||
return(p);
|
||||
}
|
||||
|
||||
typedef struct sym_t {
|
||||
struct sym_t *next; /* MUST BE FIRST */
|
||||
char *name;
|
||||
int value;
|
||||
int npatch, *patch;
|
||||
} sym_t;
|
||||
|
||||
sym_t *head;
|
||||
|
||||
void define(char *name, int value)
|
||||
{
|
||||
sym_t *p, *q;
|
||||
|
||||
for (p = head, q = (sym_t *)&head; p; p = p->next) {
|
||||
if (!strcmp(p->name, name))
|
||||
error("redefined symbol");
|
||||
q = p;
|
||||
}
|
||||
|
||||
p = q->next = (sym_t *)Malloc(sizeof(sym_t));
|
||||
p->next = NULL;
|
||||
p->name = Strdup(name);
|
||||
p->value = value;
|
||||
p->npatch = 0;
|
||||
p->patch = NULL;
|
||||
|
||||
if (debug) {
|
||||
fprintf(stderr, "\"%s\" ", p->name);
|
||||
if (p->value != NOVALUE)
|
||||
fprintf(stderr, "defined as 0x%x\n", p->value);
|
||||
else
|
||||
fprintf(stderr, "undefined\n");
|
||||
}
|
||||
}
|
||||
|
||||
sym_t *lookup(char *name)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next)
|
||||
if (!strcmp(p->name, name))
|
||||
return(p);
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
void patch(sym_t *p, int location)
|
||||
{
|
||||
p->npatch += 1;
|
||||
p->patch = (int *)Realloc(p->patch, p->npatch * sizeof(int *));
|
||||
|
||||
p->patch[p->npatch - 1] = location;
|
||||
}
|
||||
|
||||
void backpatch(void)
|
||||
{
|
||||
int i;
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next) {
|
||||
|
||||
if (p->value == NOVALUE) {
|
||||
fprintf(stderr,
|
||||
"%s: undefined symbol \"%s\"\n",
|
||||
filename, p->name);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (p->npatch) {
|
||||
if (debug)
|
||||
fprintf(stderr,
|
||||
"\"%s\" (0x%x) patched at",
|
||||
p->name, p->value);
|
||||
|
||||
for (i = 0; i < p->npatch; i++) {
|
||||
M[p->patch[i]][0] &= ~1;
|
||||
M[p->patch[i]][0] |= ((p->value >> 8) & 1);
|
||||
M[p->patch[i]][1] = p->value & 0xff;
|
||||
|
||||
if (debug)
|
||||
fprintf(stderr, " 0x%x", p->patch[i]);
|
||||
}
|
||||
|
||||
if (debug)
|
||||
fputc('\n', stderr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Output words in byte-reversed order (least significant first)
|
||||
* since the sequencer RAM is loaded that way.
|
||||
*/
|
||||
void output(FILE *fp)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < LC; i++)
|
||||
fprintf(fp, "\t0x%02x, 0x%02x, 0x%02x, 0x%02x,\n",
|
||||
M[i][3],
|
||||
M[i][2],
|
||||
M[i][1],
|
||||
M[i][0]);
|
||||
}
|
||||
|
||||
char **getl(int *n)
|
||||
{
|
||||
int i;
|
||||
char *p;
|
||||
static char buf[MAXLINE];
|
||||
static char *a[MAXTOKEN];
|
||||
|
||||
i = 0;
|
||||
|
||||
while (fgets(buf, sizeof(buf), ifp)) {
|
||||
|
||||
lineno += 1;
|
||||
|
||||
if (buf[strlen(buf)-1] != '\n')
|
||||
error("line too long");
|
||||
|
||||
p = strchr(buf, '#');
|
||||
if (p)
|
||||
*p = '\0';
|
||||
|
||||
for (p = strtok(buf, ", \t\n"); p; p = strtok(NULL, ", \t\n"))
|
||||
if (i < MAXTOKEN-1)
|
||||
a[i++] = p;
|
||||
else
|
||||
error("too many tokens");
|
||||
if (i) {
|
||||
*n = i;
|
||||
return(a);
|
||||
}
|
||||
}
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
#define A 0x8000 /* `A'ccumulator ok */
|
||||
#define I 0x4000 /* use as immediate value */
|
||||
#define SL 0x2000 /* shift left */
|
||||
#define SR 0x1000 /* shift right */
|
||||
#define RL 0x0800 /* rotate left */
|
||||
#define RR 0x0400 /* rotate right */
|
||||
#define LO 0x8000 /* lookup: ori-{jmp,jc,jnc,call} */
|
||||
#define LA 0x4000 /* lookup: and-{jz,jnz} */
|
||||
#define LX 0x2000 /* lookup: xor-{je,jne} */
|
||||
#define NA -1 /* not applicable */
|
||||
|
||||
struct {
|
||||
char *name;
|
||||
int n; /* number of operands, including opcode */
|
||||
unsigned int op; /* immediate or L?|pos_from_0 */
|
||||
unsigned int dest; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int src; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int imm; /* pos_from_0, A|pos_from_0, or I|immediate */
|
||||
unsigned int addr; /* NA or pos_from_0 */
|
||||
int fmt; /* instruction format - 1, 2, or 3 */
|
||||
} instr[] = {
|
||||
/*
|
||||
* N OP DEST SRC IMM ADDR FMT
|
||||
*/
|
||||
"mov", 3, 1, 1, 2, I|0xff, NA, 1,
|
||||
"mov", 4, LO|2, NA, 1, I|0, 3, 3,
|
||||
"mvi", 3, 0, 1, I|R_ALLZEROS, A|2, NA, 1,
|
||||
"mvi", 4, LO|2, NA, I|R_ALLZEROS, 1, 3, 3,
|
||||
"not", 2, 2, 1, 1, I|0xff, NA, 1,
|
||||
"not", 3, 2, 1, 2, I|0xff, NA, 1,
|
||||
"and", 3, 1, 1, 1, A|2, NA, 1,
|
||||
"and", 4, 1, 1, 3, A|2, NA, 1,
|
||||
"or", 3, 0, 1, 1, A|2, NA, 1,
|
||||
"or", 4, 0, 1, 3, A|2, NA, 1,
|
||||
"or", 5, LO|3, NA, 1, 2, 4, 3,
|
||||
"xor", 3, 2, 1, 1, A|2, NA, 1,
|
||||
"xor", 4, 2, 1, 3, A|2, NA, 1,
|
||||
"nop", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"inc", 2, 3, 1, 1, I|1, NA, 1,
|
||||
"inc", 3, 3, 1, 2, I|1, NA, 1,
|
||||
"dec", 2, 3, 1, 1, I|0xff, NA, 1,
|
||||
"dec", 3, 3, 1, 2, I|0xff, NA, 1,
|
||||
"jmp", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jnc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"call", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"test", 5, LA|3, NA, 1, A|2, 4, 3,
|
||||
"cmp", 5, LX|3, NA, 1, A|2, 4, 3,
|
||||
"ret", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"clc", 1, 3, I|R_NONE, I|R_ALLZEROS, I|1, NA, 1,
|
||||
"clc", 4, 3, 2, I|R_ALLZEROS, A|3, NA, 1,
|
||||
"stc", 1, 3, I|R_NONE, I|R_ALLONES, I|1, NA, 1,
|
||||
"stc", 2, 3, 1, I|R_ALLONES, I|1, NA, 1,
|
||||
"add", 3, 3, 1, 1, A|2, NA, 1,
|
||||
"add", 4, 3, 1, 3, A|2, NA, 1,
|
||||
"adc", 3, 4, 1, 1, A|2, NA, 1,
|
||||
"adc", 4, 4, 1, 3, A|2, NA, 1,
|
||||
"shl", 3, 5, 1, 1, SL|2, NA, 2,
|
||||
"shl", 4, 5, 1, 2, SL|3, NA, 2,
|
||||
"shr", 3, 5, 1, 1, SR|2, NA, 2,
|
||||
"shr", 4, 5, 1, 2, SR|3, NA, 2,
|
||||
"rol", 3, 5, 1, 1, RL|2, NA, 2,
|
||||
"rol", 4, 5, 1, 2, RL|3, NA, 2,
|
||||
"ror", 3, 5, 1, 1, RR|2, NA, 2,
|
||||
"ror", 4, 5, 1, 2, RR|3, NA, 2,
|
||||
/*
|
||||
* Extensions (note also that mvi allows A)
|
||||
*/
|
||||
"clr", 2, 1, 1, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
0
|
||||
};
|
||||
|
||||
int eval_operand(char **a, int spec)
|
||||
{
|
||||
int i;
|
||||
unsigned int want = spec & (LO|LA|LX);
|
||||
|
||||
static struct {
|
||||
unsigned int what;
|
||||
char *name;
|
||||
int value;
|
||||
} jmptab[] = {
|
||||
LO, "jmp", 8,
|
||||
LO, "jc", 9,
|
||||
LO, "jnc", 10,
|
||||
LO, "call", 11,
|
||||
LA, "jz", 15,
|
||||
LA, "jnz", 13,
|
||||
LX, "je", 14,
|
||||
LX, "jne", 12,
|
||||
};
|
||||
|
||||
spec &= ~(LO|LA|LX);
|
||||
|
||||
for (i = 0; i < sizeof(jmptab)/sizeof(jmptab[0]); i++)
|
||||
if (jmptab[i].what == want &&
|
||||
!strcmp(jmptab[i].name, a[spec]))
|
||||
{
|
||||
return(jmptab[i].value);
|
||||
}
|
||||
|
||||
if (want)
|
||||
error("invalid jump");
|
||||
|
||||
return(spec); /* "case 0" - no flags set */
|
||||
}
|
||||
|
||||
int eval_sdi(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
unsigned val;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
|
||||
switch (spec & (A|I|SL|SR|RL|RR)) {
|
||||
case SL:
|
||||
case SR:
|
||||
case RL:
|
||||
case RR:
|
||||
if (isdigit(*a[spec &~ (SL|SR|RL|RR)]))
|
||||
val = strtol(a[spec &~ (SL|SR|RL|RR)], NULL, 0);
|
||||
else {
|
||||
p = lookup(a[spec &~ (SL|SR|RL|RR)]);
|
||||
if (!p)
|
||||
error("undefined symbol used");
|
||||
val = p->value;
|
||||
}
|
||||
|
||||
switch (spec & (SL|SR|RL|RR)) { /* blech */
|
||||
case SL:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(val % 8));
|
||||
case SR:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(1 << 3) |
|
||||
((8 - (val % 8)) % 8));
|
||||
case RL:
|
||||
return(val % 8);
|
||||
case RR:
|
||||
return((8 - (val % 8)) % 8);
|
||||
}
|
||||
case I:
|
||||
return(spec &~ I);
|
||||
case A:
|
||||
/*
|
||||
* An immediate field of zero selects
|
||||
* the accumulator. Vigorously object
|
||||
* if zero is given otherwise - it's
|
||||
* most likely an error.
|
||||
*/
|
||||
spec &= ~A;
|
||||
if (!strcmp("A", a[spec]))
|
||||
return(0);
|
||||
if (isdigit(*a[spec]) &&
|
||||
strtol(a[spec], NULL, 0) == 0)
|
||||
{
|
||||
error("immediate value of zero selects accumulator");
|
||||
}
|
||||
/* falls through */
|
||||
case 0:
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
p = lookup(a[spec]);
|
||||
if (p)
|
||||
return(p->value);
|
||||
error("undefined symbol used");
|
||||
}
|
||||
|
||||
return(NA); /* shut the compiler up */
|
||||
}
|
||||
|
||||
int eval_addr(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
|
||||
p = lookup(a[spec]);
|
||||
|
||||
if (p) {
|
||||
if (p->value != NOVALUE)
|
||||
return(p->value);
|
||||
patch(p, LC);
|
||||
} else {
|
||||
define(a[spec], NOVALUE);
|
||||
p = lookup(a[spec]);
|
||||
patch(p, LC);
|
||||
}
|
||||
|
||||
return(NA); /* will be patched in later */
|
||||
}
|
||||
|
||||
int crack(char **a, int n)
|
||||
{
|
||||
int i;
|
||||
int I_imm, I_addr;
|
||||
int I_op, I_dest, I_src, I_ret;
|
||||
|
||||
/*
|
||||
* Check for "ret" at the end of the line; remove
|
||||
* it unless it's "ret" alone - we still want to
|
||||
* look it up in the table.
|
||||
*/
|
||||
I_ret = (strcmp(a[n-1], "ret") ? 0 : !0);
|
||||
if (I_ret && n > 1)
|
||||
n -= 1;
|
||||
|
||||
for (i = 0; instr[i].name; i++) {
|
||||
/*
|
||||
* Look for match in table given constraints,
|
||||
* currently just the name and the number of
|
||||
* operands.
|
||||
*/
|
||||
if (!strcmp(instr[i].name, *a) && instr[i].n == n)
|
||||
break;
|
||||
}
|
||||
if (!instr[i].name)
|
||||
error("unknown opcode or wrong number of operands");
|
||||
|
||||
I_op = eval_operand(a, instr[i].op);
|
||||
I_src = eval_sdi(a, instr[i].src);
|
||||
I_imm = eval_sdi(a, instr[i].imm);
|
||||
I_dest = eval_sdi(a, instr[i].dest);
|
||||
I_addr = eval_addr(a, instr[i].addr);
|
||||
|
||||
switch (instr[i].fmt) {
|
||||
case 1:
|
||||
case 2:
|
||||
M[LC][0] = (I_op << 1) | I_ret;
|
||||
M[LC][1] = I_dest;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
case 3:
|
||||
if (I_ret)
|
||||
error("illegal use of \"ret\"");
|
||||
M[LC][0] = (I_op << 1) | ((I_addr >> 8) & 1);
|
||||
M[LC][1] = I_addr & 0xff;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
}
|
||||
|
||||
return(1); /* no two-byte instructions yet */
|
||||
}
|
||||
|
||||
#undef SL
|
||||
#undef SR
|
||||
#undef RL
|
||||
#undef RR
|
||||
#undef LX
|
||||
#undef LA
|
||||
#undef LO
|
||||
#undef I
|
||||
#undef A
|
||||
|
||||
void assemble(void)
|
||||
{
|
||||
int n;
|
||||
char **a;
|
||||
sym_t *p;
|
||||
|
||||
while ((a = getl(&n))) {
|
||||
|
||||
while (a[0][strlen(*a)-1] == ':') {
|
||||
a[0][strlen(*a)-1] = '\0';
|
||||
p = lookup(*a);
|
||||
if (p)
|
||||
p->value = LC;
|
||||
else
|
||||
define(*a, LC);
|
||||
a += 1;
|
||||
n -= 1;
|
||||
}
|
||||
|
||||
if (!n) /* line was all labels */
|
||||
continue;
|
||||
|
||||
if (n == 3 && !strcmp("VERSION", *a))
|
||||
fprintf(ofp, "#define %s \"%s\"\n", a[1], a[2]);
|
||||
else {
|
||||
if (n == 3 && !strcmp("=", a[1]))
|
||||
define(*a, strtol(a[2], NULL, 0));
|
||||
else
|
||||
LC += crack(a, n);
|
||||
}
|
||||
}
|
||||
|
||||
backpatch();
|
||||
output(ofp);
|
||||
|
||||
if (debug)
|
||||
output(stderr);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ((c = getopt(argc, argv, "dho:")) != EOF) {
|
||||
switch (c) {
|
||||
case 'd':
|
||||
debug = !0;
|
||||
break;
|
||||
case 'o':
|
||||
ofp = fopen(optarg, "w");
|
||||
if (!ofp) {
|
||||
perror(optarg);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
break;
|
||||
case 'h':
|
||||
printf("usage: %s [-d] [-ooutput] input\n", *argv);
|
||||
exit(EXIT_SUCCESS);
|
||||
case NULL:
|
||||
/*
|
||||
* An impossible option to shut the compiler
|
||||
* up about sccsid[].
|
||||
*/
|
||||
exit((int)sccsid);
|
||||
default:
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
if (argc - optind != 1) {
|
||||
fprintf(stderr, "%s: must have one input file\n", *argv);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
filename = argv[optind];
|
||||
|
||||
ifp = fopen(filename, "r");
|
||||
if (!ifp) {
|
||||
perror(filename);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (!ofp) {
|
||||
ofp = fopen(ADOTOUT, "w");
|
||||
if (!ofp) {
|
||||
perror(ADOTOUT);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
assemble();
|
||||
exit(EXIT_SUCCESS);
|
||||
}
|
584
sys/dev/aic7xxx/aicasm/aicasm.c
Normal file
584
sys/dev/aic7xxx/aicasm/aicasm.c
Normal file
@ -0,0 +1,584 @@
|
||||
/*
|
||||
* Adaptec 274x device driver for Linux.
|
||||
* Copyright (c) 1994 The University of Calgary Department of Computer Science.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* Comments are started by `#' and continue to the end of the line; lines
|
||||
* may be of the form:
|
||||
*
|
||||
* <label>*
|
||||
* <label>* <undef-sym> = <value>
|
||||
* <label>* <opcode> <operand>*
|
||||
*
|
||||
* A <label> is an <undef-sym> ending in a colon. Spaces, tabs, and commas
|
||||
* are token separators.
|
||||
*/
|
||||
|
||||
/* #define _POSIX_SOURCE 1 */
|
||||
#define _POSIX_C_SOURCE 2
|
||||
|
||||
#include <ctype.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#define MEMORY 512 /* 2^9 29-bit words */
|
||||
#define MAXLINE 1024
|
||||
#define MAXTOKEN 32
|
||||
#define ADOTOUT "a.out"
|
||||
#define NOVALUE -1
|
||||
|
||||
/*
|
||||
* AIC-7770 register definitions
|
||||
*/
|
||||
#define R_SINDEX 0x65
|
||||
#define R_ALLONES 0x69
|
||||
#define R_ALLZEROS 0x6a
|
||||
#define R_NONE 0x6a
|
||||
|
||||
static
|
||||
char sccsid[] =
|
||||
"@(#)aic7770.c 1.10 94/07/22 jda";
|
||||
|
||||
int debug;
|
||||
int lineno, LC;
|
||||
char *filename;
|
||||
FILE *ifp, *ofp;
|
||||
unsigned char M[MEMORY][4];
|
||||
|
||||
void error(char *s)
|
||||
{
|
||||
fprintf(stderr, "%s: %s at line %d\n", filename, s, lineno);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
void *Malloc(size_t size)
|
||||
{
|
||||
void *p = malloc(size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
void *Realloc(void *ptr, size_t size)
|
||||
{
|
||||
void *p = realloc(ptr, size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
char *Strdup(char *s)
|
||||
{
|
||||
char *p = (char *)Malloc(strlen(s) + 1);
|
||||
strcpy(p, s);
|
||||
return(p);
|
||||
}
|
||||
|
||||
typedef struct sym_t {
|
||||
struct sym_t *next; /* MUST BE FIRST */
|
||||
char *name;
|
||||
int value;
|
||||
int npatch, *patch;
|
||||
} sym_t;
|
||||
|
||||
sym_t *head;
|
||||
|
||||
void define(char *name, int value)
|
||||
{
|
||||
sym_t *p, *q;
|
||||
|
||||
for (p = head, q = (sym_t *)&head; p; p = p->next) {
|
||||
if (!strcmp(p->name, name))
|
||||
error("redefined symbol");
|
||||
q = p;
|
||||
}
|
||||
|
||||
p = q->next = (sym_t *)Malloc(sizeof(sym_t));
|
||||
p->next = NULL;
|
||||
p->name = Strdup(name);
|
||||
p->value = value;
|
||||
p->npatch = 0;
|
||||
p->patch = NULL;
|
||||
|
||||
if (debug) {
|
||||
fprintf(stderr, "\"%s\" ", p->name);
|
||||
if (p->value != NOVALUE)
|
||||
fprintf(stderr, "defined as 0x%x\n", p->value);
|
||||
else
|
||||
fprintf(stderr, "undefined\n");
|
||||
}
|
||||
}
|
||||
|
||||
sym_t *lookup(char *name)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next)
|
||||
if (!strcmp(p->name, name))
|
||||
return(p);
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
void patch(sym_t *p, int location)
|
||||
{
|
||||
p->npatch += 1;
|
||||
p->patch = (int *)Realloc(p->patch, p->npatch * sizeof(int *));
|
||||
|
||||
p->patch[p->npatch - 1] = location;
|
||||
}
|
||||
|
||||
void backpatch(void)
|
||||
{
|
||||
int i;
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next) {
|
||||
|
||||
if (p->value == NOVALUE) {
|
||||
fprintf(stderr,
|
||||
"%s: undefined symbol \"%s\"\n",
|
||||
filename, p->name);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (p->npatch) {
|
||||
if (debug)
|
||||
fprintf(stderr,
|
||||
"\"%s\" (0x%x) patched at",
|
||||
p->name, p->value);
|
||||
|
||||
for (i = 0; i < p->npatch; i++) {
|
||||
M[p->patch[i]][0] &= ~1;
|
||||
M[p->patch[i]][0] |= ((p->value >> 8) & 1);
|
||||
M[p->patch[i]][1] = p->value & 0xff;
|
||||
|
||||
if (debug)
|
||||
fprintf(stderr, " 0x%x", p->patch[i]);
|
||||
}
|
||||
|
||||
if (debug)
|
||||
fputc('\n', stderr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Output words in byte-reversed order (least significant first)
|
||||
* since the sequencer RAM is loaded that way.
|
||||
*/
|
||||
void output(FILE *fp)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < LC; i++)
|
||||
fprintf(fp, "\t0x%02x, 0x%02x, 0x%02x, 0x%02x,\n",
|
||||
M[i][3],
|
||||
M[i][2],
|
||||
M[i][1],
|
||||
M[i][0]);
|
||||
}
|
||||
|
||||
char **getl(int *n)
|
||||
{
|
||||
int i;
|
||||
char *p;
|
||||
static char buf[MAXLINE];
|
||||
static char *a[MAXTOKEN];
|
||||
|
||||
i = 0;
|
||||
|
||||
while (fgets(buf, sizeof(buf), ifp)) {
|
||||
|
||||
lineno += 1;
|
||||
|
||||
if (buf[strlen(buf)-1] != '\n')
|
||||
error("line too long");
|
||||
|
||||
p = strchr(buf, '#');
|
||||
if (p)
|
||||
*p = '\0';
|
||||
|
||||
for (p = strtok(buf, ", \t\n"); p; p = strtok(NULL, ", \t\n"))
|
||||
if (i < MAXTOKEN-1)
|
||||
a[i++] = p;
|
||||
else
|
||||
error("too many tokens");
|
||||
if (i) {
|
||||
*n = i;
|
||||
return(a);
|
||||
}
|
||||
}
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
#define A 0x8000 /* `A'ccumulator ok */
|
||||
#define I 0x4000 /* use as immediate value */
|
||||
#define SL 0x2000 /* shift left */
|
||||
#define SR 0x1000 /* shift right */
|
||||
#define RL 0x0800 /* rotate left */
|
||||
#define RR 0x0400 /* rotate right */
|
||||
#define LO 0x8000 /* lookup: ori-{jmp,jc,jnc,call} */
|
||||
#define LA 0x4000 /* lookup: and-{jz,jnz} */
|
||||
#define LX 0x2000 /* lookup: xor-{je,jne} */
|
||||
#define NA -1 /* not applicable */
|
||||
|
||||
struct {
|
||||
char *name;
|
||||
int n; /* number of operands, including opcode */
|
||||
unsigned int op; /* immediate or L?|pos_from_0 */
|
||||
unsigned int dest; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int src; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int imm; /* pos_from_0, A|pos_from_0, or I|immediate */
|
||||
unsigned int addr; /* NA or pos_from_0 */
|
||||
int fmt; /* instruction format - 1, 2, or 3 */
|
||||
} instr[] = {
|
||||
/*
|
||||
* N OP DEST SRC IMM ADDR FMT
|
||||
*/
|
||||
"mov", 3, 1, 1, 2, I|0xff, NA, 1,
|
||||
"mov", 4, LO|2, NA, 1, I|0, 3, 3,
|
||||
"mvi", 3, 0, 1, I|R_ALLZEROS, A|2, NA, 1,
|
||||
"mvi", 4, LO|2, NA, I|R_ALLZEROS, 1, 3, 3,
|
||||
"not", 2, 2, 1, 1, I|0xff, NA, 1,
|
||||
"not", 3, 2, 1, 2, I|0xff, NA, 1,
|
||||
"and", 3, 1, 1, 1, A|2, NA, 1,
|
||||
"and", 4, 1, 1, 3, A|2, NA, 1,
|
||||
"or", 3, 0, 1, 1, A|2, NA, 1,
|
||||
"or", 4, 0, 1, 3, A|2, NA, 1,
|
||||
"or", 5, LO|3, NA, 1, 2, 4, 3,
|
||||
"xor", 3, 2, 1, 1, A|2, NA, 1,
|
||||
"xor", 4, 2, 1, 3, A|2, NA, 1,
|
||||
"nop", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"inc", 2, 3, 1, 1, I|1, NA, 1,
|
||||
"inc", 3, 3, 1, 2, I|1, NA, 1,
|
||||
"dec", 2, 3, 1, 1, I|0xff, NA, 1,
|
||||
"dec", 3, 3, 1, 2, I|0xff, NA, 1,
|
||||
"jmp", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jnc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"call", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"test", 5, LA|3, NA, 1, A|2, 4, 3,
|
||||
"cmp", 5, LX|3, NA, 1, A|2, 4, 3,
|
||||
"ret", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"clc", 1, 3, I|R_NONE, I|R_ALLZEROS, I|1, NA, 1,
|
||||
"clc", 4, 3, 2, I|R_ALLZEROS, A|3, NA, 1,
|
||||
"stc", 1, 3, I|R_NONE, I|R_ALLONES, I|1, NA, 1,
|
||||
"stc", 2, 3, 1, I|R_ALLONES, I|1, NA, 1,
|
||||
"add", 3, 3, 1, 1, A|2, NA, 1,
|
||||
"add", 4, 3, 1, 3, A|2, NA, 1,
|
||||
"adc", 3, 4, 1, 1, A|2, NA, 1,
|
||||
"adc", 4, 4, 1, 3, A|2, NA, 1,
|
||||
"shl", 3, 5, 1, 1, SL|2, NA, 2,
|
||||
"shl", 4, 5, 1, 2, SL|3, NA, 2,
|
||||
"shr", 3, 5, 1, 1, SR|2, NA, 2,
|
||||
"shr", 4, 5, 1, 2, SR|3, NA, 2,
|
||||
"rol", 3, 5, 1, 1, RL|2, NA, 2,
|
||||
"rol", 4, 5, 1, 2, RL|3, NA, 2,
|
||||
"ror", 3, 5, 1, 1, RR|2, NA, 2,
|
||||
"ror", 4, 5, 1, 2, RR|3, NA, 2,
|
||||
/*
|
||||
* Extensions (note also that mvi allows A)
|
||||
*/
|
||||
"clr", 2, 1, 1, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
0
|
||||
};
|
||||
|
||||
int eval_operand(char **a, int spec)
|
||||
{
|
||||
int i;
|
||||
unsigned int want = spec & (LO|LA|LX);
|
||||
|
||||
static struct {
|
||||
unsigned int what;
|
||||
char *name;
|
||||
int value;
|
||||
} jmptab[] = {
|
||||
LO, "jmp", 8,
|
||||
LO, "jc", 9,
|
||||
LO, "jnc", 10,
|
||||
LO, "call", 11,
|
||||
LA, "jz", 15,
|
||||
LA, "jnz", 13,
|
||||
LX, "je", 14,
|
||||
LX, "jne", 12,
|
||||
};
|
||||
|
||||
spec &= ~(LO|LA|LX);
|
||||
|
||||
for (i = 0; i < sizeof(jmptab)/sizeof(jmptab[0]); i++)
|
||||
if (jmptab[i].what == want &&
|
||||
!strcmp(jmptab[i].name, a[spec]))
|
||||
{
|
||||
return(jmptab[i].value);
|
||||
}
|
||||
|
||||
if (want)
|
||||
error("invalid jump");
|
||||
|
||||
return(spec); /* "case 0" - no flags set */
|
||||
}
|
||||
|
||||
int eval_sdi(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
unsigned val;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
|
||||
switch (spec & (A|I|SL|SR|RL|RR)) {
|
||||
case SL:
|
||||
case SR:
|
||||
case RL:
|
||||
case RR:
|
||||
if (isdigit(*a[spec &~ (SL|SR|RL|RR)]))
|
||||
val = strtol(a[spec &~ (SL|SR|RL|RR)], NULL, 0);
|
||||
else {
|
||||
p = lookup(a[spec &~ (SL|SR|RL|RR)]);
|
||||
if (!p)
|
||||
error("undefined symbol used");
|
||||
val = p->value;
|
||||
}
|
||||
|
||||
switch (spec & (SL|SR|RL|RR)) { /* blech */
|
||||
case SL:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(val % 8));
|
||||
case SR:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(1 << 3) |
|
||||
((8 - (val % 8)) % 8));
|
||||
case RL:
|
||||
return(val % 8);
|
||||
case RR:
|
||||
return((8 - (val % 8)) % 8);
|
||||
}
|
||||
case I:
|
||||
return(spec &~ I);
|
||||
case A:
|
||||
/*
|
||||
* An immediate field of zero selects
|
||||
* the accumulator. Vigorously object
|
||||
* if zero is given otherwise - it's
|
||||
* most likely an error.
|
||||
*/
|
||||
spec &= ~A;
|
||||
if (!strcmp("A", a[spec]))
|
||||
return(0);
|
||||
if (isdigit(*a[spec]) &&
|
||||
strtol(a[spec], NULL, 0) == 0)
|
||||
{
|
||||
error("immediate value of zero selects accumulator");
|
||||
}
|
||||
/* falls through */
|
||||
case 0:
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
p = lookup(a[spec]);
|
||||
if (p)
|
||||
return(p->value);
|
||||
error("undefined symbol used");
|
||||
}
|
||||
|
||||
return(NA); /* shut the compiler up */
|
||||
}
|
||||
|
||||
int eval_addr(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
|
||||
p = lookup(a[spec]);
|
||||
|
||||
if (p) {
|
||||
if (p->value != NOVALUE)
|
||||
return(p->value);
|
||||
patch(p, LC);
|
||||
} else {
|
||||
define(a[spec], NOVALUE);
|
||||
p = lookup(a[spec]);
|
||||
patch(p, LC);
|
||||
}
|
||||
|
||||
return(NA); /* will be patched in later */
|
||||
}
|
||||
|
||||
int crack(char **a, int n)
|
||||
{
|
||||
int i;
|
||||
int I_imm, I_addr;
|
||||
int I_op, I_dest, I_src, I_ret;
|
||||
|
||||
/*
|
||||
* Check for "ret" at the end of the line; remove
|
||||
* it unless it's "ret" alone - we still want to
|
||||
* look it up in the table.
|
||||
*/
|
||||
I_ret = (strcmp(a[n-1], "ret") ? 0 : !0);
|
||||
if (I_ret && n > 1)
|
||||
n -= 1;
|
||||
|
||||
for (i = 0; instr[i].name; i++) {
|
||||
/*
|
||||
* Look for match in table given constraints,
|
||||
* currently just the name and the number of
|
||||
* operands.
|
||||
*/
|
||||
if (!strcmp(instr[i].name, *a) && instr[i].n == n)
|
||||
break;
|
||||
}
|
||||
if (!instr[i].name)
|
||||
error("unknown opcode or wrong number of operands");
|
||||
|
||||
I_op = eval_operand(a, instr[i].op);
|
||||
I_src = eval_sdi(a, instr[i].src);
|
||||
I_imm = eval_sdi(a, instr[i].imm);
|
||||
I_dest = eval_sdi(a, instr[i].dest);
|
||||
I_addr = eval_addr(a, instr[i].addr);
|
||||
|
||||
switch (instr[i].fmt) {
|
||||
case 1:
|
||||
case 2:
|
||||
M[LC][0] = (I_op << 1) | I_ret;
|
||||
M[LC][1] = I_dest;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
case 3:
|
||||
if (I_ret)
|
||||
error("illegal use of \"ret\"");
|
||||
M[LC][0] = (I_op << 1) | ((I_addr >> 8) & 1);
|
||||
M[LC][1] = I_addr & 0xff;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
}
|
||||
|
||||
return(1); /* no two-byte instructions yet */
|
||||
}
|
||||
|
||||
#undef SL
|
||||
#undef SR
|
||||
#undef RL
|
||||
#undef RR
|
||||
#undef LX
|
||||
#undef LA
|
||||
#undef LO
|
||||
#undef I
|
||||
#undef A
|
||||
|
||||
void assemble(void)
|
||||
{
|
||||
int n;
|
||||
char **a;
|
||||
sym_t *p;
|
||||
|
||||
while ((a = getl(&n))) {
|
||||
|
||||
while (a[0][strlen(*a)-1] == ':') {
|
||||
a[0][strlen(*a)-1] = '\0';
|
||||
p = lookup(*a);
|
||||
if (p)
|
||||
p->value = LC;
|
||||
else
|
||||
define(*a, LC);
|
||||
a += 1;
|
||||
n -= 1;
|
||||
}
|
||||
|
||||
if (!n) /* line was all labels */
|
||||
continue;
|
||||
|
||||
if (n == 3 && !strcmp("VERSION", *a))
|
||||
fprintf(ofp, "#define %s \"%s\"\n", a[1], a[2]);
|
||||
else {
|
||||
if (n == 3 && !strcmp("=", a[1]))
|
||||
define(*a, strtol(a[2], NULL, 0));
|
||||
else
|
||||
LC += crack(a, n);
|
||||
}
|
||||
}
|
||||
|
||||
backpatch();
|
||||
output(ofp);
|
||||
|
||||
if (debug)
|
||||
output(stderr);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ((c = getopt(argc, argv, "dho:")) != EOF) {
|
||||
switch (c) {
|
||||
case 'd':
|
||||
debug = !0;
|
||||
break;
|
||||
case 'o':
|
||||
ofp = fopen(optarg, "w");
|
||||
if (!ofp) {
|
||||
perror(optarg);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
break;
|
||||
case 'h':
|
||||
printf("usage: %s [-d] [-ooutput] input\n", *argv);
|
||||
exit(EXIT_SUCCESS);
|
||||
case NULL:
|
||||
/*
|
||||
* An impossible option to shut the compiler
|
||||
* up about sccsid[].
|
||||
*/
|
||||
exit((int)sccsid);
|
||||
default:
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
if (argc - optind != 1) {
|
||||
fprintf(stderr, "%s: must have one input file\n", *argv);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
filename = argv[optind];
|
||||
|
||||
ifp = fopen(filename, "r");
|
||||
if (!ifp) {
|
||||
perror(filename);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (!ofp) {
|
||||
ofp = fopen(ADOTOUT, "w");
|
||||
if (!ofp) {
|
||||
perror(ADOTOUT);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
assemble();
|
||||
exit(EXIT_SUCCESS);
|
||||
}
|
339
sys/gnu/misc/aic7770/COPYING
Normal file
339
sys/gnu/misc/aic7770/COPYING
Normal file
@ -0,0 +1,339 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 2, June 1991
|
||||
|
||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
||||
675 Mass Ave, Cambridge, MA 02139, USA
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The licenses for most software are designed to take away your
|
||||
freedom to share and change it. By contrast, the GNU General Public
|
||||
License is intended to guarantee your freedom to share and change free
|
||||
software--to make sure the software is free for all its users. This
|
||||
General Public License applies to most of the Free Software
|
||||
Foundation's software and to any other program whose authors commit to
|
||||
using it. (Some other Free Software Foundation software is covered by
|
||||
the GNU Library General Public License instead.) You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
this service if you wish), that you receive source code or can get it
|
||||
if you want it, that you can change the software or use pieces of it
|
||||
in new free programs; and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to make restrictions that forbid
|
||||
anyone to deny you these rights or to ask you to surrender the rights.
|
||||
These restrictions translate to certain responsibilities for you if you
|
||||
distribute copies of the software, or if you modify it.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must give the recipients all the rights that
|
||||
you have. You must make sure that they, too, receive or can get the
|
||||
source code. And you must show them these terms so they know their
|
||||
rights.
|
||||
|
||||
We protect your rights with two steps: (1) copyright the software, and
|
||||
(2) offer you this license which gives you legal permission to copy,
|
||||
distribute and/or modify the software.
|
||||
|
||||
Also, for each author's protection and ours, we want to make certain
|
||||
that everyone understands that there is no warranty for this free
|
||||
software. If the software is modified by someone else and passed on, we
|
||||
want its recipients to know that what they have is not the original, so
|
||||
that any problems introduced by others will not reflect on the original
|
||||
authors' reputations.
|
||||
|
||||
Finally, any free program is threatened constantly by software
|
||||
patents. We wish to avoid the danger that redistributors of a free
|
||||
program will individually obtain patent licenses, in effect making the
|
||||
program proprietary. To prevent this, we have made it clear that any
|
||||
patent must be licensed for everyone's free use or not licensed at all.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License applies to any program or other work which contains
|
||||
a notice placed by the copyright holder saying it may be distributed
|
||||
under the terms of this General Public License. The "Program", below,
|
||||
refers to any such program or work, and a "work based on the Program"
|
||||
means either the Program or any derivative work under copyright law:
|
||||
that is to say, a work containing the Program or a portion of it,
|
||||
either verbatim or with modifications and/or translated into another
|
||||
language. (Hereinafter, translation is included without limitation in
|
||||
the term "modification".) Each licensee is addressed as "you".
|
||||
|
||||
Activities other than copying, distribution and modification are not
|
||||
covered by this License; they are outside its scope. The act of
|
||||
running the Program is not restricted, and the output from the Program
|
||||
is covered only if its contents constitute a work based on the
|
||||
Program (independent of having been made by running the Program).
|
||||
Whether that is true depends on what the Program does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Program's
|
||||
source code as you receive it, in any medium, provided that you
|
||||
conspicuously and appropriately publish on each copy an appropriate
|
||||
copyright notice and disclaimer of warranty; keep intact all the
|
||||
notices that refer to this License and to the absence of any warranty;
|
||||
and give any other recipients of the Program a copy of this License
|
||||
along with the Program.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy, and
|
||||
you may at your option offer warranty protection in exchange for a fee.
|
||||
|
||||
2. You may modify your copy or copies of the Program or any portion
|
||||
of it, thus forming a work based on the Program, and copy and
|
||||
distribute such modifications or work under the terms of Section 1
|
||||
above, provided that you also meet all of these conditions:
|
||||
|
||||
a) You must cause the modified files to carry prominent notices
|
||||
stating that you changed the files and the date of any change.
|
||||
|
||||
b) You must cause any work that you distribute or publish, that in
|
||||
whole or in part contains or is derived from the Program or any
|
||||
part thereof, to be licensed as a whole at no charge to all third
|
||||
parties under the terms of this License.
|
||||
|
||||
c) If the modified program normally reads commands interactively
|
||||
when run, you must cause it, when started running for such
|
||||
interactive use in the most ordinary way, to print or display an
|
||||
announcement including an appropriate copyright notice and a
|
||||
notice that there is no warranty (or else, saying that you provide
|
||||
a warranty) and that users may redistribute the program under
|
||||
these conditions, and telling the user how to view a copy of this
|
||||
License. (Exception: if the Program itself is interactive but
|
||||
does not normally print such an announcement, your work based on
|
||||
the Program is not required to print an announcement.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If
|
||||
identifiable sections of that work are not derived from the Program,
|
||||
and can be reasonably considered independent and separate works in
|
||||
themselves, then this License, and its terms, do not apply to those
|
||||
sections when you distribute them as separate works. But when you
|
||||
distribute the same sections as part of a whole which is a work based
|
||||
on the Program, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the
|
||||
entire whole, and thus to each and every part regardless of who wrote it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest
|
||||
your rights to work written entirely by you; rather, the intent is to
|
||||
exercise the right to control the distribution of derivative or
|
||||
collective works based on the Program.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Program
|
||||
with the Program (or with a work based on the Program) on a volume of
|
||||
a storage or distribution medium does not bring the other work under
|
||||
the scope of this License.
|
||||
|
||||
3. You may copy and distribute the Program (or a work based on it,
|
||||
under Section 2) in object code or executable form under the terms of
|
||||
Sections 1 and 2 above provided that you also do one of the following:
|
||||
|
||||
a) Accompany it with the complete corresponding machine-readable
|
||||
source code, which must be distributed under the terms of Sections
|
||||
1 and 2 above on a medium customarily used for software interchange; or,
|
||||
|
||||
b) Accompany it with a written offer, valid for at least three
|
||||
years, to give any third party, for a charge no more than your
|
||||
cost of physically performing source distribution, a complete
|
||||
machine-readable copy of the corresponding source code, to be
|
||||
distributed under the terms of Sections 1 and 2 above on a medium
|
||||
customarily used for software interchange; or,
|
||||
|
||||
c) Accompany it with the information you received as to the offer
|
||||
to distribute corresponding source code. (This alternative is
|
||||
allowed only for noncommercial distribution and only if you
|
||||
received the program in object code or executable form with such
|
||||
an offer, in accord with Subsection b above.)
|
||||
|
||||
The source code for a work means the preferred form of the work for
|
||||
making modifications to it. For an executable work, complete source
|
||||
code means all the source code for all modules it contains, plus any
|
||||
associated interface definition files, plus the scripts used to
|
||||
control compilation and installation of the executable. However, as a
|
||||
special exception, the source code distributed need not include
|
||||
anything that is normally distributed (in either source or binary
|
||||
form) with the major components (compiler, kernel, and so on) of the
|
||||
operating system on which the executable runs, unless that component
|
||||
itself accompanies the executable.
|
||||
|
||||
If distribution of executable or object code is made by offering
|
||||
access to copy from a designated place, then offering equivalent
|
||||
access to copy the source code from the same place counts as
|
||||
distribution of the source code, even though third parties are not
|
||||
compelled to copy the source along with the object code.
|
||||
|
||||
4. You may not copy, modify, sublicense, or distribute the Program
|
||||
except as expressly provided under this License. Any attempt
|
||||
otherwise to copy, modify, sublicense or distribute the Program is
|
||||
void, and will automatically terminate your rights under this License.
|
||||
However, parties who have received copies, or rights, from you under
|
||||
this License will not have their licenses terminated so long as such
|
||||
parties remain in full compliance.
|
||||
|
||||
5. You are not required to accept this License, since you have not
|
||||
signed it. However, nothing else grants you permission to modify or
|
||||
distribute the Program or its derivative works. These actions are
|
||||
prohibited by law if you do not accept this License. Therefore, by
|
||||
modifying or distributing the Program (or any work based on the
|
||||
Program), you indicate your acceptance of this License to do so, and
|
||||
all its terms and conditions for copying, distributing or modifying
|
||||
the Program or works based on it.
|
||||
|
||||
6. Each time you redistribute the Program (or any work based on the
|
||||
Program), the recipient automatically receives a license from the
|
||||
original licensor to copy, distribute or modify the Program subject to
|
||||
these terms and conditions. You may not impose any further
|
||||
restrictions on the recipients' exercise of the rights granted herein.
|
||||
You are not responsible for enforcing compliance by third parties to
|
||||
this License.
|
||||
|
||||
7. If, as a consequence of a court judgment or allegation of patent
|
||||
infringement or for any other reason (not limited to patent issues),
|
||||
conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot
|
||||
distribute so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you
|
||||
may not distribute the Program at all. For example, if a patent
|
||||
license would not permit royalty-free redistribution of the Program by
|
||||
all those who receive copies directly or indirectly through you, then
|
||||
the only way you could satisfy both it and this License would be to
|
||||
refrain entirely from distribution of the Program.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under
|
||||
any particular circumstance, the balance of the section is intended to
|
||||
apply and the section as a whole is intended to apply in other
|
||||
circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any
|
||||
patents or other property right claims or to contest validity of any
|
||||
such claims; this section has the sole purpose of protecting the
|
||||
integrity of the free software distribution system, which is
|
||||
implemented by public license practices. Many people have made
|
||||
generous contributions to the wide range of software distributed
|
||||
through that system in reliance on consistent application of that
|
||||
system; it is up to the author/donor to decide if he or she is willing
|
||||
to distribute software through any other system and a licensee cannot
|
||||
impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to
|
||||
be a consequence of the rest of this License.
|
||||
|
||||
8. If the distribution and/or use of the Program is restricted in
|
||||
certain countries either by patents or by copyrighted interfaces, the
|
||||
original copyright holder who places the Program under this License
|
||||
may add an explicit geographical distribution limitation excluding
|
||||
those countries, so that distribution is permitted only in or among
|
||||
countries not thus excluded. In such case, this License incorporates
|
||||
the limitation as if written in the body of this License.
|
||||
|
||||
9. The Free Software Foundation may publish revised and/or new versions
|
||||
of the General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program
|
||||
specifies a version number of this License which applies to it and "any
|
||||
later version", you have the option of following the terms and conditions
|
||||
either of that version or of any later version published by the Free
|
||||
Software Foundation. If the Program does not specify a version number of
|
||||
this License, you may choose any version ever published by the Free Software
|
||||
Foundation.
|
||||
|
||||
10. If you wish to incorporate parts of the Program into other free
|
||||
programs whose distribution conditions are different, write to the author
|
||||
to ask for permission. For software which is copyrighted by the Free
|
||||
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||
make exceptions for this. Our decision will be guided by the two goals
|
||||
of preserving the free status of all derivatives of our free software and
|
||||
of promoting the sharing and reuse of software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||
REPAIR OR CORRECTION.
|
||||
|
||||
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||
POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
Appendix: How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
convey the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) 19yy <name of author>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program is interactive, make it output a short notice like this
|
||||
when it starts in an interactive mode:
|
||||
|
||||
Gnomovision version 69, Copyright (C) 19yy name of author
|
||||
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, the commands you use may
|
||||
be called something other than `show w' and `show c'; they could even be
|
||||
mouse-clicks or menu items--whatever suits your program.
|
||||
|
||||
You should also get your employer (if you work as a programmer) or your
|
||||
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||
necessary. Here is a sample; alter the names:
|
||||
|
||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||
|
||||
<signature of Ty Coon>, 1 April 1989
|
||||
Ty Coon, President of Vice
|
||||
|
||||
This General Public License does not permit incorporating your program into
|
||||
proprietary programs. If your program is a subroutine library, you may
|
||||
consider it more useful to permit linking proprietary applications with the
|
||||
library. If this is what you want to do, use the GNU Library General
|
||||
Public License instead of this License.
|
16
sys/gnu/misc/aic7770/COPYRIGHT
Normal file
16
sys/gnu/misc/aic7770/COPYRIGHT
Normal file
@ -0,0 +1,16 @@
|
||||
Adaptec 274x device driver for Linux.
|
||||
Copyright (c) 1994 The University of Calgary Department of Computer Science.
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
94
sys/gnu/misc/aic7770/README
Normal file
94
sys/gnu/misc/aic7770/README
Normal file
@ -0,0 +1,94 @@
|
||||
@(#)README 1.16 94/11/09 jda
|
||||
|
||||
AHA274x/284x DRIVER
|
||||
|
||||
*** THIS SHOULD BE CONSIDERED BETA SOFTWARE ***
|
||||
|
||||
BACKGROUND & LIMITATIONS
|
||||
|
||||
For various reasons, we ended up with one of these cards under the
|
||||
impression that support was soon forthcoming. In mid-May, I asked
|
||||
Scott Ferris (the official person who's supposed to be writing this
|
||||
driver) what documentation he used, _finally_ got it from Adaptec,
|
||||
and started writing this driver. It is now at what I would consider
|
||||
a stable state - it runs our news server and is battered by SCSI
|
||||
requests 24 hours a day without dying. There are a few devices it
|
||||
reportedly doesn't like working with - those are being sorted out. Due
|
||||
to some unexpected equipment loans, I am able to support this at least
|
||||
for the time being.
|
||||
|
||||
YOU MUST HAVE THE BIOS ENABLED OR THIS WILL NOT WORK. The BIOS extracts
|
||||
some configuration information that I cannot get to portably yet, as
|
||||
well as provides some self-tests which this driver does not attempt to
|
||||
duplicate.
|
||||
|
||||
Scott's driver development is stalled for now, and after discussions
|
||||
with him, this is now officially out of "pre-alpha" status and into
|
||||
beta until the remaining device problems can be resolved. The latest
|
||||
patches can be obtained via anonymous ftp from ftp.cpsc.ucalgary.ca in
|
||||
/pub/systems/linux/aha274x.
|
||||
|
||||
It supports both EISA 274x and VL-bus 284x, either single or twin-bus cards
|
||||
(but not the second SCSI bus of twin cards - see aha274x.c), and supports
|
||||
disconnection, synchronous SCSI, and scatter-gather. Unlike previous
|
||||
versions, abort() and reset() are now implemented, and both hosts.c and
|
||||
aha274x.c should give a clean compile. Code is now present to detect parity
|
||||
errors, but has not been tested.
|
||||
|
||||
I wrote this using a 1.0.9 kernel. Unfortunately, I'm getting tired of
|
||||
#ifdef'ing everything to handle two or three different evolutionary steps
|
||||
in the SCSI kernel code, so I've upgraded my system to 1.1.49, and will
|
||||
only leave in code to support versions from about 1.1.45 onward.
|
||||
|
||||
Thanks to patches supplied by Mark Olson <molson@tricord.com>, this driver
|
||||
will now work with the 284x series (the VL-bus version of this card). The
|
||||
294x (PCI-bus) support is based on patches sent to me by Mark Olson and
|
||||
Alan Hourihane <alanh@fairlite.demon.co.uk>.
|
||||
|
||||
Under protest, this driver is subject to the GPL - see the file
|
||||
COPYING for details.
|
||||
|
||||
Thanks to the following people for bug fixes/code improvements (also
|
||||
thanks to the people who have sent me feedback):
|
||||
|
||||
"David F. Carlson" <dave@ee.rochester.edu>
|
||||
Jimen Ching <jiching@wiliki.eng.hawaii.edu>
|
||||
mday@artisoft.com (Matt Day)
|
||||
"Dean W. Gehnert" <deang@ims.com>
|
||||
Darcy Grant <darcy@cpsc.ucalgary.ca>
|
||||
Alan Hourihane <alanh@fairlite.demon.co.uk>
|
||||
isely@fncrd8.fnal.gov (Mike Isely)
|
||||
Mike Jerger <jerger@ux1.cso.uiuc.edu>
|
||||
tm@netcom.com (Toshiyasu Morita)
|
||||
neal@interact.org (Neal Norwitz)
|
||||
Mark Olson <molson@tricord.com>
|
||||
map@europa.ecn.uoknor.edu (Michael A. Parker)
|
||||
Thomas Scheunemann <thomas@dagobert.uni-duisburg.de>
|
||||
|
||||
Special thanks to Drew Eckhardt <drew@kinglear.cs.Colorado.EDU> for
|
||||
fielding my questions about synchronous negotiation. Steffen Moeller
|
||||
<smoe0024@rz.uni-hildesheim.de> sent me installation instructions which
|
||||
were previously included in this README.
|
||||
|
||||
David Pirie <pirie@cpsc.ucalgary.ca> was nice enough to loan me his
|
||||
2842 card for a week so I could track down one bug, as well as his
|
||||
CD-ROM drive later, and also thanks to Doug Fortune at Riley's Data Share
|
||||
in Calgary, who arranged a long-term loan of a 2842 board for further work.
|
||||
|
||||
Many thanks to the fearless prerelease testers! Dean Gehnert has been
|
||||
building Slackware boot disks for the driver, which are available from
|
||||
ftp.cpsc.ucalgary.ca in /pub/systems/linux/aha274x/slackware_boot.
|
||||
|
||||
Carl Riches <cgr@poplar1.cfr.washington.edu> has set up a mailing list
|
||||
for aic7xxx driver development. To subscribe, send a message to
|
||||
aic7770-list@poplar1.cfr.washington.edu with a message body of:
|
||||
|
||||
subscribe AIC7770-LIST <your name here, without the angle brackets>
|
||||
|
||||
Please direct questions and discussions to that list instead of me. When
|
||||
sending bug reports, please include a description of your hardware, the
|
||||
release numbers displayed by the driver at boot time, and as accurate a
|
||||
facsimilie of any error message you're mailing about.
|
||||
|
||||
John Aycock
|
||||
aycock@cpsc.ucalgary.ca
|
19
sys/gnu/misc/aic7770/README-FIRST
Normal file
19
sys/gnu/misc/aic7770/README-FIRST
Normal file
@ -0,0 +1,19 @@
|
||||
This is VERY MUCH ALPHA SOFTWARE. You MUST know what you're doing to
|
||||
use this, or else!!!
|
||||
|
||||
Ok, everything's been renamed to reference an "aic7xxx" driver instead
|
||||
of "aha274x", and a merger of the two PCI patches I had has been put in,
|
||||
along with re-doing the detection and configuration routines. To summarize
|
||||
the status: it compiles cleanly. I don't expect it to work off the bat,
|
||||
but it's for the 294x development people to synchronize their code
|
||||
together.
|
||||
|
||||
The file scsi-diffs-1.1.59 is NOT a proper patch file, but some diffs
|
||||
to kernel files concatenated together. I've sent these off to Drew,
|
||||
but if you're testing this you'll have to apply them - it allows a
|
||||
per-driver-instance can_queue variable, which for the aic7xxx driver
|
||||
is the number of SCBs the card supports.
|
||||
|
||||
Good luck! I await your comments.. Mark, Alan - let me know where I
|
||||
broke it, please ;-)
|
||||
:ja
|
54
sys/gnu/misc/aic7770/aic7770.1
Normal file
54
sys/gnu/misc/aic7770/aic7770.1
Normal file
@ -0,0 +1,54 @@
|
||||
.\" Copyright (c) 1994
|
||||
.\" Justin T. Gibbs. All rights reserved.
|
||||
.\"
|
||||
.\" Redistribution and use in source and binary forms, with or without
|
||||
.\" modification, are permitted provided that the following conditions
|
||||
.\" are met:
|
||||
.\" 1. Redistributions of source code must retain the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer.
|
||||
.\" 2. Redistributions in binary form must reproduce the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer in the
|
||||
.\" documentation and/or other materials provided with the distribution.
|
||||
.\" 3. All advertising materials mentioning features or use of this software
|
||||
.\" must display the following acknowledgement:
|
||||
.\" This product includes software developed by Justin T. Gibbs.
|
||||
.\" 4. The name of Justin T. Gibbs may not be used to endorse or promote
|
||||
.\" products derived from this software without specific prior written
|
||||
.\" permission.
|
||||
.\"
|
||||
.\" THIS SOFTWARE IS PROVIDED BY JUSTIN T. GIBBS ``AS IS'' AND
|
||||
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
.\" SUCH DAMAGE.
|
||||
.\"
|
||||
.\" @(#)aic7770.1 11/15/94
|
||||
.\"
|
||||
.Dd November 11, 1994
|
||||
.Dt AIC7770 1
|
||||
.Os BSD 4
|
||||
.Sh NAME
|
||||
.Nm aic7770
|
||||
.Nd aic7770 SCSI controller assembler
|
||||
.Sh SYNOPSIS
|
||||
.Nm aic7770
|
||||
.Op Fl o destination
|
||||
.Ar source-file
|
||||
.Sh DESCRIPTION
|
||||
.Ar Source-file
|
||||
is a file containing Aic7770 compatible assembly code. The output of the
|
||||
assembler defaults to
|
||||
.Ar a.out
|
||||
but can be optionally redirected to
|
||||
.Ar destination.
|
||||
.Pp
|
||||
.Sh AUTHOR
|
||||
This aic7770 compiler was written by John Aycock (aycock@cpsc.ucalgary.ca) and
|
||||
is subject to the GNU Public License.
|
||||
|
584
sys/gnu/misc/aic7770/aic7770.c
Normal file
584
sys/gnu/misc/aic7770/aic7770.c
Normal file
@ -0,0 +1,584 @@
|
||||
/*
|
||||
* Adaptec 274x device driver for Linux.
|
||||
* Copyright (c) 1994 The University of Calgary Department of Computer Science.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* Comments are started by `#' and continue to the end of the line; lines
|
||||
* may be of the form:
|
||||
*
|
||||
* <label>*
|
||||
* <label>* <undef-sym> = <value>
|
||||
* <label>* <opcode> <operand>*
|
||||
*
|
||||
* A <label> is an <undef-sym> ending in a colon. Spaces, tabs, and commas
|
||||
* are token separators.
|
||||
*/
|
||||
|
||||
/* #define _POSIX_SOURCE 1 */
|
||||
#define _POSIX_C_SOURCE 2
|
||||
|
||||
#include <ctype.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#define MEMORY 512 /* 2^9 29-bit words */
|
||||
#define MAXLINE 1024
|
||||
#define MAXTOKEN 32
|
||||
#define ADOTOUT "a.out"
|
||||
#define NOVALUE -1
|
||||
|
||||
/*
|
||||
* AIC-7770 register definitions
|
||||
*/
|
||||
#define R_SINDEX 0x65
|
||||
#define R_ALLONES 0x69
|
||||
#define R_ALLZEROS 0x6a
|
||||
#define R_NONE 0x6a
|
||||
|
||||
static
|
||||
char sccsid[] =
|
||||
"@(#)aic7770.c 1.10 94/07/22 jda";
|
||||
|
||||
int debug;
|
||||
int lineno, LC;
|
||||
char *filename;
|
||||
FILE *ifp, *ofp;
|
||||
unsigned char M[MEMORY][4];
|
||||
|
||||
void error(char *s)
|
||||
{
|
||||
fprintf(stderr, "%s: %s at line %d\n", filename, s, lineno);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
void *Malloc(size_t size)
|
||||
{
|
||||
void *p = malloc(size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
void *Realloc(void *ptr, size_t size)
|
||||
{
|
||||
void *p = realloc(ptr, size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
char *Strdup(char *s)
|
||||
{
|
||||
char *p = (char *)Malloc(strlen(s) + 1);
|
||||
strcpy(p, s);
|
||||
return(p);
|
||||
}
|
||||
|
||||
typedef struct sym_t {
|
||||
struct sym_t *next; /* MUST BE FIRST */
|
||||
char *name;
|
||||
int value;
|
||||
int npatch, *patch;
|
||||
} sym_t;
|
||||
|
||||
sym_t *head;
|
||||
|
||||
void define(char *name, int value)
|
||||
{
|
||||
sym_t *p, *q;
|
||||
|
||||
for (p = head, q = (sym_t *)&head; p; p = p->next) {
|
||||
if (!strcmp(p->name, name))
|
||||
error("redefined symbol");
|
||||
q = p;
|
||||
}
|
||||
|
||||
p = q->next = (sym_t *)Malloc(sizeof(sym_t));
|
||||
p->next = NULL;
|
||||
p->name = Strdup(name);
|
||||
p->value = value;
|
||||
p->npatch = 0;
|
||||
p->patch = NULL;
|
||||
|
||||
if (debug) {
|
||||
fprintf(stderr, "\"%s\" ", p->name);
|
||||
if (p->value != NOVALUE)
|
||||
fprintf(stderr, "defined as 0x%x\n", p->value);
|
||||
else
|
||||
fprintf(stderr, "undefined\n");
|
||||
}
|
||||
}
|
||||
|
||||
sym_t *lookup(char *name)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next)
|
||||
if (!strcmp(p->name, name))
|
||||
return(p);
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
void patch(sym_t *p, int location)
|
||||
{
|
||||
p->npatch += 1;
|
||||
p->patch = (int *)Realloc(p->patch, p->npatch * sizeof(int *));
|
||||
|
||||
p->patch[p->npatch - 1] = location;
|
||||
}
|
||||
|
||||
void backpatch(void)
|
||||
{
|
||||
int i;
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next) {
|
||||
|
||||
if (p->value == NOVALUE) {
|
||||
fprintf(stderr,
|
||||
"%s: undefined symbol \"%s\"\n",
|
||||
filename, p->name);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (p->npatch) {
|
||||
if (debug)
|
||||
fprintf(stderr,
|
||||
"\"%s\" (0x%x) patched at",
|
||||
p->name, p->value);
|
||||
|
||||
for (i = 0; i < p->npatch; i++) {
|
||||
M[p->patch[i]][0] &= ~1;
|
||||
M[p->patch[i]][0] |= ((p->value >> 8) & 1);
|
||||
M[p->patch[i]][1] = p->value & 0xff;
|
||||
|
||||
if (debug)
|
||||
fprintf(stderr, " 0x%x", p->patch[i]);
|
||||
}
|
||||
|
||||
if (debug)
|
||||
fputc('\n', stderr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Output words in byte-reversed order (least significant first)
|
||||
* since the sequencer RAM is loaded that way.
|
||||
*/
|
||||
void output(FILE *fp)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < LC; i++)
|
||||
fprintf(fp, "\t0x%02x, 0x%02x, 0x%02x, 0x%02x,\n",
|
||||
M[i][3],
|
||||
M[i][2],
|
||||
M[i][1],
|
||||
M[i][0]);
|
||||
}
|
||||
|
||||
char **getl(int *n)
|
||||
{
|
||||
int i;
|
||||
char *p;
|
||||
static char buf[MAXLINE];
|
||||
static char *a[MAXTOKEN];
|
||||
|
||||
i = 0;
|
||||
|
||||
while (fgets(buf, sizeof(buf), ifp)) {
|
||||
|
||||
lineno += 1;
|
||||
|
||||
if (buf[strlen(buf)-1] != '\n')
|
||||
error("line too long");
|
||||
|
||||
p = strchr(buf, '#');
|
||||
if (p)
|
||||
*p = '\0';
|
||||
|
||||
for (p = strtok(buf, ", \t\n"); p; p = strtok(NULL, ", \t\n"))
|
||||
if (i < MAXTOKEN-1)
|
||||
a[i++] = p;
|
||||
else
|
||||
error("too many tokens");
|
||||
if (i) {
|
||||
*n = i;
|
||||
return(a);
|
||||
}
|
||||
}
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
#define A 0x8000 /* `A'ccumulator ok */
|
||||
#define I 0x4000 /* use as immediate value */
|
||||
#define SL 0x2000 /* shift left */
|
||||
#define SR 0x1000 /* shift right */
|
||||
#define RL 0x0800 /* rotate left */
|
||||
#define RR 0x0400 /* rotate right */
|
||||
#define LO 0x8000 /* lookup: ori-{jmp,jc,jnc,call} */
|
||||
#define LA 0x4000 /* lookup: and-{jz,jnz} */
|
||||
#define LX 0x2000 /* lookup: xor-{je,jne} */
|
||||
#define NA -1 /* not applicable */
|
||||
|
||||
struct {
|
||||
char *name;
|
||||
int n; /* number of operands, including opcode */
|
||||
unsigned int op; /* immediate or L?|pos_from_0 */
|
||||
unsigned int dest; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int src; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int imm; /* pos_from_0, A|pos_from_0, or I|immediate */
|
||||
unsigned int addr; /* NA or pos_from_0 */
|
||||
int fmt; /* instruction format - 1, 2, or 3 */
|
||||
} instr[] = {
|
||||
/*
|
||||
* N OP DEST SRC IMM ADDR FMT
|
||||
*/
|
||||
"mov", 3, 1, 1, 2, I|0xff, NA, 1,
|
||||
"mov", 4, LO|2, NA, 1, I|0, 3, 3,
|
||||
"mvi", 3, 0, 1, I|R_ALLZEROS, A|2, NA, 1,
|
||||
"mvi", 4, LO|2, NA, I|R_ALLZEROS, 1, 3, 3,
|
||||
"not", 2, 2, 1, 1, I|0xff, NA, 1,
|
||||
"not", 3, 2, 1, 2, I|0xff, NA, 1,
|
||||
"and", 3, 1, 1, 1, A|2, NA, 1,
|
||||
"and", 4, 1, 1, 3, A|2, NA, 1,
|
||||
"or", 3, 0, 1, 1, A|2, NA, 1,
|
||||
"or", 4, 0, 1, 3, A|2, NA, 1,
|
||||
"or", 5, LO|3, NA, 1, 2, 4, 3,
|
||||
"xor", 3, 2, 1, 1, A|2, NA, 1,
|
||||
"xor", 4, 2, 1, 3, A|2, NA, 1,
|
||||
"nop", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"inc", 2, 3, 1, 1, I|1, NA, 1,
|
||||
"inc", 3, 3, 1, 2, I|1, NA, 1,
|
||||
"dec", 2, 3, 1, 1, I|0xff, NA, 1,
|
||||
"dec", 3, 3, 1, 2, I|0xff, NA, 1,
|
||||
"jmp", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jnc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"call", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"test", 5, LA|3, NA, 1, A|2, 4, 3,
|
||||
"cmp", 5, LX|3, NA, 1, A|2, 4, 3,
|
||||
"ret", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"clc", 1, 3, I|R_NONE, I|R_ALLZEROS, I|1, NA, 1,
|
||||
"clc", 4, 3, 2, I|R_ALLZEROS, A|3, NA, 1,
|
||||
"stc", 1, 3, I|R_NONE, I|R_ALLONES, I|1, NA, 1,
|
||||
"stc", 2, 3, 1, I|R_ALLONES, I|1, NA, 1,
|
||||
"add", 3, 3, 1, 1, A|2, NA, 1,
|
||||
"add", 4, 3, 1, 3, A|2, NA, 1,
|
||||
"adc", 3, 4, 1, 1, A|2, NA, 1,
|
||||
"adc", 4, 4, 1, 3, A|2, NA, 1,
|
||||
"shl", 3, 5, 1, 1, SL|2, NA, 2,
|
||||
"shl", 4, 5, 1, 2, SL|3, NA, 2,
|
||||
"shr", 3, 5, 1, 1, SR|2, NA, 2,
|
||||
"shr", 4, 5, 1, 2, SR|3, NA, 2,
|
||||
"rol", 3, 5, 1, 1, RL|2, NA, 2,
|
||||
"rol", 4, 5, 1, 2, RL|3, NA, 2,
|
||||
"ror", 3, 5, 1, 1, RR|2, NA, 2,
|
||||
"ror", 4, 5, 1, 2, RR|3, NA, 2,
|
||||
/*
|
||||
* Extensions (note also that mvi allows A)
|
||||
*/
|
||||
"clr", 2, 1, 1, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
0
|
||||
};
|
||||
|
||||
int eval_operand(char **a, int spec)
|
||||
{
|
||||
int i;
|
||||
unsigned int want = spec & (LO|LA|LX);
|
||||
|
||||
static struct {
|
||||
unsigned int what;
|
||||
char *name;
|
||||
int value;
|
||||
} jmptab[] = {
|
||||
LO, "jmp", 8,
|
||||
LO, "jc", 9,
|
||||
LO, "jnc", 10,
|
||||
LO, "call", 11,
|
||||
LA, "jz", 15,
|
||||
LA, "jnz", 13,
|
||||
LX, "je", 14,
|
||||
LX, "jne", 12,
|
||||
};
|
||||
|
||||
spec &= ~(LO|LA|LX);
|
||||
|
||||
for (i = 0; i < sizeof(jmptab)/sizeof(jmptab[0]); i++)
|
||||
if (jmptab[i].what == want &&
|
||||
!strcmp(jmptab[i].name, a[spec]))
|
||||
{
|
||||
return(jmptab[i].value);
|
||||
}
|
||||
|
||||
if (want)
|
||||
error("invalid jump");
|
||||
|
||||
return(spec); /* "case 0" - no flags set */
|
||||
}
|
||||
|
||||
int eval_sdi(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
unsigned val;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
|
||||
switch (spec & (A|I|SL|SR|RL|RR)) {
|
||||
case SL:
|
||||
case SR:
|
||||
case RL:
|
||||
case RR:
|
||||
if (isdigit(*a[spec &~ (SL|SR|RL|RR)]))
|
||||
val = strtol(a[spec &~ (SL|SR|RL|RR)], NULL, 0);
|
||||
else {
|
||||
p = lookup(a[spec &~ (SL|SR|RL|RR)]);
|
||||
if (!p)
|
||||
error("undefined symbol used");
|
||||
val = p->value;
|
||||
}
|
||||
|
||||
switch (spec & (SL|SR|RL|RR)) { /* blech */
|
||||
case SL:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(val % 8));
|
||||
case SR:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(1 << 3) |
|
||||
((8 - (val % 8)) % 8));
|
||||
case RL:
|
||||
return(val % 8);
|
||||
case RR:
|
||||
return((8 - (val % 8)) % 8);
|
||||
}
|
||||
case I:
|
||||
return(spec &~ I);
|
||||
case A:
|
||||
/*
|
||||
* An immediate field of zero selects
|
||||
* the accumulator. Vigorously object
|
||||
* if zero is given otherwise - it's
|
||||
* most likely an error.
|
||||
*/
|
||||
spec &= ~A;
|
||||
if (!strcmp("A", a[spec]))
|
||||
return(0);
|
||||
if (isdigit(*a[spec]) &&
|
||||
strtol(a[spec], NULL, 0) == 0)
|
||||
{
|
||||
error("immediate value of zero selects accumulator");
|
||||
}
|
||||
/* falls through */
|
||||
case 0:
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
p = lookup(a[spec]);
|
||||
if (p)
|
||||
return(p->value);
|
||||
error("undefined symbol used");
|
||||
}
|
||||
|
||||
return(NA); /* shut the compiler up */
|
||||
}
|
||||
|
||||
int eval_addr(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
|
||||
p = lookup(a[spec]);
|
||||
|
||||
if (p) {
|
||||
if (p->value != NOVALUE)
|
||||
return(p->value);
|
||||
patch(p, LC);
|
||||
} else {
|
||||
define(a[spec], NOVALUE);
|
||||
p = lookup(a[spec]);
|
||||
patch(p, LC);
|
||||
}
|
||||
|
||||
return(NA); /* will be patched in later */
|
||||
}
|
||||
|
||||
int crack(char **a, int n)
|
||||
{
|
||||
int i;
|
||||
int I_imm, I_addr;
|
||||
int I_op, I_dest, I_src, I_ret;
|
||||
|
||||
/*
|
||||
* Check for "ret" at the end of the line; remove
|
||||
* it unless it's "ret" alone - we still want to
|
||||
* look it up in the table.
|
||||
*/
|
||||
I_ret = (strcmp(a[n-1], "ret") ? 0 : !0);
|
||||
if (I_ret && n > 1)
|
||||
n -= 1;
|
||||
|
||||
for (i = 0; instr[i].name; i++) {
|
||||
/*
|
||||
* Look for match in table given constraints,
|
||||
* currently just the name and the number of
|
||||
* operands.
|
||||
*/
|
||||
if (!strcmp(instr[i].name, *a) && instr[i].n == n)
|
||||
break;
|
||||
}
|
||||
if (!instr[i].name)
|
||||
error("unknown opcode or wrong number of operands");
|
||||
|
||||
I_op = eval_operand(a, instr[i].op);
|
||||
I_src = eval_sdi(a, instr[i].src);
|
||||
I_imm = eval_sdi(a, instr[i].imm);
|
||||
I_dest = eval_sdi(a, instr[i].dest);
|
||||
I_addr = eval_addr(a, instr[i].addr);
|
||||
|
||||
switch (instr[i].fmt) {
|
||||
case 1:
|
||||
case 2:
|
||||
M[LC][0] = (I_op << 1) | I_ret;
|
||||
M[LC][1] = I_dest;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
case 3:
|
||||
if (I_ret)
|
||||
error("illegal use of \"ret\"");
|
||||
M[LC][0] = (I_op << 1) | ((I_addr >> 8) & 1);
|
||||
M[LC][1] = I_addr & 0xff;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
}
|
||||
|
||||
return(1); /* no two-byte instructions yet */
|
||||
}
|
||||
|
||||
#undef SL
|
||||
#undef SR
|
||||
#undef RL
|
||||
#undef RR
|
||||
#undef LX
|
||||
#undef LA
|
||||
#undef LO
|
||||
#undef I
|
||||
#undef A
|
||||
|
||||
void assemble(void)
|
||||
{
|
||||
int n;
|
||||
char **a;
|
||||
sym_t *p;
|
||||
|
||||
while ((a = getl(&n))) {
|
||||
|
||||
while (a[0][strlen(*a)-1] == ':') {
|
||||
a[0][strlen(*a)-1] = '\0';
|
||||
p = lookup(*a);
|
||||
if (p)
|
||||
p->value = LC;
|
||||
else
|
||||
define(*a, LC);
|
||||
a += 1;
|
||||
n -= 1;
|
||||
}
|
||||
|
||||
if (!n) /* line was all labels */
|
||||
continue;
|
||||
|
||||
if (n == 3 && !strcmp("VERSION", *a))
|
||||
fprintf(ofp, "#define %s \"%s\"\n", a[1], a[2]);
|
||||
else {
|
||||
if (n == 3 && !strcmp("=", a[1]))
|
||||
define(*a, strtol(a[2], NULL, 0));
|
||||
else
|
||||
LC += crack(a, n);
|
||||
}
|
||||
}
|
||||
|
||||
backpatch();
|
||||
output(ofp);
|
||||
|
||||
if (debug)
|
||||
output(stderr);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ((c = getopt(argc, argv, "dho:")) != EOF) {
|
||||
switch (c) {
|
||||
case 'd':
|
||||
debug = !0;
|
||||
break;
|
||||
case 'o':
|
||||
ofp = fopen(optarg, "w");
|
||||
if (!ofp) {
|
||||
perror(optarg);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
break;
|
||||
case 'h':
|
||||
printf("usage: %s [-d] [-ooutput] input\n", *argv);
|
||||
exit(EXIT_SUCCESS);
|
||||
case NULL:
|
||||
/*
|
||||
* An impossible option to shut the compiler
|
||||
* up about sccsid[].
|
||||
*/
|
||||
exit((int)sccsid);
|
||||
default:
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
if (argc - optind != 1) {
|
||||
fprintf(stderr, "%s: must have one input file\n", *argv);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
filename = argv[optind];
|
||||
|
||||
ifp = fopen(filename, "r");
|
||||
if (!ifp) {
|
||||
perror(filename);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (!ofp) {
|
||||
ofp = fopen(ADOTOUT, "w");
|
||||
if (!ofp) {
|
||||
perror(ADOTOUT);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
assemble();
|
||||
exit(EXIT_SUCCESS);
|
||||
}
|
1064
sys/gnu/misc/aic7770/aic7770.seq
Normal file
1064
sys/gnu/misc/aic7770/aic7770.seq
Normal file
File diff suppressed because it is too large
Load Diff
339
sys/gnu/misc/aic7xxx/COPYING
Normal file
339
sys/gnu/misc/aic7xxx/COPYING
Normal file
@ -0,0 +1,339 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 2, June 1991
|
||||
|
||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
||||
675 Mass Ave, Cambridge, MA 02139, USA
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The licenses for most software are designed to take away your
|
||||
freedom to share and change it. By contrast, the GNU General Public
|
||||
License is intended to guarantee your freedom to share and change free
|
||||
software--to make sure the software is free for all its users. This
|
||||
General Public License applies to most of the Free Software
|
||||
Foundation's software and to any other program whose authors commit to
|
||||
using it. (Some other Free Software Foundation software is covered by
|
||||
the GNU Library General Public License instead.) You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
this service if you wish), that you receive source code or can get it
|
||||
if you want it, that you can change the software or use pieces of it
|
||||
in new free programs; and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to make restrictions that forbid
|
||||
anyone to deny you these rights or to ask you to surrender the rights.
|
||||
These restrictions translate to certain responsibilities for you if you
|
||||
distribute copies of the software, or if you modify it.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must give the recipients all the rights that
|
||||
you have. You must make sure that they, too, receive or can get the
|
||||
source code. And you must show them these terms so they know their
|
||||
rights.
|
||||
|
||||
We protect your rights with two steps: (1) copyright the software, and
|
||||
(2) offer you this license which gives you legal permission to copy,
|
||||
distribute and/or modify the software.
|
||||
|
||||
Also, for each author's protection and ours, we want to make certain
|
||||
that everyone understands that there is no warranty for this free
|
||||
software. If the software is modified by someone else and passed on, we
|
||||
want its recipients to know that what they have is not the original, so
|
||||
that any problems introduced by others will not reflect on the original
|
||||
authors' reputations.
|
||||
|
||||
Finally, any free program is threatened constantly by software
|
||||
patents. We wish to avoid the danger that redistributors of a free
|
||||
program will individually obtain patent licenses, in effect making the
|
||||
program proprietary. To prevent this, we have made it clear that any
|
||||
patent must be licensed for everyone's free use or not licensed at all.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License applies to any program or other work which contains
|
||||
a notice placed by the copyright holder saying it may be distributed
|
||||
under the terms of this General Public License. The "Program", below,
|
||||
refers to any such program or work, and a "work based on the Program"
|
||||
means either the Program or any derivative work under copyright law:
|
||||
that is to say, a work containing the Program or a portion of it,
|
||||
either verbatim or with modifications and/or translated into another
|
||||
language. (Hereinafter, translation is included without limitation in
|
||||
the term "modification".) Each licensee is addressed as "you".
|
||||
|
||||
Activities other than copying, distribution and modification are not
|
||||
covered by this License; they are outside its scope. The act of
|
||||
running the Program is not restricted, and the output from the Program
|
||||
is covered only if its contents constitute a work based on the
|
||||
Program (independent of having been made by running the Program).
|
||||
Whether that is true depends on what the Program does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Program's
|
||||
source code as you receive it, in any medium, provided that you
|
||||
conspicuously and appropriately publish on each copy an appropriate
|
||||
copyright notice and disclaimer of warranty; keep intact all the
|
||||
notices that refer to this License and to the absence of any warranty;
|
||||
and give any other recipients of the Program a copy of this License
|
||||
along with the Program.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy, and
|
||||
you may at your option offer warranty protection in exchange for a fee.
|
||||
|
||||
2. You may modify your copy or copies of the Program or any portion
|
||||
of it, thus forming a work based on the Program, and copy and
|
||||
distribute such modifications or work under the terms of Section 1
|
||||
above, provided that you also meet all of these conditions:
|
||||
|
||||
a) You must cause the modified files to carry prominent notices
|
||||
stating that you changed the files and the date of any change.
|
||||
|
||||
b) You must cause any work that you distribute or publish, that in
|
||||
whole or in part contains or is derived from the Program or any
|
||||
part thereof, to be licensed as a whole at no charge to all third
|
||||
parties under the terms of this License.
|
||||
|
||||
c) If the modified program normally reads commands interactively
|
||||
when run, you must cause it, when started running for such
|
||||
interactive use in the most ordinary way, to print or display an
|
||||
announcement including an appropriate copyright notice and a
|
||||
notice that there is no warranty (or else, saying that you provide
|
||||
a warranty) and that users may redistribute the program under
|
||||
these conditions, and telling the user how to view a copy of this
|
||||
License. (Exception: if the Program itself is interactive but
|
||||
does not normally print such an announcement, your work based on
|
||||
the Program is not required to print an announcement.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If
|
||||
identifiable sections of that work are not derived from the Program,
|
||||
and can be reasonably considered independent and separate works in
|
||||
themselves, then this License, and its terms, do not apply to those
|
||||
sections when you distribute them as separate works. But when you
|
||||
distribute the same sections as part of a whole which is a work based
|
||||
on the Program, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the
|
||||
entire whole, and thus to each and every part regardless of who wrote it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest
|
||||
your rights to work written entirely by you; rather, the intent is to
|
||||
exercise the right to control the distribution of derivative or
|
||||
collective works based on the Program.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Program
|
||||
with the Program (or with a work based on the Program) on a volume of
|
||||
a storage or distribution medium does not bring the other work under
|
||||
the scope of this License.
|
||||
|
||||
3. You may copy and distribute the Program (or a work based on it,
|
||||
under Section 2) in object code or executable form under the terms of
|
||||
Sections 1 and 2 above provided that you also do one of the following:
|
||||
|
||||
a) Accompany it with the complete corresponding machine-readable
|
||||
source code, which must be distributed under the terms of Sections
|
||||
1 and 2 above on a medium customarily used for software interchange; or,
|
||||
|
||||
b) Accompany it with a written offer, valid for at least three
|
||||
years, to give any third party, for a charge no more than your
|
||||
cost of physically performing source distribution, a complete
|
||||
machine-readable copy of the corresponding source code, to be
|
||||
distributed under the terms of Sections 1 and 2 above on a medium
|
||||
customarily used for software interchange; or,
|
||||
|
||||
c) Accompany it with the information you received as to the offer
|
||||
to distribute corresponding source code. (This alternative is
|
||||
allowed only for noncommercial distribution and only if you
|
||||
received the program in object code or executable form with such
|
||||
an offer, in accord with Subsection b above.)
|
||||
|
||||
The source code for a work means the preferred form of the work for
|
||||
making modifications to it. For an executable work, complete source
|
||||
code means all the source code for all modules it contains, plus any
|
||||
associated interface definition files, plus the scripts used to
|
||||
control compilation and installation of the executable. However, as a
|
||||
special exception, the source code distributed need not include
|
||||
anything that is normally distributed (in either source or binary
|
||||
form) with the major components (compiler, kernel, and so on) of the
|
||||
operating system on which the executable runs, unless that component
|
||||
itself accompanies the executable.
|
||||
|
||||
If distribution of executable or object code is made by offering
|
||||
access to copy from a designated place, then offering equivalent
|
||||
access to copy the source code from the same place counts as
|
||||
distribution of the source code, even though third parties are not
|
||||
compelled to copy the source along with the object code.
|
||||
|
||||
4. You may not copy, modify, sublicense, or distribute the Program
|
||||
except as expressly provided under this License. Any attempt
|
||||
otherwise to copy, modify, sublicense or distribute the Program is
|
||||
void, and will automatically terminate your rights under this License.
|
||||
However, parties who have received copies, or rights, from you under
|
||||
this License will not have their licenses terminated so long as such
|
||||
parties remain in full compliance.
|
||||
|
||||
5. You are not required to accept this License, since you have not
|
||||
signed it. However, nothing else grants you permission to modify or
|
||||
distribute the Program or its derivative works. These actions are
|
||||
prohibited by law if you do not accept this License. Therefore, by
|
||||
modifying or distributing the Program (or any work based on the
|
||||
Program), you indicate your acceptance of this License to do so, and
|
||||
all its terms and conditions for copying, distributing or modifying
|
||||
the Program or works based on it.
|
||||
|
||||
6. Each time you redistribute the Program (or any work based on the
|
||||
Program), the recipient automatically receives a license from the
|
||||
original licensor to copy, distribute or modify the Program subject to
|
||||
these terms and conditions. You may not impose any further
|
||||
restrictions on the recipients' exercise of the rights granted herein.
|
||||
You are not responsible for enforcing compliance by third parties to
|
||||
this License.
|
||||
|
||||
7. If, as a consequence of a court judgment or allegation of patent
|
||||
infringement or for any other reason (not limited to patent issues),
|
||||
conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot
|
||||
distribute so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you
|
||||
may not distribute the Program at all. For example, if a patent
|
||||
license would not permit royalty-free redistribution of the Program by
|
||||
all those who receive copies directly or indirectly through you, then
|
||||
the only way you could satisfy both it and this License would be to
|
||||
refrain entirely from distribution of the Program.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under
|
||||
any particular circumstance, the balance of the section is intended to
|
||||
apply and the section as a whole is intended to apply in other
|
||||
circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any
|
||||
patents or other property right claims or to contest validity of any
|
||||
such claims; this section has the sole purpose of protecting the
|
||||
integrity of the free software distribution system, which is
|
||||
implemented by public license practices. Many people have made
|
||||
generous contributions to the wide range of software distributed
|
||||
through that system in reliance on consistent application of that
|
||||
system; it is up to the author/donor to decide if he or she is willing
|
||||
to distribute software through any other system and a licensee cannot
|
||||
impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to
|
||||
be a consequence of the rest of this License.
|
||||
|
||||
8. If the distribution and/or use of the Program is restricted in
|
||||
certain countries either by patents or by copyrighted interfaces, the
|
||||
original copyright holder who places the Program under this License
|
||||
may add an explicit geographical distribution limitation excluding
|
||||
those countries, so that distribution is permitted only in or among
|
||||
countries not thus excluded. In such case, this License incorporates
|
||||
the limitation as if written in the body of this License.
|
||||
|
||||
9. The Free Software Foundation may publish revised and/or new versions
|
||||
of the General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program
|
||||
specifies a version number of this License which applies to it and "any
|
||||
later version", you have the option of following the terms and conditions
|
||||
either of that version or of any later version published by the Free
|
||||
Software Foundation. If the Program does not specify a version number of
|
||||
this License, you may choose any version ever published by the Free Software
|
||||
Foundation.
|
||||
|
||||
10. If you wish to incorporate parts of the Program into other free
|
||||
programs whose distribution conditions are different, write to the author
|
||||
to ask for permission. For software which is copyrighted by the Free
|
||||
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||
make exceptions for this. Our decision will be guided by the two goals
|
||||
of preserving the free status of all derivatives of our free software and
|
||||
of promoting the sharing and reuse of software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||
REPAIR OR CORRECTION.
|
||||
|
||||
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||
POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
Appendix: How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
convey the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) 19yy <name of author>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program is interactive, make it output a short notice like this
|
||||
when it starts in an interactive mode:
|
||||
|
||||
Gnomovision version 69, Copyright (C) 19yy name of author
|
||||
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, the commands you use may
|
||||
be called something other than `show w' and `show c'; they could even be
|
||||
mouse-clicks or menu items--whatever suits your program.
|
||||
|
||||
You should also get your employer (if you work as a programmer) or your
|
||||
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||
necessary. Here is a sample; alter the names:
|
||||
|
||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||
|
||||
<signature of Ty Coon>, 1 April 1989
|
||||
Ty Coon, President of Vice
|
||||
|
||||
This General Public License does not permit incorporating your program into
|
||||
proprietary programs. If your program is a subroutine library, you may
|
||||
consider it more useful to permit linking proprietary applications with the
|
||||
library. If this is what you want to do, use the GNU Library General
|
||||
Public License instead of this License.
|
16
sys/gnu/misc/aic7xxx/COPYRIGHT
Normal file
16
sys/gnu/misc/aic7xxx/COPYRIGHT
Normal file
@ -0,0 +1,16 @@
|
||||
Adaptec 274x device driver for Linux.
|
||||
Copyright (c) 1994 The University of Calgary Department of Computer Science.
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
94
sys/gnu/misc/aic7xxx/README
Normal file
94
sys/gnu/misc/aic7xxx/README
Normal file
@ -0,0 +1,94 @@
|
||||
@(#)README 1.16 94/11/09 jda
|
||||
|
||||
AHA274x/284x DRIVER
|
||||
|
||||
*** THIS SHOULD BE CONSIDERED BETA SOFTWARE ***
|
||||
|
||||
BACKGROUND & LIMITATIONS
|
||||
|
||||
For various reasons, we ended up with one of these cards under the
|
||||
impression that support was soon forthcoming. In mid-May, I asked
|
||||
Scott Ferris (the official person who's supposed to be writing this
|
||||
driver) what documentation he used, _finally_ got it from Adaptec,
|
||||
and started writing this driver. It is now at what I would consider
|
||||
a stable state - it runs our news server and is battered by SCSI
|
||||
requests 24 hours a day without dying. There are a few devices it
|
||||
reportedly doesn't like working with - those are being sorted out. Due
|
||||
to some unexpected equipment loans, I am able to support this at least
|
||||
for the time being.
|
||||
|
||||
YOU MUST HAVE THE BIOS ENABLED OR THIS WILL NOT WORK. The BIOS extracts
|
||||
some configuration information that I cannot get to portably yet, as
|
||||
well as provides some self-tests which this driver does not attempt to
|
||||
duplicate.
|
||||
|
||||
Scott's driver development is stalled for now, and after discussions
|
||||
with him, this is now officially out of "pre-alpha" status and into
|
||||
beta until the remaining device problems can be resolved. The latest
|
||||
patches can be obtained via anonymous ftp from ftp.cpsc.ucalgary.ca in
|
||||
/pub/systems/linux/aha274x.
|
||||
|
||||
It supports both EISA 274x and VL-bus 284x, either single or twin-bus cards
|
||||
(but not the second SCSI bus of twin cards - see aha274x.c), and supports
|
||||
disconnection, synchronous SCSI, and scatter-gather. Unlike previous
|
||||
versions, abort() and reset() are now implemented, and both hosts.c and
|
||||
aha274x.c should give a clean compile. Code is now present to detect parity
|
||||
errors, but has not been tested.
|
||||
|
||||
I wrote this using a 1.0.9 kernel. Unfortunately, I'm getting tired of
|
||||
#ifdef'ing everything to handle two or three different evolutionary steps
|
||||
in the SCSI kernel code, so I've upgraded my system to 1.1.49, and will
|
||||
only leave in code to support versions from about 1.1.45 onward.
|
||||
|
||||
Thanks to patches supplied by Mark Olson <molson@tricord.com>, this driver
|
||||
will now work with the 284x series (the VL-bus version of this card). The
|
||||
294x (PCI-bus) support is based on patches sent to me by Mark Olson and
|
||||
Alan Hourihane <alanh@fairlite.demon.co.uk>.
|
||||
|
||||
Under protest, this driver is subject to the GPL - see the file
|
||||
COPYING for details.
|
||||
|
||||
Thanks to the following people for bug fixes/code improvements (also
|
||||
thanks to the people who have sent me feedback):
|
||||
|
||||
"David F. Carlson" <dave@ee.rochester.edu>
|
||||
Jimen Ching <jiching@wiliki.eng.hawaii.edu>
|
||||
mday@artisoft.com (Matt Day)
|
||||
"Dean W. Gehnert" <deang@ims.com>
|
||||
Darcy Grant <darcy@cpsc.ucalgary.ca>
|
||||
Alan Hourihane <alanh@fairlite.demon.co.uk>
|
||||
isely@fncrd8.fnal.gov (Mike Isely)
|
||||
Mike Jerger <jerger@ux1.cso.uiuc.edu>
|
||||
tm@netcom.com (Toshiyasu Morita)
|
||||
neal@interact.org (Neal Norwitz)
|
||||
Mark Olson <molson@tricord.com>
|
||||
map@europa.ecn.uoknor.edu (Michael A. Parker)
|
||||
Thomas Scheunemann <thomas@dagobert.uni-duisburg.de>
|
||||
|
||||
Special thanks to Drew Eckhardt <drew@kinglear.cs.Colorado.EDU> for
|
||||
fielding my questions about synchronous negotiation. Steffen Moeller
|
||||
<smoe0024@rz.uni-hildesheim.de> sent me installation instructions which
|
||||
were previously included in this README.
|
||||
|
||||
David Pirie <pirie@cpsc.ucalgary.ca> was nice enough to loan me his
|
||||
2842 card for a week so I could track down one bug, as well as his
|
||||
CD-ROM drive later, and also thanks to Doug Fortune at Riley's Data Share
|
||||
in Calgary, who arranged a long-term loan of a 2842 board for further work.
|
||||
|
||||
Many thanks to the fearless prerelease testers! Dean Gehnert has been
|
||||
building Slackware boot disks for the driver, which are available from
|
||||
ftp.cpsc.ucalgary.ca in /pub/systems/linux/aha274x/slackware_boot.
|
||||
|
||||
Carl Riches <cgr@poplar1.cfr.washington.edu> has set up a mailing list
|
||||
for aic7xxx driver development. To subscribe, send a message to
|
||||
aic7770-list@poplar1.cfr.washington.edu with a message body of:
|
||||
|
||||
subscribe AIC7770-LIST <your name here, without the angle brackets>
|
||||
|
||||
Please direct questions and discussions to that list instead of me. When
|
||||
sending bug reports, please include a description of your hardware, the
|
||||
release numbers displayed by the driver at boot time, and as accurate a
|
||||
facsimilie of any error message you're mailing about.
|
||||
|
||||
John Aycock
|
||||
aycock@cpsc.ucalgary.ca
|
19
sys/gnu/misc/aic7xxx/README-FIRST
Normal file
19
sys/gnu/misc/aic7xxx/README-FIRST
Normal file
@ -0,0 +1,19 @@
|
||||
This is VERY MUCH ALPHA SOFTWARE. You MUST know what you're doing to
|
||||
use this, or else!!!
|
||||
|
||||
Ok, everything's been renamed to reference an "aic7xxx" driver instead
|
||||
of "aha274x", and a merger of the two PCI patches I had has been put in,
|
||||
along with re-doing the detection and configuration routines. To summarize
|
||||
the status: it compiles cleanly. I don't expect it to work off the bat,
|
||||
but it's for the 294x development people to synchronize their code
|
||||
together.
|
||||
|
||||
The file scsi-diffs-1.1.59 is NOT a proper patch file, but some diffs
|
||||
to kernel files concatenated together. I've sent these off to Drew,
|
||||
but if you're testing this you'll have to apply them - it allows a
|
||||
per-driver-instance can_queue variable, which for the aic7xxx driver
|
||||
is the number of SCBs the card supports.
|
||||
|
||||
Good luck! I await your comments.. Mark, Alan - let me know where I
|
||||
broke it, please ;-)
|
||||
:ja
|
54
sys/gnu/misc/aic7xxx/aic7xxx.1
Normal file
54
sys/gnu/misc/aic7xxx/aic7xxx.1
Normal file
@ -0,0 +1,54 @@
|
||||
.\" Copyright (c) 1994
|
||||
.\" Justin T. Gibbs. All rights reserved.
|
||||
.\"
|
||||
.\" Redistribution and use in source and binary forms, with or without
|
||||
.\" modification, are permitted provided that the following conditions
|
||||
.\" are met:
|
||||
.\" 1. Redistributions of source code must retain the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer.
|
||||
.\" 2. Redistributions in binary form must reproduce the above copyright
|
||||
.\" notice, this list of conditions and the following disclaimer in the
|
||||
.\" documentation and/or other materials provided with the distribution.
|
||||
.\" 3. All advertising materials mentioning features or use of this software
|
||||
.\" must display the following acknowledgement:
|
||||
.\" This product includes software developed by Justin T. Gibbs.
|
||||
.\" 4. The name of Justin T. Gibbs may not be used to endorse or promote
|
||||
.\" products derived from this software without specific prior written
|
||||
.\" permission.
|
||||
.\"
|
||||
.\" THIS SOFTWARE IS PROVIDED BY JUSTIN T. GIBBS ``AS IS'' AND
|
||||
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
.\" SUCH DAMAGE.
|
||||
.\"
|
||||
.\" @(#)aic7770.1 11/15/94
|
||||
.\"
|
||||
.Dd November 11, 1994
|
||||
.Dt AIC7770 1
|
||||
.Os BSD 4
|
||||
.Sh NAME
|
||||
.Nm aic7770
|
||||
.Nd aic7770 SCSI controller assembler
|
||||
.Sh SYNOPSIS
|
||||
.Nm aic7770
|
||||
.Op Fl o destination
|
||||
.Ar source-file
|
||||
.Sh DESCRIPTION
|
||||
.Ar Source-file
|
||||
is a file containing Aic7770 compatible assembly code. The output of the
|
||||
assembler defaults to
|
||||
.Ar a.out
|
||||
but can be optionally redirected to
|
||||
.Ar destination.
|
||||
.Pp
|
||||
.Sh AUTHOR
|
||||
This aic7770 compiler was written by John Aycock (aycock@cpsc.ucalgary.ca) and
|
||||
is subject to the GNU Public License.
|
||||
|
584
sys/gnu/misc/aic7xxx/aic7xxx.c
Normal file
584
sys/gnu/misc/aic7xxx/aic7xxx.c
Normal file
@ -0,0 +1,584 @@
|
||||
/*
|
||||
* Adaptec 274x device driver for Linux.
|
||||
* Copyright (c) 1994 The University of Calgary Department of Computer Science.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
*
|
||||
* Comments are started by `#' and continue to the end of the line; lines
|
||||
* may be of the form:
|
||||
*
|
||||
* <label>*
|
||||
* <label>* <undef-sym> = <value>
|
||||
* <label>* <opcode> <operand>*
|
||||
*
|
||||
* A <label> is an <undef-sym> ending in a colon. Spaces, tabs, and commas
|
||||
* are token separators.
|
||||
*/
|
||||
|
||||
/* #define _POSIX_SOURCE 1 */
|
||||
#define _POSIX_C_SOURCE 2
|
||||
|
||||
#include <ctype.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#define MEMORY 512 /* 2^9 29-bit words */
|
||||
#define MAXLINE 1024
|
||||
#define MAXTOKEN 32
|
||||
#define ADOTOUT "a.out"
|
||||
#define NOVALUE -1
|
||||
|
||||
/*
|
||||
* AIC-7770 register definitions
|
||||
*/
|
||||
#define R_SINDEX 0x65
|
||||
#define R_ALLONES 0x69
|
||||
#define R_ALLZEROS 0x6a
|
||||
#define R_NONE 0x6a
|
||||
|
||||
static
|
||||
char sccsid[] =
|
||||
"@(#)aic7770.c 1.10 94/07/22 jda";
|
||||
|
||||
int debug;
|
||||
int lineno, LC;
|
||||
char *filename;
|
||||
FILE *ifp, *ofp;
|
||||
unsigned char M[MEMORY][4];
|
||||
|
||||
void error(char *s)
|
||||
{
|
||||
fprintf(stderr, "%s: %s at line %d\n", filename, s, lineno);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
void *Malloc(size_t size)
|
||||
{
|
||||
void *p = malloc(size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
void *Realloc(void *ptr, size_t size)
|
||||
{
|
||||
void *p = realloc(ptr, size);
|
||||
if (!p)
|
||||
error("out of memory");
|
||||
return(p);
|
||||
}
|
||||
|
||||
char *Strdup(char *s)
|
||||
{
|
||||
char *p = (char *)Malloc(strlen(s) + 1);
|
||||
strcpy(p, s);
|
||||
return(p);
|
||||
}
|
||||
|
||||
typedef struct sym_t {
|
||||
struct sym_t *next; /* MUST BE FIRST */
|
||||
char *name;
|
||||
int value;
|
||||
int npatch, *patch;
|
||||
} sym_t;
|
||||
|
||||
sym_t *head;
|
||||
|
||||
void define(char *name, int value)
|
||||
{
|
||||
sym_t *p, *q;
|
||||
|
||||
for (p = head, q = (sym_t *)&head; p; p = p->next) {
|
||||
if (!strcmp(p->name, name))
|
||||
error("redefined symbol");
|
||||
q = p;
|
||||
}
|
||||
|
||||
p = q->next = (sym_t *)Malloc(sizeof(sym_t));
|
||||
p->next = NULL;
|
||||
p->name = Strdup(name);
|
||||
p->value = value;
|
||||
p->npatch = 0;
|
||||
p->patch = NULL;
|
||||
|
||||
if (debug) {
|
||||
fprintf(stderr, "\"%s\" ", p->name);
|
||||
if (p->value != NOVALUE)
|
||||
fprintf(stderr, "defined as 0x%x\n", p->value);
|
||||
else
|
||||
fprintf(stderr, "undefined\n");
|
||||
}
|
||||
}
|
||||
|
||||
sym_t *lookup(char *name)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next)
|
||||
if (!strcmp(p->name, name))
|
||||
return(p);
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
void patch(sym_t *p, int location)
|
||||
{
|
||||
p->npatch += 1;
|
||||
p->patch = (int *)Realloc(p->patch, p->npatch * sizeof(int *));
|
||||
|
||||
p->patch[p->npatch - 1] = location;
|
||||
}
|
||||
|
||||
void backpatch(void)
|
||||
{
|
||||
int i;
|
||||
sym_t *p;
|
||||
|
||||
for (p = head; p; p = p->next) {
|
||||
|
||||
if (p->value == NOVALUE) {
|
||||
fprintf(stderr,
|
||||
"%s: undefined symbol \"%s\"\n",
|
||||
filename, p->name);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (p->npatch) {
|
||||
if (debug)
|
||||
fprintf(stderr,
|
||||
"\"%s\" (0x%x) patched at",
|
||||
p->name, p->value);
|
||||
|
||||
for (i = 0; i < p->npatch; i++) {
|
||||
M[p->patch[i]][0] &= ~1;
|
||||
M[p->patch[i]][0] |= ((p->value >> 8) & 1);
|
||||
M[p->patch[i]][1] = p->value & 0xff;
|
||||
|
||||
if (debug)
|
||||
fprintf(stderr, " 0x%x", p->patch[i]);
|
||||
}
|
||||
|
||||
if (debug)
|
||||
fputc('\n', stderr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Output words in byte-reversed order (least significant first)
|
||||
* since the sequencer RAM is loaded that way.
|
||||
*/
|
||||
void output(FILE *fp)
|
||||
{
|
||||
int i;
|
||||
|
||||
for (i = 0; i < LC; i++)
|
||||
fprintf(fp, "\t0x%02x, 0x%02x, 0x%02x, 0x%02x,\n",
|
||||
M[i][3],
|
||||
M[i][2],
|
||||
M[i][1],
|
||||
M[i][0]);
|
||||
}
|
||||
|
||||
char **getl(int *n)
|
||||
{
|
||||
int i;
|
||||
char *p;
|
||||
static char buf[MAXLINE];
|
||||
static char *a[MAXTOKEN];
|
||||
|
||||
i = 0;
|
||||
|
||||
while (fgets(buf, sizeof(buf), ifp)) {
|
||||
|
||||
lineno += 1;
|
||||
|
||||
if (buf[strlen(buf)-1] != '\n')
|
||||
error("line too long");
|
||||
|
||||
p = strchr(buf, '#');
|
||||
if (p)
|
||||
*p = '\0';
|
||||
|
||||
for (p = strtok(buf, ", \t\n"); p; p = strtok(NULL, ", \t\n"))
|
||||
if (i < MAXTOKEN-1)
|
||||
a[i++] = p;
|
||||
else
|
||||
error("too many tokens");
|
||||
if (i) {
|
||||
*n = i;
|
||||
return(a);
|
||||
}
|
||||
}
|
||||
return(NULL);
|
||||
}
|
||||
|
||||
#define A 0x8000 /* `A'ccumulator ok */
|
||||
#define I 0x4000 /* use as immediate value */
|
||||
#define SL 0x2000 /* shift left */
|
||||
#define SR 0x1000 /* shift right */
|
||||
#define RL 0x0800 /* rotate left */
|
||||
#define RR 0x0400 /* rotate right */
|
||||
#define LO 0x8000 /* lookup: ori-{jmp,jc,jnc,call} */
|
||||
#define LA 0x4000 /* lookup: and-{jz,jnz} */
|
||||
#define LX 0x2000 /* lookup: xor-{je,jne} */
|
||||
#define NA -1 /* not applicable */
|
||||
|
||||
struct {
|
||||
char *name;
|
||||
int n; /* number of operands, including opcode */
|
||||
unsigned int op; /* immediate or L?|pos_from_0 */
|
||||
unsigned int dest; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int src; /* NA, pos_from_0, or I|immediate */
|
||||
unsigned int imm; /* pos_from_0, A|pos_from_0, or I|immediate */
|
||||
unsigned int addr; /* NA or pos_from_0 */
|
||||
int fmt; /* instruction format - 1, 2, or 3 */
|
||||
} instr[] = {
|
||||
/*
|
||||
* N OP DEST SRC IMM ADDR FMT
|
||||
*/
|
||||
"mov", 3, 1, 1, 2, I|0xff, NA, 1,
|
||||
"mov", 4, LO|2, NA, 1, I|0, 3, 3,
|
||||
"mvi", 3, 0, 1, I|R_ALLZEROS, A|2, NA, 1,
|
||||
"mvi", 4, LO|2, NA, I|R_ALLZEROS, 1, 3, 3,
|
||||
"not", 2, 2, 1, 1, I|0xff, NA, 1,
|
||||
"not", 3, 2, 1, 2, I|0xff, NA, 1,
|
||||
"and", 3, 1, 1, 1, A|2, NA, 1,
|
||||
"and", 4, 1, 1, 3, A|2, NA, 1,
|
||||
"or", 3, 0, 1, 1, A|2, NA, 1,
|
||||
"or", 4, 0, 1, 3, A|2, NA, 1,
|
||||
"or", 5, LO|3, NA, 1, 2, 4, 3,
|
||||
"xor", 3, 2, 1, 1, A|2, NA, 1,
|
||||
"xor", 4, 2, 1, 3, A|2, NA, 1,
|
||||
"nop", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"inc", 2, 3, 1, 1, I|1, NA, 1,
|
||||
"inc", 3, 3, 1, 2, I|1, NA, 1,
|
||||
"dec", 2, 3, 1, 1, I|0xff, NA, 1,
|
||||
"dec", 3, 3, 1, 2, I|0xff, NA, 1,
|
||||
"jmp", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"jnc", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"call", 2, LO|0, NA, I|R_SINDEX, I|0, 1, 3,
|
||||
"test", 5, LA|3, NA, 1, A|2, 4, 3,
|
||||
"cmp", 5, LX|3, NA, 1, A|2, 4, 3,
|
||||
"ret", 1, 1, I|R_NONE, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
"clc", 1, 3, I|R_NONE, I|R_ALLZEROS, I|1, NA, 1,
|
||||
"clc", 4, 3, 2, I|R_ALLZEROS, A|3, NA, 1,
|
||||
"stc", 1, 3, I|R_NONE, I|R_ALLONES, I|1, NA, 1,
|
||||
"stc", 2, 3, 1, I|R_ALLONES, I|1, NA, 1,
|
||||
"add", 3, 3, 1, 1, A|2, NA, 1,
|
||||
"add", 4, 3, 1, 3, A|2, NA, 1,
|
||||
"adc", 3, 4, 1, 1, A|2, NA, 1,
|
||||
"adc", 4, 4, 1, 3, A|2, NA, 1,
|
||||
"shl", 3, 5, 1, 1, SL|2, NA, 2,
|
||||
"shl", 4, 5, 1, 2, SL|3, NA, 2,
|
||||
"shr", 3, 5, 1, 1, SR|2, NA, 2,
|
||||
"shr", 4, 5, 1, 2, SR|3, NA, 2,
|
||||
"rol", 3, 5, 1, 1, RL|2, NA, 2,
|
||||
"rol", 4, 5, 1, 2, RL|3, NA, 2,
|
||||
"ror", 3, 5, 1, 1, RR|2, NA, 2,
|
||||
"ror", 4, 5, 1, 2, RR|3, NA, 2,
|
||||
/*
|
||||
* Extensions (note also that mvi allows A)
|
||||
*/
|
||||
"clr", 2, 1, 1, I|R_ALLZEROS, I|0xff, NA, 1,
|
||||
0
|
||||
};
|
||||
|
||||
int eval_operand(char **a, int spec)
|
||||
{
|
||||
int i;
|
||||
unsigned int want = spec & (LO|LA|LX);
|
||||
|
||||
static struct {
|
||||
unsigned int what;
|
||||
char *name;
|
||||
int value;
|
||||
} jmptab[] = {
|
||||
LO, "jmp", 8,
|
||||
LO, "jc", 9,
|
||||
LO, "jnc", 10,
|
||||
LO, "call", 11,
|
||||
LA, "jz", 15,
|
||||
LA, "jnz", 13,
|
||||
LX, "je", 14,
|
||||
LX, "jne", 12,
|
||||
};
|
||||
|
||||
spec &= ~(LO|LA|LX);
|
||||
|
||||
for (i = 0; i < sizeof(jmptab)/sizeof(jmptab[0]); i++)
|
||||
if (jmptab[i].what == want &&
|
||||
!strcmp(jmptab[i].name, a[spec]))
|
||||
{
|
||||
return(jmptab[i].value);
|
||||
}
|
||||
|
||||
if (want)
|
||||
error("invalid jump");
|
||||
|
||||
return(spec); /* "case 0" - no flags set */
|
||||
}
|
||||
|
||||
int eval_sdi(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
unsigned val;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
|
||||
switch (spec & (A|I|SL|SR|RL|RR)) {
|
||||
case SL:
|
||||
case SR:
|
||||
case RL:
|
||||
case RR:
|
||||
if (isdigit(*a[spec &~ (SL|SR|RL|RR)]))
|
||||
val = strtol(a[spec &~ (SL|SR|RL|RR)], NULL, 0);
|
||||
else {
|
||||
p = lookup(a[spec &~ (SL|SR|RL|RR)]);
|
||||
if (!p)
|
||||
error("undefined symbol used");
|
||||
val = p->value;
|
||||
}
|
||||
|
||||
switch (spec & (SL|SR|RL|RR)) { /* blech */
|
||||
case SL:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(val % 8));
|
||||
case SR:
|
||||
if (val > 7)
|
||||
return(0xf0);
|
||||
return(((val % 8) << 4) |
|
||||
(1 << 3) |
|
||||
((8 - (val % 8)) % 8));
|
||||
case RL:
|
||||
return(val % 8);
|
||||
case RR:
|
||||
return((8 - (val % 8)) % 8);
|
||||
}
|
||||
case I:
|
||||
return(spec &~ I);
|
||||
case A:
|
||||
/*
|
||||
* An immediate field of zero selects
|
||||
* the accumulator. Vigorously object
|
||||
* if zero is given otherwise - it's
|
||||
* most likely an error.
|
||||
*/
|
||||
spec &= ~A;
|
||||
if (!strcmp("A", a[spec]))
|
||||
return(0);
|
||||
if (isdigit(*a[spec]) &&
|
||||
strtol(a[spec], NULL, 0) == 0)
|
||||
{
|
||||
error("immediate value of zero selects accumulator");
|
||||
}
|
||||
/* falls through */
|
||||
case 0:
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
p = lookup(a[spec]);
|
||||
if (p)
|
||||
return(p->value);
|
||||
error("undefined symbol used");
|
||||
}
|
||||
|
||||
return(NA); /* shut the compiler up */
|
||||
}
|
||||
|
||||
int eval_addr(char **a, int spec)
|
||||
{
|
||||
sym_t *p;
|
||||
|
||||
if (spec == NA)
|
||||
return(NA);
|
||||
if (isdigit(*a[spec]))
|
||||
return(strtol(a[spec], NULL, 0));
|
||||
|
||||
p = lookup(a[spec]);
|
||||
|
||||
if (p) {
|
||||
if (p->value != NOVALUE)
|
||||
return(p->value);
|
||||
patch(p, LC);
|
||||
} else {
|
||||
define(a[spec], NOVALUE);
|
||||
p = lookup(a[spec]);
|
||||
patch(p, LC);
|
||||
}
|
||||
|
||||
return(NA); /* will be patched in later */
|
||||
}
|
||||
|
||||
int crack(char **a, int n)
|
||||
{
|
||||
int i;
|
||||
int I_imm, I_addr;
|
||||
int I_op, I_dest, I_src, I_ret;
|
||||
|
||||
/*
|
||||
* Check for "ret" at the end of the line; remove
|
||||
* it unless it's "ret" alone - we still want to
|
||||
* look it up in the table.
|
||||
*/
|
||||
I_ret = (strcmp(a[n-1], "ret") ? 0 : !0);
|
||||
if (I_ret && n > 1)
|
||||
n -= 1;
|
||||
|
||||
for (i = 0; instr[i].name; i++) {
|
||||
/*
|
||||
* Look for match in table given constraints,
|
||||
* currently just the name and the number of
|
||||
* operands.
|
||||
*/
|
||||
if (!strcmp(instr[i].name, *a) && instr[i].n == n)
|
||||
break;
|
||||
}
|
||||
if (!instr[i].name)
|
||||
error("unknown opcode or wrong number of operands");
|
||||
|
||||
I_op = eval_operand(a, instr[i].op);
|
||||
I_src = eval_sdi(a, instr[i].src);
|
||||
I_imm = eval_sdi(a, instr[i].imm);
|
||||
I_dest = eval_sdi(a, instr[i].dest);
|
||||
I_addr = eval_addr(a, instr[i].addr);
|
||||
|
||||
switch (instr[i].fmt) {
|
||||
case 1:
|
||||
case 2:
|
||||
M[LC][0] = (I_op << 1) | I_ret;
|
||||
M[LC][1] = I_dest;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
case 3:
|
||||
if (I_ret)
|
||||
error("illegal use of \"ret\"");
|
||||
M[LC][0] = (I_op << 1) | ((I_addr >> 8) & 1);
|
||||
M[LC][1] = I_addr & 0xff;
|
||||
M[LC][2] = I_src;
|
||||
M[LC][3] = I_imm;
|
||||
break;
|
||||
}
|
||||
|
||||
return(1); /* no two-byte instructions yet */
|
||||
}
|
||||
|
||||
#undef SL
|
||||
#undef SR
|
||||
#undef RL
|
||||
#undef RR
|
||||
#undef LX
|
||||
#undef LA
|
||||
#undef LO
|
||||
#undef I
|
||||
#undef A
|
||||
|
||||
void assemble(void)
|
||||
{
|
||||
int n;
|
||||
char **a;
|
||||
sym_t *p;
|
||||
|
||||
while ((a = getl(&n))) {
|
||||
|
||||
while (a[0][strlen(*a)-1] == ':') {
|
||||
a[0][strlen(*a)-1] = '\0';
|
||||
p = lookup(*a);
|
||||
if (p)
|
||||
p->value = LC;
|
||||
else
|
||||
define(*a, LC);
|
||||
a += 1;
|
||||
n -= 1;
|
||||
}
|
||||
|
||||
if (!n) /* line was all labels */
|
||||
continue;
|
||||
|
||||
if (n == 3 && !strcmp("VERSION", *a))
|
||||
fprintf(ofp, "#define %s \"%s\"\n", a[1], a[2]);
|
||||
else {
|
||||
if (n == 3 && !strcmp("=", a[1]))
|
||||
define(*a, strtol(a[2], NULL, 0));
|
||||
else
|
||||
LC += crack(a, n);
|
||||
}
|
||||
}
|
||||
|
||||
backpatch();
|
||||
output(ofp);
|
||||
|
||||
if (debug)
|
||||
output(stderr);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
int c;
|
||||
|
||||
while ((c = getopt(argc, argv, "dho:")) != EOF) {
|
||||
switch (c) {
|
||||
case 'd':
|
||||
debug = !0;
|
||||
break;
|
||||
case 'o':
|
||||
ofp = fopen(optarg, "w");
|
||||
if (!ofp) {
|
||||
perror(optarg);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
break;
|
||||
case 'h':
|
||||
printf("usage: %s [-d] [-ooutput] input\n", *argv);
|
||||
exit(EXIT_SUCCESS);
|
||||
case NULL:
|
||||
/*
|
||||
* An impossible option to shut the compiler
|
||||
* up about sccsid[].
|
||||
*/
|
||||
exit((int)sccsid);
|
||||
default:
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
if (argc - optind != 1) {
|
||||
fprintf(stderr, "%s: must have one input file\n", *argv);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
filename = argv[optind];
|
||||
|
||||
ifp = fopen(filename, "r");
|
||||
if (!ifp) {
|
||||
perror(filename);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
if (!ofp) {
|
||||
ofp = fopen(ADOTOUT, "w");
|
||||
if (!ofp) {
|
||||
perror(ADOTOUT);
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
}
|
||||
|
||||
assemble();
|
||||
exit(EXIT_SUCCESS);
|
||||
}
|
1064
sys/gnu/misc/aic7xxx/aic7xxx.seq
Normal file
1064
sys/gnu/misc/aic7xxx/aic7xxx.seq
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user