-
Notifications
You must be signed in to change notification settings - Fork 69
N: SIO Command 'R' Read
Bill Kendrick edited this page May 27, 2022
·
4 revisions
This is a command for Devices $71-$78 - The N: Device (see SIO-Commands-for-Device-IDs-$71-to-$78).
Fetch the number of bytes requested from the protocol channel opened previously by the OPEN command. an ERROR will result if too many bytes are requested, so a STATUS should be sent beforehand to determine the # of bytes to receive.
- Use AdamNet Device 0x09 to 0x0C
- Use EOS READ CHARACTER DEVICE, with a length and buffer of 1024 bytes.
DCB | Value |
---|---|
DDEVIC | $71 |
DUNIT | $01 - $04 |
DCOMND | $52 'R' |
DSTATS | $40 |
DBUF | NULL |
DTIMLO | $0F |
DBYT | # of bytes to return |
DAUX1 | # of bytes to return LO |
DAUX2 | # of bytes to return HI |
/**
* io_main() - The IO main loop
*/
void io_main(void)
{
if (xmit_buffer_len>0)
{
OS.dcb.ddevic=0x71;
OS.dcb.dunit=1;
OS.dcb.dcomnd='W';
OS.dcb.dstats=0x80;
OS.dcb.dbuf=&xmit_buffer;
OS.dcb.dtimlo=0x0f;
OS.dcb.dbyt=xmit_buffer_len;
OS.dcb.daux1=xmit_buffer_len;
OS.dcb.daux2=0;
siov();
xmit_buffer_len=0;
return;
}
if (trip==0)
return;
// Get # of bytes waiting
OS.dcb.ddevic=0x71;
OS.dcb.dunit=1;
OS.dcb.dcomnd='S';
OS.dcb.dstats=0x40;
OS.dcb.dbuf=&status;
OS.dcb.dtimlo=0x0f;
OS.dcb.dbyt=4;
OS.dcb.daux=0;
siov();
bw=(status[1]<<8)+status[0];
connected=status[2];
// These functions are all I needed to change to port over to the N: device.
if (bw>0)
{
// Do a read into into recv buffer and ShowPLATO
OS.dcb.ddevic=0x71;
OS.dcb.dunit=1;
OS.dcb.dcomnd='R';
OS.dcb.dstats=0x40;
OS.dcb.dbuf=&recv_buffer;
OS.dcb.dbyt=bw;
OS.dcb.daux=bw;
siov();
ShowPLATO((padByte *)recv_buffer, bw);
bw=trip=0;
}
if (connected==0)
{
io_done();
}
PIA.pactl |= 1;
}
/* This uses EOSLIB: http://github.com/tschak909/eoslib */
#define NET_DEV 0x09
unsigned char response[1024]; /* RESPONSE BUFFER */
void read(void)
{
DCB *dcb = find_dcb(NET_DEV);
if (eos_read_character_device(NET_DEV,response,1024) == 0x80)
{
for (int i=0;i < dcb->len; i++)
{
putchar(response[i]);
}
}
}
Put other related command links here.
Copyright 2024 Contributors to the FujiNetWIFI project.
Join us on Discord: https://discord.gg/7MfFTvD
- Home
- What is FujiNet?
- The Definition of Done
- Board bring up for FujiNet Platform.IO code
- The Complete Linux CLI Guide
- The Complete macOS CLI Guide
- Development Env for Apps
- FujiNet-Development-Guidelines
- System Quickstarts
- FujiNet Flasher
- Setting up a TNFS Server
- FujiNet Configuration File: fnconfig.ini
- AppKey Registry - SIO Command $DC Open App Key
- CP-M Support
- BBS
- Official Hardware Versions
- Prototype Board Revisions
- FujiNet Development Guidelines
- Atari Programming
- Apple Programming
- C64 Programming
- ADAM Programming
- Testing Plan
- Hacker List
- FujiNet VirtualMachine