mirror of
https://github.com/ksherlock/marignotti.git
synced 2025-01-20 17:32:28 +00:00
debug code
This commit is contained in:
parent
ba336246ec
commit
050fd731df
131
marignotti.c
131
marignotti.c
@ -21,6 +21,9 @@
|
|||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <ctype.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
//#include <netinet/in.h>
|
//#include <netinet/in.h>
|
||||||
|
|
||||||
#include "net.h"
|
#include "net.h"
|
||||||
@ -50,6 +53,44 @@ typedef void (*selwakeup)(int col_flag, int pid);
|
|||||||
|
|
||||||
void debug_str(const char *cp)
|
void debug_str(const char *cp)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
static Word Sweet16 = -1;
|
||||||
|
|
||||||
|
|
||||||
|
if (Sweet16 == -1)
|
||||||
|
{
|
||||||
|
//volatile char *ereg = (char *)0x00c04f;
|
||||||
|
/*
|
||||||
|
// Apple II tech note 201
|
||||||
|
*/
|
||||||
|
word emu_id = 0;
|
||||||
|
word emu_version = 0;
|
||||||
|
asm {
|
||||||
|
// the lda ..,x is to prevent
|
||||||
|
// the 2nd read from being optimized out.
|
||||||
|
//brk 0xea
|
||||||
|
lda #0
|
||||||
|
ldx #0
|
||||||
|
sep #0x20
|
||||||
|
sta >0x00c04f,x
|
||||||
|
lda >0x00c04f,x
|
||||||
|
sta <emu_id
|
||||||
|
lda >0x00c04f,x
|
||||||
|
sta <emu_version
|
||||||
|
rep #0x20
|
||||||
|
}
|
||||||
|
|
||||||
|
if (emu_id == 0x16 && emu_version >= 0x23) Sweet16 = 1;
|
||||||
|
else Sweet16 = 0;
|
||||||
|
|
||||||
|
//*EMUBYTE = 0;
|
||||||
|
//if (*EMUBYTE == 0x16) Sweet16 = 1;
|
||||||
|
//else Sweet16 = 0;
|
||||||
|
#undef EMUBYTE
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Sweet16 == 0) return;
|
||||||
|
|
||||||
asm {
|
asm {
|
||||||
ldx <cp+2
|
ldx <cp+2
|
||||||
ldy <cp
|
ldy <cp
|
||||||
@ -57,9 +98,42 @@ void debug_str(const char *cp)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dump_bytes(const char *bytes, Word length)
|
||||||
|
{
|
||||||
|
static const char *HexMap = "0123456789abcdef";
|
||||||
|
static char buffer[80];
|
||||||
|
|
||||||
|
while (length)
|
||||||
|
{
|
||||||
|
Word i, j, l;
|
||||||
|
l = 16;
|
||||||
|
if (l > length) l = length;
|
||||||
|
|
||||||
|
memset(buffer, ' ', sizeof(buffer));
|
||||||
|
|
||||||
|
for (i = 0, j = 0; i < l; ++i)
|
||||||
|
{
|
||||||
|
unsigned x = bytes[i];
|
||||||
|
buffer[j++] = HexMap[x >> 4];
|
||||||
|
buffer[j++] = HexMap[x & 0x0f];
|
||||||
|
j++;
|
||||||
|
if (i == 7) j++;
|
||||||
|
|
||||||
|
buffer[50 + i] = isascii(x) && isprint(x) ? x : '.';
|
||||||
|
}
|
||||||
|
|
||||||
|
buffer[50 + 16 + 1] = 0;
|
||||||
|
debug_str(buffer);
|
||||||
|
|
||||||
|
length -= l;
|
||||||
|
bytes += l;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void dump_srbuff(const srBuff *sb)
|
void dump_srbuff(const srBuff *sb)
|
||||||
{
|
{
|
||||||
static char buffer[256];
|
static char buffer[128];
|
||||||
|
|
||||||
sprintf(buffer, "%04x %04x %08lx %08lx %08lx %04x %04x %04x",
|
sprintf(buffer, "%04x %04x %08lx %08lx %08lx %04x %04x %04x",
|
||||||
sb->srState,
|
sb->srState,
|
||||||
@ -72,11 +146,7 @@ static char buffer[256];
|
|||||||
sb->srAcceptCount
|
sb->srAcceptCount
|
||||||
);
|
);
|
||||||
|
|
||||||
asm {
|
debug_str(buffer);
|
||||||
ldx #^buffer
|
|
||||||
ldy #buffer
|
|
||||||
cop 0x84
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -242,14 +312,16 @@ int do_detach(
|
|||||||
//WriteLine("\pdo_detach");
|
//WriteLine("\pdo_detach");
|
||||||
debug_str("do_detach");
|
debug_str("do_detach");
|
||||||
|
|
||||||
|
debug_str("TCPIPCloseTCP");
|
||||||
terr = TCPIPCloseTCP(ipid);
|
terr = TCPIPCloseTCP(ipid);
|
||||||
|
|
||||||
// semaphore...
|
// semaphore...
|
||||||
|
debug_str("swait");
|
||||||
swait(semID);
|
swait(semID);
|
||||||
|
|
||||||
prev = NULL;
|
prev = NULL;
|
||||||
e = htable[ipid & (64-1)];
|
e = htable[ipid & (64-1)];
|
||||||
for(;;)
|
while (e)
|
||||||
{
|
{
|
||||||
if (e->ipid == ipid) break;
|
if (e->ipid == ipid) break;
|
||||||
prev = e;
|
prev = e;
|
||||||
@ -264,9 +336,11 @@ int do_detach(
|
|||||||
dlist = e;
|
dlist = e;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
debug_str("ssignal");
|
||||||
ssignal(semID);
|
ssignal(semID);
|
||||||
// end semaphore.
|
// end semaphore.
|
||||||
|
|
||||||
|
debug_str("return 0");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -350,6 +424,20 @@ int do_rcvd(
|
|||||||
|
|
||||||
if (rr.rrBuffCount)
|
if (rr.rrBuffCount)
|
||||||
{
|
{
|
||||||
|
{
|
||||||
|
static char buffer[80];
|
||||||
|
|
||||||
|
sprintf(buffer, "read %04x bytes %04x %04x %04x",
|
||||||
|
(Word)rr.rrBuffCount,
|
||||||
|
rr.rrMoreFlag,
|
||||||
|
rr.rrPushFlag,
|
||||||
|
rr.rrUrgentFlag
|
||||||
|
);
|
||||||
|
debug_str(buffer);
|
||||||
|
|
||||||
|
dump_bytes(data, rr.rrBuffCount);
|
||||||
|
}
|
||||||
|
|
||||||
*len = rr.rrBuffCount;
|
*len = rr.rrBuffCount;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -364,13 +452,13 @@ int do_rcvd(
|
|||||||
|
|
||||||
// if NON_BLOCKING, return EWOULDBLOCK.
|
// if NON_BLOCKING, return EWOULDBLOCK.
|
||||||
|
|
||||||
asm {
|
//asm {
|
||||||
cop 0x7f
|
// cop 0x7f
|
||||||
}
|
//}
|
||||||
// poll in main loop not called, apparently.
|
// poll in main loop not called, apparently.
|
||||||
|
|
||||||
TCPIPPoll(); //
|
//TCPIPPoll(); //
|
||||||
//sleep(1); // cop 0x7f?
|
sleep(1); // cop 0x7f?
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -383,6 +471,7 @@ static int driver(
|
|||||||
struct sockaddr *addr, int *addrlen,
|
struct sockaddr *addr, int *addrlen,
|
||||||
void *rights)
|
void *rights)
|
||||||
{
|
{
|
||||||
|
int rv;
|
||||||
|
|
||||||
{
|
{
|
||||||
static char buffer[64];
|
static char buffer[64];
|
||||||
@ -422,11 +511,13 @@ static int driver(
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case PRU_DETACH:
|
case PRU_DETACH:
|
||||||
|
// called from GS/OS
|
||||||
// int SOCKclose(int sock) part 2
|
// int SOCKclose(int sock) part 2
|
||||||
return do_detach(socknum, m, m_len, addr, addrlen, rights);
|
return do_detach(socknum, m, m_len, addr, addrlen, rights);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PRU_DISCONNECT:
|
case PRU_DISCONNECT:
|
||||||
|
// called from GS/OS
|
||||||
// int SOCKclose(int sock) part 1
|
// int SOCKclose(int sock) part 1
|
||||||
return do_disconnect(socknum, m, m_len, addr, addrlen, rights);
|
return do_disconnect(socknum, m, m_len, addr, addrlen, rights);
|
||||||
break;
|
break;
|
||||||
@ -438,8 +529,19 @@ static int driver(
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case PRU_RCVD:
|
case PRU_RCVD:
|
||||||
|
// called from GS/OS.
|
||||||
|
// may block, so be nice.
|
||||||
// SOCKrdwr(struct rwPBlock *pb, word cmd, int sock)
|
// SOCKrdwr(struct rwPBlock *pb, word cmd, int sock)
|
||||||
return do_rcvd(socknum, m, m_len, addr, addrlen, rights);
|
asm {
|
||||||
|
// dec busy.
|
||||||
|
jsl 0xE10068
|
||||||
|
}
|
||||||
|
rv = do_rcvd(socknum, m, m_len, addr, addrlen, rights);
|
||||||
|
asm {
|
||||||
|
// inc busy.
|
||||||
|
jsl 0xE10064
|
||||||
|
}
|
||||||
|
return rv;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PRU_RCVOOB:
|
case PRU_RCVOOB:
|
||||||
@ -584,8 +686,9 @@ int main(int argc, char **argv)
|
|||||||
ipidHash *e;
|
ipidHash *e;
|
||||||
ipidHash *prev;
|
ipidHash *prev;
|
||||||
|
|
||||||
debug_str("TCPIPPoll()");
|
debug_str("TCPIPPoll() begin");
|
||||||
TCPIPPoll();
|
TCPIPPoll();
|
||||||
|
debug_str("TCPIPPoll() end");
|
||||||
|
|
||||||
// monitor disconnects...
|
// monitor disconnects...
|
||||||
// semaphore ...
|
// semaphore ...
|
||||||
|
Loading…
x
Reference in New Issue
Block a user