2017-10-07 04:34:04 -04:00
|
|
|
/*
|
|
|
|
|
* 86Box A hypervisor and IBM PC system emulator that specializes in
|
|
|
|
|
* running old operating systems and software designed for IBM
|
|
|
|
|
* PC systems and compatibles from 1981 through fairly recent
|
|
|
|
|
* system designs based on the PCI bus.
|
|
|
|
|
*
|
|
|
|
|
* This file is part of the 86Box distribution.
|
|
|
|
|
*
|
|
|
|
|
* Handle the platform-side of CDROM drives.
|
|
|
|
|
*
|
2018-04-25 23:51:13 +02:00
|
|
|
* Version: @(#)win_cdrom.c 1.0.7 2018/03/26
|
2017-10-07 04:34:04 -04:00
|
|
|
*
|
|
|
|
|
* Authors: Sarah Walker, <http://pcem-emulator.co.uk/>
|
|
|
|
|
* Miran Grca, <mgrca8@gmail.com>
|
|
|
|
|
* Fred N. van Kempen, <decwiz@yahoo.com>
|
|
|
|
|
*
|
2018-03-06 01:14:38 +01:00
|
|
|
* Copyright 2016-2018 Miran Grca.
|
|
|
|
|
* Copyright 2017,2018 Fred N. van Kempen.
|
2017-10-07 04:34:04 -04:00
|
|
|
*/
|
|
|
|
|
#define UNICODE
|
|
|
|
|
#define BITMAP WINDOWS_BITMAP
|
|
|
|
|
#include <windows.h>
|
|
|
|
|
#include <windowsx.h>
|
|
|
|
|
#undef BITMAP
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
#include <wchar.h>
|
|
|
|
|
#include "../config.h"
|
|
|
|
|
#include "../disk/hdd.h"
|
2018-03-06 01:14:38 +01:00
|
|
|
#include "../disk/zip.h"
|
2017-10-07 04:34:04 -04:00
|
|
|
#include "../scsi/scsi.h"
|
2018-04-25 23:51:13 +02:00
|
|
|
#include "../cdrom/cdrom.h"
|
|
|
|
|
#include "../cdrom/cdrom_image.h"
|
|
|
|
|
#include "../cdrom/cdrom_null.h"
|
2017-10-07 04:34:04 -04:00
|
|
|
#include "../scsi/scsi_disk.h"
|
2017-10-10 03:07:29 -04:00
|
|
|
#include "../plat.h"
|
|
|
|
|
#include "../ui.h"
|
2017-10-07 04:34:04 -04:00
|
|
|
#include "win.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
cdrom_eject(uint8_t id)
|
|
|
|
|
{
|
|
|
|
|
if (cdrom_drives[id].host_drive == 0) {
|
|
|
|
|
/* Switch from empty to empty. Do nothing. */
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-17 20:32:20 +01:00
|
|
|
if (cdrom_image[id].prev_image_path) {
|
|
|
|
|
free(cdrom_image[id].prev_image_path);
|
|
|
|
|
cdrom_image[id].prev_image_path = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-07 04:34:04 -04:00
|
|
|
if (cdrom_drives[id].host_drive == 200) {
|
2018-03-17 20:32:20 +01:00
|
|
|
cdrom_image[id].prev_image_path = (wchar_t *) malloc(1024);
|
2017-10-07 04:34:04 -04:00
|
|
|
wcscpy(cdrom_image[id].prev_image_path, cdrom_image[id].image_path);
|
|
|
|
|
}
|
|
|
|
|
cdrom_drives[id].prev_host_drive = cdrom_drives[id].host_drive;
|
2018-04-25 23:51:13 +02:00
|
|
|
cdrom[id]->handler->exit(id);
|
|
|
|
|
cdrom_close_handler(id);
|
|
|
|
|
memset(cdrom_image[id].image_path, 0, 2048);
|
|
|
|
|
cdrom_null_open(id);
|
2017-10-07 04:34:04 -04:00
|
|
|
if (cdrom_drives[id].bus_type) {
|
|
|
|
|
/* Signal disc change to the emulated machine. */
|
2018-04-25 23:51:13 +02:00
|
|
|
cdrom_insert(cdrom[id]);
|
2017-10-07 04:34:04 -04:00
|
|
|
}
|
|
|
|
|
|
2017-10-10 03:07:29 -04:00
|
|
|
ui_sb_check_menu_item(SB_CDROM|id, IDM_CDROM_IMAGE | id, MF_UNCHECKED);
|
2017-10-07 04:34:04 -04:00
|
|
|
cdrom_drives[id].host_drive=0;
|
2017-10-10 03:07:29 -04:00
|
|
|
ui_sb_check_menu_item(SB_CDROM|id, IDM_CDROM_EMPTY | id, MF_CHECKED);
|
|
|
|
|
ui_sb_update_icon_state(SB_CDROM|id, 1);
|
|
|
|
|
ui_sb_enable_menu_item(SB_CDROM|id, IDM_CDROM_RELOAD | id, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
|
ui_sb_update_tip(SB_CDROM|id);
|
2017-10-07 04:34:04 -04:00
|
|
|
|
|
|
|
|
config_save();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
cdrom_reload(uint8_t id)
|
|
|
|
|
{
|
|
|
|
|
if ((cdrom_drives[id].host_drive == cdrom_drives[id].prev_host_drive) || (cdrom_drives[id].prev_host_drive == 0) || (cdrom_drives[id].host_drive != 0)) {
|
|
|
|
|
/* Switch from empty to empty. Do nothing. */
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-25 23:51:13 +02:00
|
|
|
cdrom_close_handler(id);
|
|
|
|
|
memset(cdrom_image[id].image_path, 0, 2048);
|
2017-10-07 04:34:04 -04:00
|
|
|
|
|
|
|
|
if (cdrom_drives[id].prev_host_drive == 200) {
|
|
|
|
|
wcscpy(cdrom_image[id].image_path, cdrom_image[id].prev_image_path);
|
2018-03-17 20:32:20 +01:00
|
|
|
free(cdrom_image[id].prev_image_path);
|
|
|
|
|
cdrom_image[id].prev_image_path = NULL;
|
2017-10-07 04:34:04 -04:00
|
|
|
image_open(id, cdrom_image[id].image_path);
|
|
|
|
|
if (cdrom_drives[id].bus_type) {
|
|
|
|
|
/* Signal disc change to the emulated machine. */
|
2018-04-25 23:51:13 +02:00
|
|
|
cdrom_insert(cdrom[id]);
|
2017-10-07 04:34:04 -04:00
|
|
|
}
|
|
|
|
|
if (wcslen(cdrom_image[id].image_path) == 0) {
|
2017-10-10 03:07:29 -04:00
|
|
|
ui_sb_check_menu_item(SB_CDROM|id, IDM_CDROM_EMPTY | id, MF_CHECKED);
|
2017-10-07 04:34:04 -04:00
|
|
|
cdrom_drives[id].host_drive = 0;
|
2017-10-10 03:07:29 -04:00
|
|
|
ui_sb_check_menu_item(SB_CDROM|id, IDM_CDROM_IMAGE | id, MF_UNCHECKED);
|
|
|
|
|
ui_sb_update_icon_state(SB_CDROM|id, 1);
|
2017-10-07 04:34:04 -04:00
|
|
|
} else {
|
2017-10-10 03:07:29 -04:00
|
|
|
ui_sb_check_menu_item(SB_CDROM|id, IDM_CDROM_EMPTY | id, MF_UNCHECKED);
|
2017-10-07 04:34:04 -04:00
|
|
|
cdrom_drives[id].host_drive = 200;
|
2017-10-10 03:07:29 -04:00
|
|
|
ui_sb_check_menu_item(SB_CDROM|id, IDM_CDROM_IMAGE | id, MF_CHECKED);
|
|
|
|
|
ui_sb_update_icon_state(SB_CDROM|id, 0);
|
2017-10-07 04:34:04 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-10 03:07:29 -04:00
|
|
|
ui_sb_enable_menu_item(SB_CDROM|id, IDM_CDROM_RELOAD | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
ui_sb_update_tip(SB_CDROM|id);
|
2017-10-07 04:34:04 -04:00
|
|
|
|
|
|
|
|
config_save();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2018-01-26 22:17:09 +01:00
|
|
|
void
|
|
|
|
|
zip_eject(uint8_t id)
|
|
|
|
|
{
|
|
|
|
|
zip_close(id);
|
|
|
|
|
if (zip_drives[id].bus_type) {
|
|
|
|
|
/* Signal disk change to the emulated machine. */
|
|
|
|
|
zip_insert(id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ui_sb_update_icon_state(SB_ZIP | id, 1);
|
|
|
|
|
ui_sb_enable_menu_item(SB_ZIP|id, IDM_ZIP_EJECT | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
ui_sb_enable_menu_item(SB_ZIP|id, IDM_ZIP_RELOAD | id, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
|
ui_sb_update_tip(SB_ZIP | id);
|
|
|
|
|
config_save();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
zip_reload(uint8_t id)
|
|
|
|
|
{
|
|
|
|
|
zip_disk_reload(id);
|
|
|
|
|
if (wcslen(zip_drives[id].image_path) == 0) {
|
|
|
|
|
ui_sb_enable_menu_item(SB_ZIP|id, IDM_ZIP_EJECT | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
ui_sb_update_icon_state(SB_ZIP|id, 1);
|
|
|
|
|
} else {
|
|
|
|
|
ui_sb_enable_menu_item(SB_ZIP|id, IDM_ZIP_EJECT | id, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
|
ui_sb_update_icon_state(SB_ZIP|id, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ui_sb_enable_menu_item(SB_ZIP|id, IDM_ZIP_RELOAD | id, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
|
ui_sb_update_tip(SB_ZIP|id);
|
|
|
|
|
|
|
|
|
|
config_save();
|
|
|
|
|
}
|