| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- /**
- * This file is originally part of ZuluSCSI adopted for BlueSCSI
- *
- * ZuluSCSI™ - Copyright (c) 2022-2025 Rabbit Hole Computing™
- * Portions copyright (c) 2023 joshua stein <jcs@jcs.org>
- *
- * ZuluSCSI™ firmware is licensed under the GPL version 3 or any later version.
- *
- * https://www.gnu.org/licenses/gpl-3.0.html
- * ----
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- **/
- // Compile-time configuration parameters.
- // Other settings can be set by ini file at runtime.
- #pragma once
- #include <BlueSCSI_platform_config.h>
- // Use variables for version number
- #define FW_VER_NUM "2025.07.09"
- // rel or dev only.
- #define FW_VER_SUFFIX "dev"
- #define DEF_STRINGFY(DEF) STRINGFY(DEF)
- #define STRINGFY(STR) #STR
- #define FIRMWARE_NAME_PREFIX DEF_STRINGFY(BUILD_ENV)
- #define BLUE_FW_VERSION FW_VER_NUM "-" FW_VER_SUFFIX
- #define INQUIRY_NAME PLATFORM_NAME "v" FW_VER_NUM
- #define TOOLBOX_API 0
- // Configuration and log file paths
- #define CONFIGFILE "bluescsi.ini"
- #define LOGFILE "log.txt"
- #define CRASHFILE "err.txt"
- // Prefix for command file to create new image (case-insensitive)
- #define CREATEFILE "create"
- // Log buffer size in bytes, must be a power of 2
- #ifndef LOGBUFSIZE
- #define LOGBUFSIZE 16384
- #endif
- #define LOG_SAVE_INTERVAL_MS 1000
- // How often to check for SD card presence
- #define SDCARD_POLL_INTERVAL 5000
- // Watchdog timeout
- // Watchdog will first issue a bus reset and if that does not help, crashdump.
- #define WATCHDOG_BUS_RESET_TIMEOUT 15000
- #define WATCHDOG_CRASH_TIMEOUT 30000
- // HDD image file format
- #define HDIMG_ID_POS 2 // Position to embed ID number
- #define HDIMG_LUN_POS 3 // Position to embed LUN numbers
- #define HDIMG_BLK_POS 5 // Position to embed block size numbers
- #define MAX_FILE_PATH 64 // Maximum file name length
- // Image definition options
- #define IMAGE_INDEX_MAX 9 // Maximum number of 'IMG0' style statements parsed
- // SCSI config
- #define NUM_SCSIID 8 // Maximum number of supported SCSI-IDs (The minimum is 0)
- #define NUM_SCSILUN 1 // Maximum number of LUNs supported (Currently has to be 1)
- #define READ_PARITY_CHECK 0 // Perform read parity check (unverified)
- // SCSI raw fallback configuration when no image files are detected
- // Presents the whole SD card as an SCSI drive
- #define RAW_FALLBACK_ENABLE 1
- #define RAW_FALLBACK_SCSI_ID 1
- #define RAW_FALLBACK_BLOCKSIZE 512
- // Default SCSI drive information (can be overridden in INI file)
- // Selected based on device type (fixed, removable, optical, floppy, mag-optical, tape)
- // Each entry has {vendor, product, version, serial}
- // If serial number is left empty, SD card serial number is used.
- #define DRIVEINFO_FIXED {"BLUESCSI", "HARDDRIVE", PLATFORM_REVISION, ""}
- #define DRIVEINFO_REMOVABLE {"BLUESCSI", "REMOVABLE", PLATFORM_REVISION, ""}
- #define DRIVEINFO_OPTICAL {"BLUESCSI", "CDROM", PLATFORM_REVISION, ""}
- #define DRIVEINFO_FLOPPY {"BLUESCSI", "FLOPPY", PLATFORM_REVISION, ""}
- #define DRIVEINFO_MAGOPT {"BLUESCSI", "MO_DRIVE", PLATFORM_REVISION, ""}
- #define DRIVEINFO_NETWORK {"Dayna", "SCSI/Link", "2.0f", ""}
- #define DRIVEINFO_TAPE {"BLUESCSI", "TAPE", PLATFORM_REVISION, ""}
- // Default block size
- #define DEFAULT_BLOCKSIZE 512
- // Default optical drive blocksize
- #define DEFAULT_BLOCKSIZE_OPTICAL 2048
- // Default SCSI drive information when Apple quirks are enabled
- #define APPLE_DRIVEINFO_FIXED {"QUANTUM", "BlueSCSI Pico", PLATFORM_REVISION, "1.0"}
- #define APPLE_DRIVEINFO_REMOVABLE {"IOMEGA", "BETA230", PLATFORM_REVISION, "2.02"}
- #define APPLE_DRIVEINFO_OPTICAL {"BlueSCSI", "CD-ROM CDU-55S", "1.9a", ""}
- #define APPLE_DRIVEINFO_FLOPPY {"IOMEGA", "Io20S *F", "PP33", ""}
- #define APPLE_DRIVEINFO_MAGOPT {"MOST", "RMD-5200", PLATFORM_REVISION, "1.0"}
- #define APPLE_DRIVEINFO_NETWORK {"Dayna", "SCSI/Link", "2.0f", ""}
- #define APPLE_DRIVEINFO_TAPE {"BlueSCSI", "APPLE_TAPE", PLATFORM_REVISION, ""}
- // Default Iomega ZIP drive information
- #define IOMEGA_DRIVEINFO_ZIP100 {"IOMEGA", "ZIP 100", "D.13", ""}
- #define IOMEGA_DRIVEINFO_ZIP250 {"IOMEGA", "ZIP 250", "42.S", ""}
- #define IOMEGA_DRIVEINFO_JAZ {"iomega", "jaz", "", ""}
- // Default delay for SCSI phases.
- // Can be adjusted in ini file
- #define DEFAULT_SCSI_DELAY_US 10
- #define DEFAULT_REQ_TYPE_SETUP_NS 500
- // Use prefetch buffer in read requests
- #ifndef PREFETCH_BUFFER_SIZE
- #define PREFETCH_BUFFER_SIZE 8192
- #endif
- // Masks for buttons
- #define EJECT_BTN_MASK (1|2)
- #define USER_BTN_MASK (4)
- // Zip disk media sizes
- #define ZIP100_DISK_SIZE 100663296 // bytes
- #define ZIP250_DISK_SIZE 250640384 // bytes
- #define TAPE_DEFAULT_NAME "tape.000"
- // Settings for rebooting
- #define REBOOT_INTO_MASS_STORAGE_MAGIC_NUM 0x5eeded
|