mirror of
https://github.com/RaySollium99/picodrive.git
synced 2025-09-04 23:07:46 -04:00

- PicoDrive was originally released by fDave with simple "free for non-commercial use / For commercial use, separate licencing terms must be obtained" license and I kept it in my releases. - in 2011, fDave re-released his code (same that I used as base many years ago) dual licensed with GPLv2 and MAME licenses: https://code.google.com/p/cyclone68000/ Based on the above I now proclaim that the whole source code is licensed under the MAME license as more elaborate form of "for non-commercial use". If that raises any doubt, I announce that all my modifications (which is the vast majority of code by now) is licensed under the MAME license, as it reads in COPYING file in this commit. This does not affect ym2612.c/sn76496.c that were MAME licensed already from the beginning.
153 lines
3.7 KiB
C
153 lines
3.7 KiB
C
/*
|
|
* PDB, the PicoDrive debugger
|
|
* (C) notaz, 2010
|
|
*
|
|
* This work is licensed under the terms of MAME license.
|
|
* See COPYING file in the top-level directory.
|
|
*/
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netdb.h>
|
|
#include <unistd.h>
|
|
|
|
#include "debug_net.h"
|
|
|
|
static const char * const regnames[] = {
|
|
"PC",
|
|
"R0", "R1", "R2", "R3", "R4", "R5", "R6", "R7",
|
|
"R8", "R9", "R10", "R11", "R12", "R13", "R14", "SP",
|
|
"PC2", "PC3", "PR", "SR", "GBR", "VBR", "MACH", "MACL",
|
|
"MEM0", "MEM1", // mem i/o csums
|
|
};
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
unsigned int pc_trace[5][4], pc_trace_p[5] = { 0, };
|
|
struct addrinfo *ai, *ais, hints;
|
|
int sock = -1, sock1, sock2;
|
|
struct sockaddr_in6 sa;
|
|
packet_t packet1, packet2;
|
|
int i, ret, cnt, cpuid;
|
|
int check_len_override = 0;
|
|
socklen_t sal;
|
|
|
|
if (argv[1] != NULL)
|
|
check_len_override = atoi(argv[1]);
|
|
|
|
memset(&hints, 0, sizeof(hints));
|
|
hints.ai_flags = AI_CANONNAME;
|
|
hints.ai_family = PF_UNSPEC;
|
|
hints.ai_socktype = SOCK_STREAM;
|
|
|
|
ret = getaddrinfo("::", "1234", &hints, &ais);
|
|
if (ret != 0)
|
|
return -1;
|
|
|
|
for (ai = ais; ai != NULL; ai = ai->ai_next) {
|
|
sock = socket(ai->ai_family, ai->ai_socktype, ai->ai_protocol);
|
|
if (sock == -1)
|
|
continue;
|
|
|
|
ret = bind(sock, ai->ai_addr, ai->ai_addrlen);
|
|
if (ret != 0) {
|
|
close(sock);
|
|
sock = -1;
|
|
continue;
|
|
}
|
|
break;
|
|
}
|
|
freeaddrinfo(ais);
|
|
|
|
if (sock == -1) {
|
|
perror("failed to bind");
|
|
return -1;
|
|
}
|
|
|
|
ret = listen(sock, SOMAXCONN);
|
|
if (ret != 0) {
|
|
perror("failed to listen");
|
|
return -1;
|
|
}
|
|
|
|
sal = sizeof(sa);
|
|
sock1 = accept(sock, (struct sockaddr *)&sa, &sal);
|
|
if (sock1 == -1) {
|
|
perror("failed to accept");
|
|
return -1;
|
|
}
|
|
printf("client1 connected\n");
|
|
|
|
sal = sizeof(sa);
|
|
sock2 = accept(sock, (struct sockaddr *)&sa, &sal);
|
|
if (sock2 == -1) {
|
|
perror("failed to accept");
|
|
return -1;
|
|
}
|
|
printf("client2 connected\n");
|
|
|
|
for (cnt = 0; ; cnt++)
|
|
{
|
|
int len;
|
|
#define tmp_size (4+4 + 24*4 + 2*4)
|
|
ret = recv(sock1, &packet1, tmp_size, MSG_WAITALL);
|
|
if (ret != tmp_size) {
|
|
if (ret < 0)
|
|
perror("recv1");
|
|
else
|
|
printf("recv1 %d\n", ret);
|
|
return -1;
|
|
}
|
|
ret = recv(sock2, &packet2, tmp_size, MSG_WAITALL);
|
|
if (ret != tmp_size) {
|
|
if (ret < 0)
|
|
perror("recv2");
|
|
else
|
|
printf("recv2 %d\n", ret);
|
|
return -1;
|
|
}
|
|
|
|
cpuid = packet1.header.cpuid;
|
|
len = sizeof(packet1.header) + packet1.header.len;
|
|
if (check_len_override > 0)
|
|
len = check_len_override;
|
|
|
|
if (memcmp(&packet1, &packet2, len) == 0) {
|
|
pc_trace[cpuid][pc_trace_p[cpuid]++ & 3] = packet1.regs[0];
|
|
continue;
|
|
}
|
|
|
|
if (packet1.header.cpuid != packet2.header.cpuid)
|
|
printf("%d: CPU %d %d\n", cnt, packet1.header.cpuid & 0xff, packet2.header.cpuid & 0xff);
|
|
else if (*(int *)&packet1.header != *(int *)&packet2.header)
|
|
printf("%d: header\n", cnt);
|
|
|
|
// check regs (and stuff)
|
|
for (i = 0; i < 1+24+2; i++)
|
|
if (packet1.regs[i] != packet2.regs[i])
|
|
printf("%d: %3s: %08x %08x\n", cnt, regnames[i], packet1.regs[i], packet2.regs[i]);
|
|
|
|
break;
|
|
}
|
|
|
|
printf("--\nCPU %d\n", cpuid);
|
|
for (cpuid = 0; cpuid < 2; cpuid++) {
|
|
printf("trace%d: ", cpuid);
|
|
for (i = 0; i < 4; i++)
|
|
printf(" %08x", pc_trace[cpuid][pc_trace_p[cpuid]++ & 3]);
|
|
|
|
if (packet1.header.cpuid == cpuid)
|
|
printf(" %08x", packet1.regs[0]);
|
|
else if (packet2.header.cpuid == cpuid)
|
|
printf(" %08x", packet2.regs[0]);
|
|
printf("\n");
|
|
}
|
|
|
|
for (i = 0; i < 24+1; i++)
|
|
printf("%3s: %08x %08x\n", regnames[i], packet1.regs[i], packet2.regs[i]);
|
|
|
|
return 0;
|
|
}
|
|
|