|
|
DataMuseum.dkPresents historical artifacts from the history of: Commodore CBM-900 |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Commodore CBM-900 Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - download
Length: 2857 (0xb29)
Types: TextFile
Notes: UNIX file
Names: »CK.C«
└─⟦f27320a65⟧ Bits:30001972 Commodore 900 hard disk image with partial source code
└─⟦2d53db1df⟧ UNIX Filesystem
└─⟦this⟧ »frankh/src/CK.C«
#include <stdio.h>
#define PBCS 0x93 /* Z8036 #2 port B cmd & stat reg */
#define PBDDR 0x57
#define PCDD 0x0D
#define PCDATA 0x1F
#define PBDATA 0x1D
#define CLRIPIUS 0x20 /* Mask to clear IP and IUS */
#define MCCR 0x03
#define MICR 0x01
#define PBCSR 0x13
#define SIOCRC 0x0F
/*
*
*
*
* The data lines are initialised, as follows in md.s:
* 8036 #1, port b, non-inverting: output data lines
* 8036 #1, port c, bit 0, non-inverting: input busy line
* 8036 #2, port b, bit 1, inverting: inpupt acknowledge
* 8036 #2, port c, bit 3, non-inverting: output strobe
*
*/
main()
{
register int fd;
int i, status;
unsigned int tmp;
initio();
fd = open("/dev/port", 2);
printf("Begin . . .\n");
outb( fd, PCDATA, inb(fd, PCDATA) & 0x0F); /* enable 0-3 write */
outb( fd, PCDATA, inb(fd, PCDATA) | 0x02); /* set select = 1 */
outb( fd, PCDD, 0x05); /* set up CS line */
outb( fd, PCDATA, inb(fd, PCDATA) | 0x02); /* set select = 1 */
outb( fd, PBDATA, 0);
/* outb( fd, PBDATA, inb(fd, PBDATA) | 0x80); set stop = 1 */
outb( fd, PCDATA, inb(fd, PCDATA) & ~0x02); /* set select = 0 */
printf("select on\n");
wrt( 0x0D, 0, fd);
printf(" loop . . .\n");
for( i = 0; i < 13; ++i)
printf("i = %u data = %u\n", i, red(i, fd));
/* for( i = 0; i < 12 ; ++i)
wrt( i, 1, fd);
*/
/* outb( fd, PBDATA, inb(fd, PBDATA) & ~0x80); set stop = 0 */
outb( fd, PCDATA, inb(fd, PCDATA) | 0x02); /* set select =1 */
cloio();
}
red(reg, fd)
int fd;
unsigned int reg;
{
unsigned int tmp;
/* outb(fd, PBDATA, (inb(fd, PBDATA) & 0xF0) | reg); */
outb(fd, PBDATA, reg);
outb(fd, PBDATA, (inb(fd, PBDATA) | 0x40));
tmp = 5 * 5;
outb(fd, PBDATA, (inb(fd, PBDATA) & ~0x40));
/*
* make PB0-3 input lines
*/
outb(fd, PBDDR, (inb(fd, PBDDR) | 0x0F));
tmp = 5 * 3 * 4;
outb(fd, PBDATA, (inb(fd, PBDATA) | 0x10));
tmp = 9 * 8 * 9;
tmp = inb(fd, PBDATA) & 0x0F;
outb(fd, PBDATA, (inb(fd, PBDATA) & ~0x10));
/*
* make PB0-3 output lines
*/
outb(fd, PBDDR, (inb(fd, PBDDR) & 0xF0));
return(tmp);
}
wrt(reg, data, fd)
int fd;
unsigned int reg;
unsigned int data;
{
unsigned int tmp;
/* outb(fd, PBDATA, (inb(fd, PBDATA) & 0xF0) | reg); */
outb(fd, PBDATA, reg);
outb(fd, PBDATA, (inb(fd, PBDATA) | 0x40));
tmp = 5 * 5;
outb(fd, PBDATA, (inb(fd, PBDATA) & ~0x40));
tmp = 5 * 3;
outb(fd, PBDATA, ((inb(fd, PBDATA) & 0xF0) | data));
outb(fd, PBDATA, (inb(fd, PBDATA) | 0x20));
tmp = 3 * 4 * 7;
outb(fd, PBDATA, (inb(fd, PBDATA) & ~0x20));
}
dumpreg(fd)
int fd;
{
printf("\nPBDDR:\t%x\n", inb(fd, PBDDR));
printf("PCDDR:\t%x\n", inb(fd, PCDD));
printf("PBDATA:\t%x\n", inb(fd, PBDATA));
printf("PCDATA:\t%x\n", inb(fd, PCDATA));
printf("MICR:\t%x\n", inb(fd, MICR));
printf("MCCR:\t%x\n", inb(fd, MCCR));
printf("PBCSR:\t%x\n", inb(fd, PBCSR));
printf("SIOCRC:\t%x\n\n", inb(fd, SIOCRC));
}