mirror of
https://github.com/kanjitalk755/macemu.git
synced 2025-01-10 18:29:44 +00:00
- AmigaOS: SCSI buffer memory type can be selected via prefs
This commit is contained in:
parent
d88fac31e1
commit
68310129fe
@ -15,6 +15,7 @@ V0.9 - <insert date here>
|
|||||||
- Unix: ether_linux.cpp moved and renamed to ether_unix.cpp, now
|
- Unix: ether_linux.cpp moved and renamed to ether_unix.cpp, now
|
||||||
also works with the tap driver under FreeBSD [Michael Alyn Miller]
|
also works with the tap driver under FreeBSD [Michael Alyn Miller]
|
||||||
- BeOS: fixed some bugs in the extfs file types handling
|
- BeOS: fixed some bugs in the extfs file types handling
|
||||||
|
- AmigaOS: SCSI buffer type can be selected
|
||||||
|
|
||||||
V0.9 (snapshot) - 17.Feb.2001
|
V0.9 (snapshot) - 17.Feb.2001
|
||||||
- adapted for mon V3.0 which is now the required minimum
|
- adapted for mon V3.0 which is now the required minimum
|
||||||
|
@ -508,6 +508,19 @@ AmigaOS:
|
|||||||
|
|
||||||
ahi/<hexadecimal mode ID>
|
ahi/<hexadecimal mode ID>
|
||||||
|
|
||||||
|
scsimemtype <type>
|
||||||
|
|
||||||
|
This item controls the type of memory to use for SCSI buffers. Possible
|
||||||
|
values are:
|
||||||
|
0 Chip memory
|
||||||
|
1 24-bit DMA capable memory
|
||||||
|
2 Any memory
|
||||||
|
|
||||||
|
Be warned that many SCSI host adapters will not work with the "Any memory"
|
||||||
|
setting. Basilisk II has no way of knowing which memory type is supported
|
||||||
|
by the host adapter and setting an unsupported type will result in data
|
||||||
|
corruption.
|
||||||
|
|
||||||
Windows:
|
Windows:
|
||||||
|
|
||||||
noscsi <"true" or "false">
|
noscsi <"true" or "false">
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
// Platform-specific preferences items
|
// Platform-specific preferences items
|
||||||
prefs_desc platform_prefs_items[] = {
|
prefs_desc platform_prefs_items[] = {
|
||||||
{"sound", TYPE_STRING, false, "sound output mode description"},
|
{"sound", TYPE_STRING, false, "sound output mode description"},
|
||||||
|
{"scsimemtype", TYPE_INT32, false, "SCSI buffer memory type"},
|
||||||
{NULL, TYPE_END, false, NULL} // End of list
|
{NULL, TYPE_END, false, NULL} // End of list
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -84,4 +85,5 @@ void SavePrefs(void)
|
|||||||
void AddPlatformPrefsDefaults(void)
|
void AddPlatformPrefsDefaults(void)
|
||||||
{
|
{
|
||||||
PrefsReplaceString("extfs", "WORK:");
|
PrefsReplaceString("extfs", "WORK:");
|
||||||
|
PrefsAddInt32("scsimemtype", 0);
|
||||||
}
|
}
|
||||||
|
@ -94,6 +94,7 @@ const int GAD_SCSI3_UNIT = 0x0413;
|
|||||||
const int GAD_SCSI4_UNIT = 0x0414;
|
const int GAD_SCSI4_UNIT = 0x0414;
|
||||||
const int GAD_SCSI5_UNIT = 0x0415;
|
const int GAD_SCSI5_UNIT = 0x0415;
|
||||||
const int GAD_SCSI6_UNIT = 0x0416;
|
const int GAD_SCSI6_UNIT = 0x0416;
|
||||||
|
const int GAD_SCSI_MEMTYPE = 0x0420;
|
||||||
|
|
||||||
const int GAD_VIDEO_TYPE = 0x0500; // "Graphics/Sound" pane
|
const int GAD_VIDEO_TYPE = 0x0500; // "Graphics/Sound" pane
|
||||||
const int GAD_DISPLAY_X = 0x0501;
|
const int GAD_DISPLAY_X = 0x0501;
|
||||||
@ -362,6 +363,10 @@ bool PrefsEditor(void)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case GAD_SCSI_MEMTYPE:
|
||||||
|
PrefsReplaceInt32("scsimemtype", code);
|
||||||
|
break;
|
||||||
|
|
||||||
case GAD_VIDEO_TYPE:
|
case GAD_VIDEO_TYPE:
|
||||||
ghost_graphics_gadgets(h);
|
ghost_graphics_gadgets(h);
|
||||||
break;
|
break;
|
||||||
@ -1087,6 +1092,7 @@ static void create_volumes_pane(struct LayoutHandle *h)
|
|||||||
|
|
||||||
static char scsi_dev[6][256];
|
static char scsi_dev[6][256];
|
||||||
static LONG scsi_unit[6];
|
static LONG scsi_unit[6];
|
||||||
|
static LONG scsi_memtype;
|
||||||
|
|
||||||
// Read SCSI preferences
|
// Read SCSI preferences
|
||||||
static void parse_scsi_prefs(void)
|
static void parse_scsi_prefs(void)
|
||||||
@ -1101,6 +1107,8 @@ static void parse_scsi_prefs(void)
|
|||||||
if (str)
|
if (str)
|
||||||
sscanf(str, "%[^/]/%ld", scsi_dev[i], &scsi_unit[i]);
|
sscanf(str, "%[^/]/%ld", scsi_dev[i], &scsi_unit[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scsi_memtype = PrefsFindInt32("scsimemtype");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read settings from gadgets and set preferences
|
// Read settings from gadgets and set preferences
|
||||||
@ -1125,6 +1133,10 @@ static void create_scsi_pane(struct LayoutHandle *h)
|
|||||||
parse_scsi_prefs();
|
parse_scsi_prefs();
|
||||||
|
|
||||||
VGROUP;
|
VGROUP;
|
||||||
|
LT_New(h, LA_Type, VERTICAL_KIND,
|
||||||
|
LA_LabelID, STR_SCSI_DEVICES_CTRL,
|
||||||
|
TAG_END
|
||||||
|
);
|
||||||
for (int i=0; i<7; i++) {
|
for (int i=0; i<7; i++) {
|
||||||
HGROUP;
|
HGROUP;
|
||||||
LT_New(h, LA_Type, TEXT_KIND,
|
LT_New(h, LA_Type, TEXT_KIND,
|
||||||
@ -1152,6 +1164,17 @@ static void create_scsi_pane(struct LayoutHandle *h)
|
|||||||
ENDGROUP;
|
ENDGROUP;
|
||||||
}
|
}
|
||||||
ENDGROUP;
|
ENDGROUP;
|
||||||
|
VGROUP;
|
||||||
|
LT_New(h, LA_Type, CYCLE_KIND,
|
||||||
|
LA_LabelID, STR_SCSI_MEMTYPE_CTRL,
|
||||||
|
LA_ID, GAD_SCSI_MEMTYPE,
|
||||||
|
LACY_FirstLabel, STR_MEMTYPE_CHIP_LAB,
|
||||||
|
LACY_LastLabel, STR_MEMTYPE_ANY_LAB,
|
||||||
|
LA_LONG, (ULONG)&scsi_memtype,
|
||||||
|
TAG_END
|
||||||
|
);
|
||||||
|
ENDGROUP;
|
||||||
|
ENDGROUP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1166,7 +1189,7 @@ enum {
|
|||||||
DISPLAY_SCREEN
|
DISPLAY_SCREEN
|
||||||
};
|
};
|
||||||
|
|
||||||
static BYTE display_type;
|
static LONG display_type;
|
||||||
static LONG dis_width, dis_height;
|
static LONG dis_width, dis_height;
|
||||||
static ULONG mode_id;
|
static ULONG mode_id;
|
||||||
static BYTE frameskip_num;
|
static BYTE frameskip_num;
|
||||||
@ -1210,9 +1233,9 @@ static void parse_graphics_prefs(void)
|
|||||||
|
|
||||||
const char *str = PrefsFindString("screen");
|
const char *str = PrefsFindString("screen");
|
||||||
if (str) {
|
if (str) {
|
||||||
if (sscanf(str, "win/%d/%d", &dis_width, &dis_height) == 2)
|
if (sscanf(str, "win/%ld/%ld", &dis_width, &dis_height) == 2)
|
||||||
display_type = DISPLAY_WINDOW;
|
display_type = DISPLAY_WINDOW;
|
||||||
else if (sscanf(str, "pip/%d/%d", &dis_width, &dis_height) == 2)
|
else if (sscanf(str, "pip/%ld/%ld", &dis_width, &dis_height) == 2)
|
||||||
display_type = DISPLAY_PIP;
|
display_type = DISPLAY_PIP;
|
||||||
else if (sscanf(str, "scr/%08lx", &mode_id) == 1)
|
else if (sscanf(str, "scr/%08lx", &mode_id) == 1)
|
||||||
display_type = DISPLAY_SCREEN;
|
display_type = DISPLAY_SCREEN;
|
||||||
@ -1368,7 +1391,7 @@ static void create_graphics_pane(struct LayoutHandle *h)
|
|||||||
LA_LabelID, STR_VIDEO_TYPE_CTRL,
|
LA_LabelID, STR_VIDEO_TYPE_CTRL,
|
||||||
LA_ID, GAD_VIDEO_TYPE,
|
LA_ID, GAD_VIDEO_TYPE,
|
||||||
LACY_LabelTable, (ULONG)labels,
|
LACY_LabelTable, (ULONG)labels,
|
||||||
LA_BYTE, (ULONG)&display_type,
|
LA_LONG, (ULONG)&display_type,
|
||||||
TAG_END
|
TAG_END
|
||||||
);
|
);
|
||||||
LT_New(h, LA_Type, INTEGER_KIND,
|
LT_New(h, LA_Type, INTEGER_KIND,
|
||||||
|
@ -44,6 +44,7 @@ static struct MsgPort *the_port = NULL; // Message port for device communication
|
|||||||
|
|
||||||
static ULONG buffer_size; // Size of data buffer
|
static ULONG buffer_size; // Size of data buffer
|
||||||
static UBYTE *buffer = NULL; // Pointer to data buffer
|
static UBYTE *buffer = NULL; // Pointer to data buffer
|
||||||
|
static ULONG buffer_memf; // Buffer memory flags
|
||||||
|
|
||||||
static UBYTE cmd_buffer[12]; // Buffer for SCSI command
|
static UBYTE cmd_buffer[12]; // Buffer for SCSI command
|
||||||
|
|
||||||
@ -59,9 +60,22 @@ void SCSIInit(void)
|
|||||||
{
|
{
|
||||||
int id, lun;
|
int id, lun;
|
||||||
|
|
||||||
|
int memtype = PrefsFindInt32("scsimemtype");
|
||||||
|
switch (memtype) {
|
||||||
|
case 1:
|
||||||
|
buffer_memf = MEMF_24BITDMA | MEMF_PUBLIC;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
buffer_memf = MEMF_ANY | MEMF_PUBLIC;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
buffer_memf = MEMF_CHIP | MEMF_PUBLIC;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
// Create port and buffers
|
// Create port and buffers
|
||||||
the_port = CreateMsgPort();
|
the_port = CreateMsgPort();
|
||||||
buffer = (UBYTE *)AllocMem(buffer_size = 0x10000, MEMF_CHIP | MEMF_PUBLIC);
|
buffer = (UBYTE *)AllocMem(buffer_size = 0x10000, buffer_memf);
|
||||||
sense_buffer = (UBYTE *)AllocMem(SENSE_LENGTH, MEMF_CHIP | MEMF_PUBLIC);
|
sense_buffer = (UBYTE *)AllocMem(SENSE_LENGTH, MEMF_CHIP | MEMF_PUBLIC);
|
||||||
if (the_port == NULL || buffer == NULL || sense_buffer == NULL) {
|
if (the_port == NULL || buffer == NULL || sense_buffer == NULL) {
|
||||||
ErrorAlert(GetString(STR_NO_MEM_ERR));
|
ErrorAlert(GetString(STR_NO_MEM_ERR));
|
||||||
@ -142,7 +156,7 @@ static bool try_buffer(int size)
|
|||||||
if (size <= buffer_size)
|
if (size <= buffer_size)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
UBYTE *new_buffer = (UBYTE *)AllocMem(size, MEMF_CHIP | MEMF_PUBLIC);
|
UBYTE *new_buffer = (UBYTE *)AllocMem(size, buffer_memf);
|
||||||
if (new_buffer == NULL)
|
if (new_buffer == NULL)
|
||||||
return false;
|
return false;
|
||||||
FreeMem(buffer, buffer_size);
|
FreeMem(buffer, buffer_size);
|
||||||
@ -241,7 +255,7 @@ bool scsi_send_cmd(size_t data_length, bool reading, int sg_size, uint8 **sg_ptr
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Process S/G table when reading
|
// Process S/G table when reading
|
||||||
if (res == 0) {
|
if (reading && res == 0) {
|
||||||
D(bug(" reading from buffer\n"));
|
D(bug(" reading from buffer\n"));
|
||||||
uint8 *buffer_ptr = buffer;
|
uint8 *buffer_ptr = buffer;
|
||||||
for (int i=0; i<sg_size; i++) {
|
for (int i=0; i<sg_size; i++) {
|
||||||
|
@ -44,10 +44,15 @@ user_string_def platform_strings[] = {
|
|||||||
{STR_NO_GTLAYOUT_LIB_WARN, "Cannot open gtlayout.library V39. The preferences editor GUI will not be available."},
|
{STR_NO_GTLAYOUT_LIB_WARN, "Cannot open gtlayout.library V39. The preferences editor GUI will not be available."},
|
||||||
{STR_NO_AHI_WARN, "Cannot open ahi.device V2. Audio output will be disabled."},
|
{STR_NO_AHI_WARN, "Cannot open ahi.device V2. Audio output will be disabled."},
|
||||||
{STR_NO_AHI_CTRL_WARN, "Cannot open AHI control structure. Audio output will be disabled."},
|
{STR_NO_AHI_CTRL_WARN, "Cannot open AHI control structure. Audio output will be disabled."},
|
||||||
{STR_AHI_MODE_CTRL, "AHI Mode"},
|
|
||||||
|
|
||||||
{STR_NOT_ENOUGH_MEM_WARN, "Could not get %lu MBytes of memory.\nShould I use the largest Block (%lu MBytes) instead ?"},
|
{STR_NOT_ENOUGH_MEM_WARN, "Could not get %lu MBytes of memory.\nShould I use the largest Block (%lu MBytes) instead ?"},
|
||||||
|
|
||||||
|
{STR_AHI_MODE_CTRL, "AHI Mode"},
|
||||||
|
{STR_SCSI_MEMTYPE_CTRL, "Buffer Memory Type"},
|
||||||
|
{STR_MEMTYPE_CHIP_LAB, "Chip"},
|
||||||
|
{STR_MEMTYPE_24BITDMA_LAB, "24-Bit DMA"},
|
||||||
|
{STR_MEMTYPE_ANY_LAB, "Any"},
|
||||||
|
{STR_SCSI_DEVICES_CTRL, "Virtual SCSI Devices"},
|
||||||
|
|
||||||
{-1, NULL} // End marker
|
{-1, NULL} // End marker
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -36,9 +36,14 @@ enum {
|
|||||||
STR_NO_GTLAYOUT_LIB_WARN,
|
STR_NO_GTLAYOUT_LIB_WARN,
|
||||||
STR_NO_AHI_WARN,
|
STR_NO_AHI_WARN,
|
||||||
STR_NO_AHI_CTRL_WARN,
|
STR_NO_AHI_CTRL_WARN,
|
||||||
|
STR_NOT_ENOUGH_MEM_WARN,
|
||||||
|
|
||||||
STR_AHI_MODE_CTRL,
|
STR_AHI_MODE_CTRL,
|
||||||
STR_NOT_ENOUGH_MEM_WARN,
|
STR_SCSI_MEMTYPE_CTRL,
|
||||||
|
STR_MEMTYPE_CHIP_LAB,
|
||||||
|
STR_MEMTYPE_24BITDMA_LAB,
|
||||||
|
STR_MEMTYPE_ANY_LAB,
|
||||||
|
STR_SCSI_DEVICES_CTRL
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user