mirror of
https://github.com/akuker/RASCSI.git
synced 2025-01-04 23:30:47 +00:00
Merge branch 'failed-monitor-attempt'
This commit is contained in:
commit
419f887dae
2
src/raspberrypi/.gitignore
vendored
Normal file
2
src/raspberrypi/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
*.o
|
||||||
|
*.bak
|
@ -1,8 +1,13 @@
|
|||||||
|
.DEFAULT_GOAL: all
|
||||||
|
|
||||||
CC = gcc
|
CC = gcc
|
||||||
CFLAGS = -DDISK_LOG -O0 -g -Wall
|
|
||||||
CXX = g++
|
CXX = g++
|
||||||
|
|
||||||
|
CFLAGS = -DDISK_LOG -O0 -g -Wall
|
||||||
CXXFLAGS = -DDISK_LOG -O0 -g -Wall
|
CXXFLAGS = -DDISK_LOG -O0 -g -Wall
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# If its not specified, build for STANDARD configuration
|
# If its not specified, build for STANDARD configuration
|
||||||
CONNECT_TYPE ?= STANDARD
|
CONNECT_TYPE ?= STANDARD
|
||||||
|
|
||||||
@ -15,9 +20,13 @@ RASCSI = rascsi
|
|||||||
RASCTL = rasctl
|
RASCTL = rasctl
|
||||||
RASDUMP = rasdump
|
RASDUMP = rasdump
|
||||||
SASIDUMP = sasidump
|
SASIDUMP = sasidump
|
||||||
|
SCSIMON = scsimon
|
||||||
|
|
||||||
|
#BIN_ALL = $(RASCSI) $(RASCTL) $(RASDUMP) $(SASIDUMP) $(SCSIMON)
|
||||||
|
# Temporarily remove the RASDUMP and RASDUMP tools, since they're not needed
|
||||||
|
# for my specific use case. If you need them - add them back in!
|
||||||
|
BIN_ALL = $(RASCSI) $(RASCTL) $(SCSIMON)
|
||||||
|
|
||||||
BIN_ALL = $(RASCSI) $(RASCTL) $(RASDUMP) $(SASIDUMP)
|
|
||||||
|
|
||||||
SRC_RASCSI = \
|
SRC_RASCSI = \
|
||||||
rascsi.cpp \
|
rascsi.cpp \
|
||||||
@ -46,16 +55,29 @@ SRC_SASIDUMP = \
|
|||||||
filepath.cpp \
|
filepath.cpp \
|
||||||
fileio.cpp
|
fileio.cpp
|
||||||
|
|
||||||
|
SRC_SCSIMON = \
|
||||||
|
scsimon.cpp \
|
||||||
|
scsi.cpp \
|
||||||
|
disk.cpp \
|
||||||
|
gpiobus.cpp \
|
||||||
|
ctapdriver.cpp \
|
||||||
|
cfilesystem.cpp \
|
||||||
|
filepath.cpp \
|
||||||
|
fileio.cpp \
|
||||||
|
scsimondev.cpp
|
||||||
|
|
||||||
OBJ_RASCSI := $(SRC_RASCSI:%.cpp=%.o)
|
OBJ_RASCSI := $(SRC_RASCSI:%.cpp=%.o)
|
||||||
OBJ_RASCTL := $(SRC_RASCTL:%.cpp=%.o)
|
OBJ_RASCTL := $(SRC_RASCTL:%.cpp=%.o)
|
||||||
OBJ_RASDUMP := $(SRC_RASDUMP:%.cpp=%.o)
|
OBJ_RASDUMP := $(SRC_RASDUMP:%.cpp=%.o)
|
||||||
OBJ_SASIDUMP := $(SRC_SASIDUMP:%.cpp=%.o)
|
OBJ_SASIDUMP := $(SRC_SASIDUMP:%.cpp=%.o)
|
||||||
OBJ_ALL := $(OBJ_RASCSI) $(OBJ_RASCTL) $(OBJ_RASDUMP) $(OBJ_SASIDUMP)
|
OBJ_SCSIMON := $(SRC_SCSIMON:%.cpp=%.o)
|
||||||
|
OBJ_ALL := $(OBJ_RASCSI) $(OBJ_RASCTL) $(OBJ_RASDUMP) $(OBJ_SASIDUMP) $(OBJ_SCSIMON)
|
||||||
|
|
||||||
%.o: %.cpp
|
%.o: %.cpp
|
||||||
$(CXX) $(CXXFLAGS) -c $< -o $@
|
$(CXX) $(CXXFLAGS) -c $< -o $@
|
||||||
|
|
||||||
ALL: $(BIN_ALL)
|
ALL: $(BIN_ALL)
|
||||||
|
all: $(BIN_ALL)
|
||||||
|
|
||||||
$(RASCSI): $(OBJ_RASCSI)
|
$(RASCSI): $(OBJ_RASCSI)
|
||||||
$(CXX) -o $@ $(OBJ_RASCSI) -lpthread
|
$(CXX) -o $@ $(OBJ_RASCSI) -lpthread
|
||||||
@ -69,8 +91,14 @@ $(RASDUMP): $(OBJ_RASDUMP)
|
|||||||
$(SASIDUMP): $(OBJ_SASIDUMP)
|
$(SASIDUMP): $(OBJ_SASIDUMP)
|
||||||
$(CXX) -o $@ $(OBJ_SASIDUMP)
|
$(CXX) -o $@ $(OBJ_SASIDUMP)
|
||||||
|
|
||||||
|
$(SCSIMON): $(OBJ_SCSIMON)
|
||||||
|
$(CXX) $(CXXFLAGS) -o $@ $(OBJ_SCSIMON) -lpthread
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f $(OBJ_ALL) $(BIN_ALL)
|
rm -f $(OBJ_ALL) $(BIN_ALL)
|
||||||
|
|
||||||
run:
|
run:
|
||||||
sudo ./$(RASCSI) -ID1 /home/pi/HARDDISK.HDA -ID6 /home/pi/marathon.iso
|
sudo ./$(RASCSI) -ID1 /home/pi/HARDDISK.HDA -ID6 /home/pi/marathon.iso
|
||||||
|
|
||||||
|
.PHONY: Debug
|
||||||
|
Debug: scsimon
|
||||||
|
@ -4534,6 +4534,7 @@ void FASTCALL SCSICD::GetBuf(
|
|||||||
ASSERT(this);
|
ASSERT(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
// SCSI Host Bridge
|
// SCSI Host Bridge
|
||||||
@ -6294,6 +6295,7 @@ BUS::phase_t FASTCALL SASIDEV::Process()
|
|||||||
// Get bus information
|
// Get bus information
|
||||||
ctrl.bus->Aquire();
|
ctrl.bus->Aquire();
|
||||||
|
|
||||||
|
// For the monitor tool, we shouldn't need to reset. We're just logging information
|
||||||
// Reset
|
// Reset
|
||||||
if (ctrl.bus->GetRST()) {
|
if (ctrl.bus->GetRST()) {
|
||||||
#if defined(DISK_LOG)
|
#if defined(DISK_LOG)
|
||||||
@ -6373,7 +6375,7 @@ void FASTCALL SASIDEV::BusFree()
|
|||||||
// Phase Setting
|
// Phase Setting
|
||||||
ctrl.phase = BUS::busfree;
|
ctrl.phase = BUS::busfree;
|
||||||
|
|
||||||
// 信号線
|
Set Signal lines
|
||||||
ctrl.bus->SetREQ(FALSE);
|
ctrl.bus->SetREQ(FALSE);
|
||||||
ctrl.bus->SetMSG(FALSE);
|
ctrl.bus->SetMSG(FALSE);
|
||||||
ctrl.bus->SetCD(FALSE);
|
ctrl.bus->SetCD(FALSE);
|
||||||
@ -6666,8 +6668,8 @@ void FASTCALL SASIDEV::Status()
|
|||||||
|
|
||||||
#ifndef RASCSI
|
#ifndef RASCSI
|
||||||
// Request status
|
// Request status
|
||||||
ctrl.bus->SetDAT(ctrl.buffer[0]);
|
// ctrl.bus->SetDAT(ctrl.buffer[0]);
|
||||||
ctrl.bus->SetREQ(TRUE);
|
// ctrl.bus->SetREQ(TRUE);
|
||||||
|
|
||||||
#if defined(DISK_LOG)
|
#if defined(DISK_LOG)
|
||||||
Log(Log::Normal, "Status Phase $%02X", ctrl.status);
|
Log(Log::Normal, "Status Phase $%02X", ctrl.status);
|
||||||
@ -8026,6 +8028,7 @@ void FASTCALL SCSIDEV::Reset()
|
|||||||
BUS::phase_t FASTCALL SCSIDEV::Process()
|
BUS::phase_t FASTCALL SCSIDEV::Process()
|
||||||
{
|
{
|
||||||
ASSERT(this);
|
ASSERT(this);
|
||||||
|
printf("SCSIDEV::Process() %d\n", ctrl.id);
|
||||||
|
|
||||||
// Do nothing if not connected
|
// Do nothing if not connected
|
||||||
if (ctrl.id < 0 || ctrl.bus == NULL) {
|
if (ctrl.id < 0 || ctrl.bus == NULL) {
|
||||||
|
@ -229,6 +229,8 @@ public:
|
|||||||
// NULL check
|
// NULL check
|
||||||
BOOL FASTCALL IsSASI() const;
|
BOOL FASTCALL IsSASI() const;
|
||||||
// SASI Check
|
// SASI Check
|
||||||
|
virtual BOOL FASTCALL IsMonitor() const {return FALSE;}
|
||||||
|
// Check if this is a monitor device
|
||||||
|
|
||||||
// Media Operations
|
// Media Operations
|
||||||
virtual BOOL FASTCALL Open(const Filepath& path, BOOL attn = TRUE);
|
virtual BOOL FASTCALL Open(const Filepath& path, BOOL attn = TRUE);
|
||||||
@ -933,6 +935,8 @@ public:
|
|||||||
// SASI Check
|
// SASI Check
|
||||||
virtual BOOL FASTCALL IsSCSI() const {return FALSE;}
|
virtual BOOL FASTCALL IsSCSI() const {return FALSE;}
|
||||||
// SCSI check
|
// SCSI check
|
||||||
|
virtual BOOL FASTCALL IsMonitor() const {return FALSE;}
|
||||||
|
// Check to see if this is a monitor device
|
||||||
Disk* FASTCALL GetBusyUnit();
|
Disk* FASTCALL GetBusyUnit();
|
||||||
// Get the busy unit
|
// Get the busy unit
|
||||||
|
|
||||||
@ -1141,4 +1145,6 @@ private:
|
|||||||
// Internal data
|
// Internal data
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif // disk_h
|
#endif // disk_h
|
||||||
|
@ -169,6 +169,7 @@ BOOL FASTCALL GPIOBUS::Init(mode_e mode)
|
|||||||
// Open /dev/mem
|
// Open /dev/mem
|
||||||
fd = open("/dev/mem", O_RDWR | O_SYNC);
|
fd = open("/dev/mem", O_RDWR | O_SYNC);
|
||||||
if (fd == -1) {
|
if (fd == -1) {
|
||||||
|
printf("Error: Unable to open /dev/mem. Are you running as root?\n");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -274,6 +275,7 @@ BOOL FASTCALL GPIOBUS::Init(mode_e mode)
|
|||||||
PinConfig(PIN_DTD, GPIO_OUTPUT);
|
PinConfig(PIN_DTD, GPIO_OUTPUT);
|
||||||
|
|
||||||
// Set the ENABLE signal
|
// Set the ENABLE signal
|
||||||
|
// This is used to show that the application is running
|
||||||
PinSetSignal(PIN_ENB, ENB_OFF);
|
PinSetSignal(PIN_ENB, ENB_OFF);
|
||||||
PinConfig(PIN_ENB, GPIO_OUTPUT);
|
PinConfig(PIN_ENB, GPIO_OUTPUT);
|
||||||
|
|
||||||
@ -373,6 +375,7 @@ BOOL FASTCALL GPIOBUS::Init(mode_e mode)
|
|||||||
MakeTable();
|
MakeTable();
|
||||||
|
|
||||||
// Finally, enable ENABLE
|
// Finally, enable ENABLE
|
||||||
|
// Show the user that this app is running
|
||||||
SetControl(PIN_ENB, ENB_ON);
|
SetControl(PIN_ENB, ENB_ON);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -549,9 +552,15 @@ BOOL FASTCALL GPIOBUS::GetBSY()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetBSY(BOOL ast)
|
void FASTCALL GPIOBUS::SetBSY(BOOL ast)
|
||||||
{
|
{
|
||||||
// Set BSY signal
|
if(actmode == MONITOR)
|
||||||
SetSignal(PIN_BSY, ast);
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET BSY IN MONITOR MODE");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Set BSY signal
|
||||||
|
SetSignal(PIN_BSY, ast);
|
||||||
|
}
|
||||||
if (actmode == TARGET) {
|
if (actmode == TARGET) {
|
||||||
if (ast) {
|
if (ast) {
|
||||||
// Turn on ACTIVE signal
|
// Turn on ACTIVE signal
|
||||||
@ -603,8 +612,14 @@ void FASTCALL GPIOBUS::SetSEL(BOOL ast)
|
|||||||
SetControl(PIN_ACT, ACT_ON);
|
SetControl(PIN_ACT, ACT_ON);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set SEL signal
|
if (actmode != MONITOR)
|
||||||
SetSignal(PIN_SEL, ast);
|
{
|
||||||
|
// Set SEL signal
|
||||||
|
SetSignal(PIN_SEL, ast);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET SEL IN MONITOR MODE");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
@ -624,7 +639,14 @@ BOOL FASTCALL GPIOBUS::GetATN()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetATN(BOOL ast)
|
void FASTCALL GPIOBUS::SetATN(BOOL ast)
|
||||||
{
|
{
|
||||||
SetSignal(PIN_ATN, ast);
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET ATN IN MONITOR MODE");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SetSignal(PIN_ATN, ast);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
@ -644,7 +666,14 @@ BOOL FASTCALL GPIOBUS::GetACK()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetACK(BOOL ast)
|
void FASTCALL GPIOBUS::SetACK(BOOL ast)
|
||||||
{
|
{
|
||||||
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET ACK IN MONITOR MODE");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
SetSignal(PIN_ACK, ast);
|
SetSignal(PIN_ACK, ast);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
@ -664,7 +693,14 @@ BOOL FASTCALL GPIOBUS::GetRST()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetRST(BOOL ast)
|
void FASTCALL GPIOBUS::SetRST(BOOL ast)
|
||||||
{
|
{
|
||||||
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET RST IN MONITOR MODE");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
SetSignal(PIN_RST, ast);
|
SetSignal(PIN_RST, ast);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
@ -684,7 +720,13 @@ BOOL FASTCALL GPIOBUS::GetMSG()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetMSG(BOOL ast)
|
void FASTCALL GPIOBUS::SetMSG(BOOL ast)
|
||||||
{
|
{
|
||||||
SetSignal(PIN_MSG, ast);
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET MSG IN MONITOR MODE");
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
SetSignal(PIN_MSG, ast);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
@ -704,7 +746,14 @@ BOOL FASTCALL GPIOBUS::GetCD()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetCD(BOOL ast)
|
void FASTCALL GPIOBUS::SetCD(BOOL ast)
|
||||||
{
|
{
|
||||||
SetSignal(PIN_CD, ast);
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET CD IN MONITOR MODE");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SetSignal(PIN_CD, ast);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
@ -754,6 +803,21 @@ BOOL FASTCALL GPIOBUS::GetIO()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetIO(BOOL ast)
|
void FASTCALL GPIOBUS::SetIO(BOOL ast)
|
||||||
{
|
{
|
||||||
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET IO IN MONITOR MODE");
|
||||||
|
SetControl(PIN_DTD, DTD_IN);
|
||||||
|
SetMode(PIN_DT0, IN);
|
||||||
|
SetMode(PIN_DT1, IN);
|
||||||
|
SetMode(PIN_DT2, IN);
|
||||||
|
SetMode(PIN_DT3, IN);
|
||||||
|
SetMode(PIN_DT4, IN);
|
||||||
|
SetMode(PIN_DT5, IN);
|
||||||
|
SetMode(PIN_DT6, IN);
|
||||||
|
SetMode(PIN_DT7, IN);
|
||||||
|
SetMode(PIN_DP, IN);
|
||||||
|
}
|
||||||
|
|
||||||
SetSignal(PIN_IO, ast);
|
SetSignal(PIN_IO, ast);
|
||||||
|
|
||||||
if (actmode == TARGET) {
|
if (actmode == TARGET) {
|
||||||
@ -802,6 +866,12 @@ BOOL FASTCALL GPIOBUS::GetREQ()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetREQ(BOOL ast)
|
void FASTCALL GPIOBUS::SetREQ(BOOL ast)
|
||||||
{
|
{
|
||||||
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET REQ IN MONITOR MODE");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
SetSignal(PIN_REQ, ast);
|
SetSignal(PIN_REQ, ast);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -835,6 +905,14 @@ BYTE FASTCALL GPIOBUS::GetDAT()
|
|||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
void FASTCALL GPIOBUS::SetDAT(BYTE dat)
|
void FASTCALL GPIOBUS::SetDAT(BYTE dat)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
if(actmode == MONITOR)
|
||||||
|
{
|
||||||
|
printf("WARNING!!! SOMEONE TRIED TO SET Data IN MONITOR MODE");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Write to port
|
// Write to port
|
||||||
#if SIGNAL_CONTROL_MODE == 0
|
#if SIGNAL_CONTROL_MODE == 0
|
||||||
DWORD fsel;
|
DWORD fsel;
|
||||||
|
1174
src/raspberrypi/scsimon.cpp
Normal file
1174
src/raspberrypi/scsimon.cpp
Normal file
File diff suppressed because it is too large
Load Diff
1902
src/raspberrypi/scsimondev.cpp
Normal file
1902
src/raspberrypi/scsimondev.cpp
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user