main.cpp 53 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899
  1. /*
  2. * F4 BlueSCSI
  3. * Copyright (c) 2021 Eric Helgeson, Tech by Androda, LLC
  4. *
  5. * This file is free software: you may copy, redistribute and/or modify it
  6. * under the terms of the GNU General Public License as published by the
  7. * Free Software Foundation, either version 2 of the License, or (at your
  8. * option) any later version.
  9. *
  10. * This file is distributed in the hope that it will be useful, but
  11. * WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  13. * General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see https://github.com/erichelgeson/bluescsi.
  17. *
  18. * This file incorporates work covered by the following copyright and
  19. * permission notice:
  20. *
  21. * Copyright (c) 2019 komatsu
  22. *
  23. * Permission to use, copy, modify, and/or distribute this software
  24. * for any purpose with or without fee is hereby granted, provided
  25. * that the above copyright notice and this permission notice appear
  26. * in all copies.
  27. *
  28. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  29. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  30. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  31. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR
  32. * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS
  33. * OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
  34. * NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  35. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  36. */
  37. #pragma GCC diagnostic warning "-fpermissive"
  38. #include <Arduino.h> // For Platform.IO
  39. #include <SdFat.h>
  40. #include <setjmp.h>
  41. #include <libmaple/exti.h>
  42. #define DEBUG 1 // 0:No debug information output
  43. // 1: Debug information output to USB Serial
  44. // 2: Debug information output to LOG.txt (slow)
  45. #define VDS "2022-09-20"
  46. // Log File
  47. #define VERSION "1.1-" VDS "-BLACKSASI"
  48. #define LOG_FILENAME "LOG.txt"
  49. #include "blacksasi.h"
  50. #include "scsi_cmds.h"
  51. #include "scsi_sense.h"
  52. #include "scsi_status.h"
  53. #include "scsi_mode.h"
  54. #ifdef USE_STM32_DMA
  55. #warning "warning USE_STM32_DMA"
  56. #endif
  57. // SDFAT
  58. SdFs SD;
  59. FsFile LOG_FILE;
  60. volatile bool m_isBusReset = false; // Bus reset
  61. volatile bool m_resetJmp = false; // Call longjmp on reset
  62. jmp_buf m_resetJmpBuf;
  63. byte scsi_id_mask; // Mask list of responding SCSI IDs
  64. byte m_id; // Currently responding SCSI-ID
  65. byte m_lun; // Logical unit number currently responding
  66. byte m_sts; // Status byte
  67. byte m_msg; // Message bytes
  68. byte m_buf[MAX_BLOCKSIZE]; // General purpose buffer
  69. byte m_scsi_buf[SCSI_BUF_SIZE]; // Buffer for SCSI READ/WRITE Buffer
  70. unsigned m_scsi_buf_size = 0;
  71. byte m_msb[256]; // Command storage bytes
  72. SCSI_DEVICE scsi_device_list[NUM_SCSIID][NUM_SCSILUN]; // Maximum number
  73. SCSI_INQUIRY_DATA default_hdd, default_optical;
  74. // function table
  75. byte (*scsi_command_table[MAX_SCSI_COMMAND])(SCSI_DEVICE *dev, const byte *cdb);
  76. uint32_t db_bsrr[256];
  77. // scsi command functions
  78. SCSI_COMMAND_HANDLER(onUnimplemented);
  79. SCSI_COMMAND_HANDLER(onNOP);
  80. SCSI_COMMAND_HANDLER(onRequestSense);
  81. SCSI_COMMAND_HANDLER(onRead6);
  82. SCSI_COMMAND_HANDLER(onRead10);
  83. SCSI_COMMAND_HANDLER(onWrite6);
  84. SCSI_COMMAND_HANDLER(onWrite10);
  85. SCSI_COMMAND_HANDLER(onInquiry);
  86. SCSI_COMMAND_HANDLER(onReadCapacity);
  87. SCSI_COMMAND_HANDLER(onModeSense);
  88. SCSI_COMMAND_HANDLER(onModeSelect);
  89. SCSI_COMMAND_HANDLER(onVerify);
  90. SCSI_COMMAND_HANDLER(onReadBuffer);
  91. SCSI_COMMAND_HANDLER(onWriteBuffer);
  92. SCSI_COMMAND_HANDLER(onTestUnitReady);
  93. SCSI_COMMAND_HANDLER(onReZeroUnit);
  94. SCSI_COMMAND_HANDLER(onSendDiagnostic);
  95. SCSI_COMMAND_HANDLER(onReadDefectData);
  96. SCSI_COMMAND_HANDLER(onReadTOC);
  97. SCSI_COMMAND_HANDLER(onReadDVDStructure);
  98. SCSI_COMMAND_HANDLER(onReadDiscInformation);
  99. static uint32_t MSFtoLBA(const byte *msf);
  100. static void LBAtoMSF(const uint32_t lba, byte *msf);
  101. static void flashError(const unsigned error);
  102. void findDriveImages(FsFile root);
  103. /*
  104. * IO read.
  105. */
  106. inline byte readIO(void)
  107. {
  108. // Port input data register
  109. uint32_t ret = GPIOD->regs->IDR;
  110. byte bret = (byte)~(((ret >> 8) & 0b11111111));
  111. #if READ_PARITY_CHECK
  112. if((db_bsrr[bret]^ret)&1) // TODO fix parity calculation
  113. m_sts |= 0x01; // parity error
  114. #endif
  115. return bret;
  116. }
  117. // If config file exists, read the first three lines and copy the contents.
  118. // File must be well formed or you will get junk in the SCSI Vendor fields.
  119. void readSCSIDeviceConfig(SCSI_DEVICE *dev) {
  120. FsFile config_file = SD.open("scsi-config.txt", O_RDONLY);
  121. if (!config_file.isOpen()) {
  122. return;
  123. }
  124. SCSI_INQUIRY_DATA *iq = dev->inquiry_block;
  125. char vendor[9];
  126. memset(vendor, 0, sizeof(vendor));
  127. config_file.readBytes(vendor, sizeof(vendor));
  128. LOG_FILE.print("SCSI VENDOR: ");
  129. LOG_FILE.println(vendor);
  130. memcpy(&iq->vendor, vendor, 8);
  131. char product[17];
  132. memset(product, 0, sizeof(product));
  133. config_file.readBytes(product, sizeof(product));
  134. LOG_FILE.print("SCSI PRODUCT: ");
  135. LOG_FILE.println(product);
  136. memcpy(&iq->product, product, 16);
  137. char version[5];
  138. memset(version, 0, sizeof(version));
  139. config_file.readBytes(version, sizeof(version));
  140. LOG_FILE.print("SCSI VERSION: ");
  141. LOG_FILE.println(version);
  142. memcpy(&iq->revision, version, 4);
  143. config_file.close();
  144. }
  145. bool VerifyISOPVD(SCSI_DEVICE *dev, unsigned sector_size, bool mode2)
  146. {
  147. int seek = 16 * sector_size;
  148. if(sector_size > CDROM_COMMON_SECTORSIZE) seek += 16;
  149. if(mode2) seek += 8;
  150. bool ret = false;
  151. dev->m_file->seekSet(seek);
  152. dev->m_file->read(m_buf, 2048);
  153. ret = ((m_buf[0] == 1 && !strncmp((char *)&m_buf[1], "CD001", 5) && m_buf[6] == 1) ||
  154. (m_buf[8] == 1 && !strncmp((char *)&m_buf[9], "CDROM", 5) && m_buf[14] == 1));
  155. dev->m_file->rewind();
  156. return ret;
  157. }
  158. /*
  159. * Open HDD image file
  160. */
  161. bool hddimageOpen(SCSI_DEVICE *dev, FsFile *file,int id,int lun,int blocksize)
  162. {
  163. dev->m_fileSize= 0;
  164. dev->m_sector_offset = 0;
  165. dev->m_blocksize = blocksize;
  166. dev->m_rawblocksize = blocksize;
  167. dev->m_file = file;
  168. if(!dev->m_file->isOpen()) { goto failed; }
  169. dev->m_fileSize = dev->m_file->size();
  170. if(dev->m_fileSize < 1) {
  171. LOG_FILE.println(" - file is 0 bytes, can not use.");
  172. goto failed;
  173. }
  174. if(dev->m_type == SCSI_DEVICE_OPTICAL) {
  175. LOG_FILE.print(" CDROM");
  176. dev->m_blocksize = CDROM_COMMON_SECTORSIZE;
  177. // Borrowed from PCEM
  178. if(VerifyISOPVD(dev, CDROM_COMMON_SECTORSIZE, false)) {
  179. dev->m_rawblocksize = CDROM_COMMON_SECTORSIZE;
  180. dev->m_mode2 = false;
  181. } else if(VerifyISOPVD(dev, CDROM_RAW_SECTORSIZE, false)) {
  182. dev->m_rawblocksize = CDROM_RAW_SECTORSIZE;
  183. dev->m_mode2 = false;
  184. dev->m_raw = true;
  185. dev->m_sector_offset = 16;
  186. } else if(VerifyISOPVD(dev, 2336, true)) {
  187. dev->m_rawblocksize = 2336;
  188. dev->m_mode2 = true;
  189. } else if(VerifyISOPVD(dev, CDROM_RAW_SECTORSIZE, true)) {
  190. dev->m_rawblocksize = CDROM_RAW_SECTORSIZE;
  191. dev->m_mode2 = true;
  192. dev->m_raw = true;
  193. dev->m_sector_offset = 24;
  194. } else {
  195. // Last ditch effort
  196. // size must be less than 700MB
  197. if(dev->m_fileSize > 912579600) {
  198. goto failed;
  199. }
  200. dev->m_raw = true;
  201. if(!(dev->m_fileSize % CDROM_COMMON_SECTORSIZE)) {
  202. // try a multiple of 2048
  203. dev->m_blocksize = CDROM_COMMON_SECTORSIZE;
  204. dev->m_rawblocksize = CDROM_COMMON_SECTORSIZE;
  205. } else {
  206. // I give up!
  207. LOG_FILE.println(" InvalidISO");
  208. goto failed;
  209. }
  210. }
  211. } else {
  212. LOG_FILE.print(" HDD");
  213. }
  214. dev->m_blockcount = dev->m_fileSize / dev->m_blocksize;
  215. // check blocksize dummy file
  216. LOG_FILE.print(" / ");
  217. LOG_FILE.print(dev->m_fileSize);
  218. LOG_FILE.print("bytes / ");
  219. LOG_FILE.print(dev->m_fileSize / 1024);
  220. LOG_FILE.print("KiB / ");
  221. LOG_FILE.print(dev->m_fileSize / 1024 / 1024);
  222. LOG_FILE.println("MiB");
  223. if(dev->m_type == SCSI_DEVICE_OPTICAL) {
  224. LOG_FILE.print(" MODE2:");LOG_FILE.print(dev->m_mode2);
  225. LOG_FILE.print(" BlockSize:");LOG_FILE.println(dev->m_rawblocksize);
  226. }
  227. return true; // File opened
  228. failed:
  229. dev->m_file->close();
  230. dev->m_fileSize = dev->m_blocksize = 0; // no file
  231. delete dev->m_file;
  232. dev->m_file = NULL;
  233. return false;
  234. }
  235. /*
  236. * Initialization.
  237. * Initialize the bus and set the PIN orientation
  238. */
  239. void setup()
  240. {
  241. // Setup BSRR table
  242. for (unsigned i = 0; i <= 255; i++) {
  243. db_bsrr[i] = genBSRR(i);
  244. }
  245. gpioInit();
  246. // Default all SCSI command handlers to onUnimplemented
  247. for(unsigned i = 0; i < MAX_SCSI_COMMAND; i++)
  248. {
  249. scsi_command_table[i] = onUnimplemented;
  250. }
  251. // SCSI commands that just need to return ok
  252. scsi_command_table[SCSI_FORMAT_UNIT4] = onNOP;
  253. scsi_command_table[SCSI_FORMAT_UNIT6] = onNOP;
  254. scsi_command_table[SCSI_REASSIGN_BLOCKS] = onNOP;
  255. scsi_command_table[SCSI_SEEK6] = onNOP;
  256. scsi_command_table[SCSI_SEEK10] = onNOP;
  257. scsi_command_table[SCSI_START_STOP_UNIT] = onNOP;
  258. scsi_command_table[SCSI_PREVENT_ALLOW_REMOVAL] = onNOP;
  259. scsi_command_table[SCSI_RELEASE] = onNOP;
  260. scsi_command_table[SCSI_RESERVE] = onNOP;
  261. scsi_command_table[SCSI_TEST_UNIT_READY] = onNOP;
  262. // SCSI commands that have handlers
  263. scsi_command_table[SCSI_REZERO_UNIT] = onReZeroUnit;
  264. scsi_command_table[SCSI_REQUEST_SENSE] = onRequestSense;
  265. scsi_command_table[SCSI_READ6] = onRead6;
  266. scsi_command_table[SCSI_READ10] = onRead10;
  267. scsi_command_table[SCSI_WRITE6] = onWrite6;
  268. scsi_command_table[SCSI_WRITE10] = onWrite10;
  269. scsi_command_table[SCSI_INQUIRY] = onInquiry;
  270. scsi_command_table[SCSI_READ_CAPACITY] = onReadCapacity;
  271. scsi_command_table[SCSI_MODE_SENSE6] = onModeSense;
  272. scsi_command_table[SCSI_MODE_SENSE10] = onModeSense;
  273. scsi_command_table[SCSI_MODE_SELECT6] = onModeSelect;
  274. scsi_command_table[SCSI_MODE_SELECT10] = onModeSelect;
  275. scsi_command_table[SCSI_VERIFY10] = onVerify;
  276. scsi_command_table[SCSI_READ_BUFFER] = onReadBuffer;
  277. scsi_command_table[SCSI_WRITE_BUFFER] = onWriteBuffer;
  278. scsi_command_table[SCSI_SEND_DIAG] = onSendDiagnostic;
  279. scsi_command_table[SCSI_READ_DEFECT_DATA] = onReadDefectData;
  280. scsi_command_table[SCSI_READ_TOC] = onReadTOC;
  281. scsi_command_table[SCSI_READ_DVD_STRUCTURE] = onReadDVDStructure;
  282. scsi_command_table[SCSI_READ_DISC_INFORMATION] = onReadDiscInformation;
  283. // clear and initialize default inquiry blocks
  284. // default SCSI HDD
  285. memset(&default_hdd, 0, sizeof(default_hdd));
  286. default_hdd.ansi_version = 1;
  287. default_hdd.response_format = 1;
  288. default_hdd.additional_length = 31;
  289. memcpy(&default_hdd.vendor, "QUANTUM", 7);
  290. memcpy(&default_hdd.product, "BlackSASI", 9);
  291. memcpy(&default_hdd.revision, "1.0", 3);
  292. // default SCSI CDROM
  293. memset(&default_optical, 0, sizeof(default_optical));
  294. default_optical.peripheral_device_type = 5;
  295. default_optical.rmb = 1;
  296. default_optical.ansi_version = 1;
  297. default_optical.response_format = 1;
  298. default_optical.additional_length = 42;
  299. default_optical.sync = 1;
  300. memcpy(&default_optical.vendor, "BlackSASI", 9);
  301. memcpy(&default_optical.product, "CD-ROM CDU-55S", 14);
  302. memcpy(&default_optical.revision, "1.9a", 4);
  303. default_optical.release = 0x20;
  304. memcpy(&default_optical.revision_date, "1995", 4);
  305. // Serial initialization
  306. #if DEBUG == 1
  307. serial.begin(115200);
  308. // If using a USB->TTL monitor instead of USB serial monitor - you can uncomment this.
  309. //while (!Serial);
  310. #endif
  311. delay(3000);
  312. int image_file_set = ((digitalRead(BOARD_SWITCH1_PIN) == LOW) ) |
  313. ((digitalRead(BOARD_SWITCH2_PIN) == LOW) ) << 1 |
  314. ((digitalRead(BOARD_SWITCH3_PIN) == LOW) ) << 2 |
  315. ((digitalRead(BOARD_SWITCH4_PIN) == LOW) ) << 3;
  316. // Transceiver Pin Initialization
  317. pinMode(BOARD_SCSI_TAD, OUTPUT);
  318. pinMode(BOARD_SCSI_IND, OUTPUT);
  319. pinMode(BOARD_SCSI_DTD, OUTPUT);
  320. TRANSCEIVER_IO_SET(vIND,TR_INPUT);
  321. TRANSCEIVER_IO_SET(vTAD,TR_INPUT);
  322. // Turn off the output port
  323. SCSI_TARGET_INACTIVE()
  324. //Occurs when the RST pin state changes from HIGH to LOW
  325. //attachInterrupt(RST, onBusReset, FALLING);
  326. // Try Full and half clock speeds.
  327. LED1_ON();
  328. int mhz = 0;
  329. // Try each speed bucket a few times, and go way down for very old SD cards
  330. // Most will initialize immediately at the highest speed
  331. int speedsToTry[] = {50, 49, 43, 42, 25, 24, 17, 16, 8, 7, 5, 4, 3, 1 };
  332. for (int i = 0; i < sizeof(speedsToTry); i++) {
  333. if(SD.begin(SdSpiConfig(SS, DEDICATED_SPI, SD_SCK_MHZ(speedsToTry[i])))) {
  334. mhz = speedsToTry[i];
  335. break;
  336. }
  337. }
  338. LED1_OFF();
  339. if(mhz == 0) {
  340. #if DEBUG > 0
  341. LOG("SD initialization failed!");
  342. #endif
  343. flashError(ERROR_NO_SDCARD);
  344. }
  345. initFileLog(mhz);
  346. serial.println("YYYYY");
  347. readSDCardInfo();
  348. serial.println("XXXX");
  349. //HD image file open
  350. scsi_id_mask = 0x00;
  351. // Iterate over the root path in the SD card looking for candidate image files.
  352. FsFile root;
  353. char image_set_dir_name[] = "/ImageSetX/";
  354. image_set_dir_name[9] = char(image_file_set) + 0x30;
  355. root.open(image_set_dir_name);
  356. if (root.isDirectory()) {
  357. LOG_FILE.print("Looking for images in: ");
  358. LOG_FILE.println(image_set_dir_name);
  359. LOG_FILE.sync();
  360. } else {
  361. root.close();
  362. root.open("/");
  363. }
  364. findDriveImages(root);
  365. root.close();
  366. FsFile images_all_dir;
  367. images_all_dir.open("/ImageSetAll/");
  368. if (images_all_dir.isDirectory()) {
  369. LOG_FILE.println("Looking for images in: /ImageSetAll/");
  370. LOG_FILE.sync();
  371. findDriveImages(images_all_dir);
  372. }
  373. images_all_dir.close();
  374. // Error if there are 0 image files
  375. if(scsi_id_mask==0) {
  376. LOG_FILE.println("ERROR: No valid images found!");
  377. flashError(ERROR_FALSE_INIT);
  378. }
  379. finalizeFileLog();
  380. LED1_OFF();
  381. //Occurs when the RST pin state changes from HIGH to LOW
  382. attachInterrupt(BOARD_SCSI_RST, onBusReset, FALLING);
  383. }
  384. void findDriveImages(FsFile root) {
  385. bool image_ready;
  386. FsFile *file = NULL;
  387. char path_name[MAX_FILE_PATH+1];
  388. root.getName(path_name, sizeof(path_name));
  389. SD.chdir(path_name);
  390. SCSI_DEVICE *dev = NULL;
  391. while (1) {
  392. // Directories can not be opened RDWR, so it will fail, but fails the same way with no file/dir, so we need to peek at the file first.
  393. FsFile file_test = root.openNextFile(O_RDONLY);
  394. char name[MAX_FILE_PATH+1];
  395. file_test.getName(name, MAX_FILE_PATH+1);
  396. // Skip directories and already open files.
  397. if(file_test.isDir() || strncmp(name, "LOG.txt", 7) == 0) {
  398. file_test.close();
  399. continue;
  400. }
  401. // If error there is no next file to open.
  402. if(file_test.getError() > 0) {
  403. file_test.close();
  404. break;
  405. }
  406. // Valid file, open for reading/writing.
  407. file = new FsFile(SD.open(name, O_RDWR));
  408. if(file && file->isFile()) {
  409. SCSI_DEVICE_TYPE device_type;
  410. if(tolower(name[1]) != 'd') {
  411. file->close();
  412. delete file;
  413. LOG_FILE.print("Not an image: ");
  414. LOG_FILE.println(name);
  415. continue;
  416. }
  417. switch (tolower(name[0])) {
  418. case 'h': device_type = SCSI_DEVICE_HDD;
  419. break;
  420. case 'c': device_type = SCSI_DEVICE_OPTICAL;
  421. break;
  422. default:
  423. file->close();
  424. delete file;
  425. LOG_FILE.print("Not an image: ");
  426. LOG_FILE.println(name);
  427. continue;
  428. }
  429. // Defaults for Hard Disks
  430. int id = 1; // 0 and 3 are common in Macs for physical HD and CD, so avoid them.
  431. int lun = 0;
  432. int blk = 512;
  433. // Positionally read in and coerase the chars to integers.
  434. // We only require the minimum and read in the next if provided.
  435. int file_name_length = strlen(name);
  436. if(file_name_length > 2) { // HD[N]
  437. int tmp_id = name[HDIMG_ID_POS] - '0';
  438. // If valid id, set it, else use default
  439. if(tmp_id > -1 && tmp_id < 8) {
  440. id = tmp_id;
  441. } else {
  442. LOG_FILE.print(name);
  443. LOG_FILE.println(" - bad SCSI id in filename, Using default ID 1");
  444. }
  445. }
  446. if(file_name_length > 3) { // HDN[N]
  447. int tmp_lun = name[HDIMG_LUN_POS] - '0';
  448. // If valid lun, set it, else use default
  449. if(tmp_lun == 0 || tmp_lun == 1) {
  450. lun = tmp_lun;
  451. } else {
  452. LOG_FILE.print(name);
  453. LOG_FILE.println(" - bad SCSI LUN in filename, Using default LUN ID 0");
  454. }
  455. }
  456. int blk1 = 0, blk2, blk3, blk4 = 0;
  457. if(file_name_length > 8) { // HD00_[111]
  458. blk1 = name[HDIMG_BLK_POS] - '0';
  459. blk2 = name[HDIMG_BLK_POS+1] - '0';
  460. blk3 = name[HDIMG_BLK_POS+2] - '0';
  461. if(file_name_length > 9) // HD00_NNN[1]
  462. blk4 = name[HDIMG_BLK_POS+3] - '0';
  463. }
  464. if(blk1 == 2 && blk2 == 5 && blk3 == 6) {
  465. blk = 256;
  466. } else if(blk1 == 1 && blk2 == 0 && blk3 == 2 && blk4 == 4) {
  467. blk = 1024;
  468. } else if(blk1 == 2 && blk2 == 0 && blk3 == 4 && blk4 == 8) {
  469. blk = 2048;
  470. }
  471. if(id < NUM_SCSIID && lun < NUM_SCSILUN) {
  472. dev = &scsi_device_list[id][lun];
  473. LOG_FILE.print(" - ");
  474. LOG_FILE.print(name);
  475. dev->m_type = device_type;
  476. image_ready = hddimageOpen(dev, file, id, lun, blk);
  477. if(image_ready) { // Marked as a responsive ID
  478. scsi_id_mask |= 1<<id;
  479. switch(dev->m_type)
  480. {
  481. case SCSI_DEVICE_HDD:
  482. // default SCSI HDD
  483. dev->inquiry_block = &default_hdd;
  484. break;
  485. case SCSI_DEVICE_OPTICAL:
  486. // default SCSI CDROM
  487. dev->inquiry_block = &default_optical;
  488. break;
  489. }
  490. readSCSIDeviceConfig(dev);
  491. }
  492. }
  493. }
  494. LOG_FILE.sync();
  495. }
  496. // cd .. before going back.
  497. SD.chdir("/");
  498. }
  499. static void flashError(const unsigned error)
  500. {
  501. while(true) {
  502. for(uint8_t i = 0; i < error; i++) {
  503. LED1_ON();
  504. delay(250);
  505. LED1_OFF();
  506. delay(250);
  507. }
  508. delay(3000);
  509. }
  510. }
  511. /*
  512. * Return from exception and call longjmp
  513. */
  514. void __attribute__ ((noinline)) longjmpFromInterrupt(jmp_buf jmpb, int retval) __attribute__ ((noreturn));
  515. void longjmpFromInterrupt(jmp_buf jmpb, int retval) {
  516. // Address of longjmp with the thumb bit cleared
  517. const uint32_t longjmpaddr = ((uint32_t)longjmp) & 0xfffffffe;
  518. const uint32_t zero = 0;
  519. // Default PSR value, function calls don't require any particular value
  520. const uint32_t PSR = 0x01000000;
  521. // For documentation on what this is doing, see:
  522. // https://developer.arm.com/documentation/dui0552/a/the-cortex-m3-processor/exception-model/exception-entry-and-return
  523. // Stack frame needs to have R0-R3, R12, LR, PC, PSR (from bottom to top)
  524. // This is being set up to have R0 and R1 contain the parameters passed to longjmp, and PC is the address of the longjmp function.
  525. // This is using existing stack space, rather than allocating more, as longjmp is just going to unroll the stack even further.
  526. // 0xfffffff9 is the EXC_RETURN value to return to thread mode.
  527. asm (
  528. "str %0, [sp];\
  529. str %1, [sp, #4];\
  530. str %2, [sp, #8];\
  531. str %2, [sp, #12];\
  532. str %2, [sp, #16];\
  533. str %2, [sp, #20];\
  534. str %3, [sp, #24];\
  535. str %4, [sp, #28];\
  536. ldr lr, =0xfffffff9;\
  537. bx lr"
  538. :: "r"(jmpb),"r"(retval),"r"(zero), "r"(longjmpaddr), "r"(PSR)
  539. );
  540. }
  541. /*
  542. * Bus reset interrupt.
  543. */
  544. void onBusReset(void)
  545. {
  546. if(isHigh(digitalRead(BOARD_SCSI_RST))) {
  547. delayMicroseconds(20);
  548. if(isHigh(digitalRead(BOARD_SCSI_RST))) {
  549. // BUS FREE is done in the main process
  550. // gpio_mode(MSG, GPIO_OUTPUT_OD);
  551. // gpio_mode(CD, GPIO_OUTPUT_OD);
  552. // gpio_mode(REQ, GPIO_OUTPUT_OD);
  553. // gpio_mode(IO, GPIO_OUTPUT_OD);
  554. // Should I enter DB and DBP once?
  555. SCSI_DB_INPUT()
  556. LOGN("BusReset!");
  557. if (m_resetJmp) {
  558. m_resetJmp = false;
  559. // Jumping out of the interrupt handler, so need to clear the interupt source.
  560. uint8 exti = 15; // PIN_MAP[RST].gpio_bit; the gpio_bit is just the number in the pin bank
  561. EXTI_BASE->PR = (1U << exti);
  562. longjmpFromInterrupt(m_resetJmpBuf, 1);
  563. } else {
  564. m_isBusReset = true;
  565. }
  566. }
  567. }
  568. }
  569. /*
  570. * Enable the reset longjmp, and check if reset fired while it was disabled.
  571. */
  572. void enableResetJmp(void) {
  573. m_resetJmp = true;
  574. if (m_isBusReset) {
  575. longjmp(m_resetJmpBuf, 1);
  576. }
  577. }
  578. /*
  579. * Read by handshake.
  580. */
  581. inline byte readHandshake(void)
  582. {
  583. SCSI_OUT(vREQ,active)
  584. //SCSI_DB_INPUT()
  585. while( ! SCSI_IN(vACK));
  586. byte r = readIO();
  587. SCSI_OUT(vREQ,inactive)
  588. while( SCSI_IN(vACK));
  589. return r;
  590. }
  591. /*
  592. * Write with a handshake.
  593. */
  594. inline void writeHandshake(byte d)
  595. {
  596. // This has a 400ns bus settle delay built in. Not optimal for multi-byte transfers.
  597. GPIOD->regs->BSRR = db_bsrr[d]; // setup DB,DBP (160ns) //PM2022 need to add parity from PE
  598. TRANSCEIVER_IO_SET(vDTD,DB_OUTPUT)
  599. SCSI_DB_OUTPUT() // (180ns)
  600. // ACK.Fall to DB output delay 100ns(MAX) (DTC-510B)
  601. SCSI_OUT(vREQ,inactive) // setup wait (30ns)w
  602. SCSI_OUT(vREQ,inactive) // setup wait (30ns)
  603. SCSI_OUT(vREQ,inactive) // setup wait (30ns)
  604. SCSI_OUT(vREQ,active) // (30ns)
  605. //while(!SCSI_IN(vACK)) { if(m_isBusReset){ SCSI_DB_INPUT() return; }}
  606. while(!SCSI_IN(vACK));
  607. // ACK.Fall to REQ.Raise delay 500ns(typ.) (DTC-510B)
  608. uint32_t bsrrCall = ((db_bsrr[0xff] & 0xFFDFFFFF) | 0x00000020);
  609. GPIOE->regs->BSRR = bsrrCall; // DB=0xFF , SCSI_OUT(vREQ,inactive) //PM2022 should wirite data to bus
  610. // REQ.Raise to DB hold time 0ns
  611. SCSI_DB_INPUT() // (150ns)
  612. TRANSCEIVER_IO_SET(vDTD,DB_INPUT)
  613. while( SCSI_IN(vACK));
  614. }
  615. #pragma GCC push_options
  616. #pragma GCC optimize ("-Os")
  617. /*
  618. * This loop is tuned to repeat the following pattern:
  619. * 1) Set REQ
  620. * 2) 5 cycles of work/delay
  621. * 3) Wait for ACK
  622. * Cycle time tunings are for 72MHz STM32F103
  623. * Alignment matters. For the 3 instruction wait loops,it looks like crossing
  624. * an 8 byte prefetch buffer can add 2 cycles of wait every branch taken.
  625. */
  626. void writeDataLoop(uint32_t blocksize, const byte* srcptr) {
  627. #define REQ_ON() (PBREG->BSRR = req_rst_bit);
  628. #define FETCH_BSRR_DB() (bsrr_val = bsrr_tbl[*srcptr++])
  629. #define REQ_OFF_DB_SET(BSRR_VAL) PBREG->BSRR = BSRR_VAL;
  630. #define WAIT_ACK_ACTIVE() while((*port_b_idr>>(vACK&15)&1))
  631. #define WAIT_ACK_INACTIVE() while(!(*port_b_idr>>(vACK&15)&1))
  632. register const byte *endptr= srcptr + blocksize; // End pointer
  633. register const uint32_t *bsrr_tbl = db_bsrr; // Table to convert to BSRR
  634. register uint32_t bsrr_val; // BSRR value to output (DB, DBP, REQ = ACTIVE)
  635. register uint32_t req_bit = BITMASK(vREQ);
  636. register uint32_t req_rst_bit = BITMASK(vREQ) << 16;
  637. register volatile uint32 *port_b_idr = &(GPIOB->regs->IDR);
  638. // Start the first bus cycle.
  639. FETCH_BSRR_DB();
  640. REQ_OFF_DB_SET(bsrr_val);
  641. REQ_ON();
  642. FETCH_BSRR_DB();
  643. WAIT_ACK_ACTIVE();
  644. REQ_OFF_DB_SET(bsrr_val);
  645. // Align the starts of the do/while and WAIT loops to an 8 byte prefetch.
  646. do{
  647. WAIT_ACK_INACTIVE();
  648. REQ_ON();
  649. // 4 cycles of work
  650. FETCH_BSRR_DB();
  651. WAIT_ACK_ACTIVE();
  652. REQ_OFF_DB_SET(bsrr_val);
  653. }while(srcptr < endptr);
  654. WAIT_ACK_INACTIVE();
  655. // Finish the last bus cycle, byte is already on DB.
  656. REQ_ON();
  657. WAIT_ACK_ACTIVE();
  658. REQ_OFF_DB_SET(bsrr_val);
  659. WAIT_ACK_INACTIVE();
  660. }
  661. #pragma GCC pop_options
  662. /*
  663. * Data in phase.
  664. * Send len bytes of data array p.
  665. */
  666. void writeDataPhase(int len, const byte* p)
  667. {
  668. LOG(" DI ");
  669. SCSI_PHASE_CHANGE(SCSI_PHASE_DATAIN);
  670. // Bus settle delay 400ns. Following code was measured at 800ns before REQ asserted. STM32F103.
  671. TRANSCEIVER_IO_SET(vDTD,TR_OUTPUT)
  672. SCSI_DB_OUTPUT()
  673. writeDataLoop(len, p);
  674. SCSI_DB_INPUT()
  675. TRANSCEIVER_IO_SET(vDTD,DB_INPUT)
  676. }
  677. /*
  678. * Data in phase.
  679. * Send len block while reading from SD card.
  680. */
  681. void writeDataPhaseSD(SCSI_DEVICE *dev, uint32_t adds, uint32_t len)
  682. {
  683. LOG (" DI(SD) ");
  684. SCSI_PHASE_CHANGE(SCSI_PHASE_DATAIN);
  685. //Bus settle delay 400ns, file.seek() measured at over 1000ns.
  686. uint64_t pos = (uint64_t)adds * dev->m_rawblocksize;
  687. dev->m_file->seekSet(pos);
  688. TRANSCEIVER_IO_SET(vDTD,DB_OUTPUT)
  689. SCSI_DB_OUTPUT()
  690. for(uint32_t i = 0; i < len; i++) {
  691. // Asynchronous reads will make it faster ...
  692. m_resetJmp = false;
  693. dev->m_file->read(m_buf, dev->m_rawblocksize);
  694. enableResetJmp();
  695. writeDataLoop(dev->m_blocksize, &m_buf[dev->m_sector_offset]);
  696. }
  697. SCSI_DB_INPUT()
  698. TRANSCEIVER_IO_SET(vDTD,DB_INPUT)
  699. }
  700. #pragma GCC push_options
  701. #pragma GCC optimize ("-Os")
  702. /*
  703. * See writeDataLoop for optimization info.
  704. */
  705. void readDataLoop(uint32_t blockSize, byte* dstptr) __attribute__ ((aligned(16)));
  706. void readDataLoop(uint32_t blockSize, byte* dstptr)
  707. {
  708. register byte *endptr= dstptr + blockSize - 1;
  709. #define REQ_ON() (PEREG->BSRR = req_rst_bit);
  710. #define REQ_OFF() (PEREG->BSRR = req_bit);
  711. #define WAIT_ACK_ACTIVE() while((*port_b_idr>>(vACK&15)&1)) //PM2022
  712. #define WAIT_ACK_INACTIVE() while(!(*port_b_idr>>(vACK&15)&1))
  713. register uint32_t req_bit = BITMASK(vREQ);
  714. register uint32_t req_rst_bit = BITMASK(vREQ) << 16;
  715. register volatile uint32 *port_b_idr = &(GPIOB->regs->IDR);
  716. REQ_ON();
  717. // Start of the do/while and WAIT are already aligned to 8 bytes.
  718. do {
  719. WAIT_ACK_ACTIVE();
  720. uint32_t ret = PDREG->IDR;
  721. REQ_OFF();
  722. *dstptr++ = (byte)~(((ret) & 0b11111111));
  723. // Move wait loop in to a single 8 byte prefetch buffer
  724. asm("nop.w;nop");
  725. WAIT_ACK_INACTIVE();
  726. REQ_ON();
  727. // Extra 1 cycle delay
  728. asm("nop");
  729. } while(dstptr<endptr);
  730. WAIT_ACK_ACTIVE();
  731. uint32_t ret = GPIOD->regs->IDR;
  732. REQ_OFF();
  733. *dstptr = (byte)~(((ret ) & 0b11111111) );
  734. WAIT_ACK_INACTIVE();
  735. }
  736. #pragma GCC pop_options
  737. /*
  738. * Data out phase.
  739. * len block read
  740. */
  741. void readDataPhase(int len, byte* p)
  742. {
  743. LOG(" DO ");
  744. SCSI_PHASE_CHANGE(SCSI_PHASE_DATAOUT);
  745. // Bus settle delay 400ns. The following code was measured at 450ns before REQ asserted. STM32F103.
  746. readDataLoop(len, p);
  747. }
  748. /*
  749. * Data out phase.
  750. * Write to SD card while reading len block.
  751. */
  752. void readDataPhaseSD(SCSI_DEVICE *dev, uint32_t adds, uint32_t len)
  753. {
  754. LOG(" DO(SD) ");
  755. SCSI_PHASE_CHANGE(SCSI_PHASE_DATAOUT);
  756. //Bus settle delay 400ns, file.seek() measured at over 1000ns.
  757. uint64_t pos = (uint64_t)adds * dev->m_blocksize;
  758. dev->m_file->seekSet(pos);
  759. for(uint32_t i = 0; i < len; i++) {
  760. m_resetJmp = true;
  761. readDataLoop(dev->m_blocksize, m_buf);
  762. m_resetJmp = false;
  763. dev->m_file->write(m_buf, dev->m_blocksize);
  764. // If a reset happened while writing, break and let the flush happen before it is handled.
  765. if (m_isBusReset) {
  766. break;
  767. }
  768. }
  769. dev->m_file->flush();
  770. enableResetJmp();
  771. }
  772. /*
  773. * Data out phase.
  774. * Compare to SD card while reading len block.
  775. */
  776. void verifyDataPhaseSD(SCSI_DEVICE *dev, uint32_t adds, uint32_t len)
  777. {
  778. LOG(" DO(SD) ");
  779. SCSI_PHASE_CHANGE(SCSI_PHASE_DATAOUT);
  780. //Bus settle delay 400ns, file.seek() measured at over 1000ns.
  781. uint64_t pos = (uint64_t)adds * dev->m_blocksize;
  782. dev->m_file->seekSet(pos);
  783. for(uint32_t i = 0; i < len; i++) {
  784. readDataLoop(dev->m_blocksize, m_buf);
  785. // This has just gone through the transfer to make things work, a compare would go here.
  786. }
  787. }
  788. /*
  789. * MsgIn2.
  790. */
  791. void MsgIn2(int msg)
  792. {
  793. LOG(" MI:"); LOGHEX(msg); LOG(" ");
  794. SCSI_PHASE_CHANGE(SCSI_PHASE_MESSAGEIN);
  795. // Bus settle delay 400ns built in to writeHandshake
  796. writeHandshake(msg);
  797. }
  798. /*
  799. * Main loop.
  800. */
  801. void loop()
  802. {
  803. // Reset all DB and Target pins, switch transceivers to input
  804. // Precaution against bugs or jumps which don't clean up properly
  805. SCSI_DB_INPUT();
  806. TRANSCEIVER_IO_SET(vDTD,DB_INPUT)
  807. SCSI_TARGET_INACTIVE();
  808. // Reset target state bits (BSY, MSG, CD, REQ, IO)
  809. GPIOE->regs->BSRR = 0x00000074; // MSG, CD, REQ, IO
  810. GPIOB->regs->BSRR = 0x00000040; // BOARD_SCSI_BSY
  811. TRANSCEIVER_IO_SET(vTAD,TR_INPUT)
  812. TRANSCEIVER_IO_SET(vIND,TR_INPUT)
  813. LED3_ON();
  814. //int msg = 0;
  815. m_msg = 0;
  816. m_lun = 0xff;
  817. SCSI_DEVICE *dev = (SCSI_DEVICE *)0; // HDD image for current SCSI-ID, LUN
  818. do {
  819. serial.print(SCSI_IN(vBSY));
  820. serial.print(SCSI_IN(vSEL));
  821. serial.println(SCSI_IN(vRST));
  822. } while( SCSI_IN(vBSY) || !SCSI_IN(vSEL) || SCSI_IN(vRST));
  823. //do {} while( !SCSI_IN(vBSY) || SCSI_IN(vRST));
  824. // We're in ARBITRATION
  825. //LOG(" A:"); LOGHEX(readIO()); LOG(" ");
  826. //do {} while( SCSI_IN(vBSY) || !SCSI_IN(vSEL) || SCSI_IN(vRST));
  827. //LOG(" S:"); LOGHEX(readIO()); LOG(" ");
  828. // We're in SELECTION
  829. byte scsiid = readIO() & scsi_id_mask;
  830. if(SCSI_IN(vIO) || (scsiid) == 0) {
  831. delayMicroseconds(1);
  832. return;
  833. }
  834. // We've been selected
  835. TRANSCEIVER_IO_SET(vTAD,TR_OUTPUT);
  836. TRANSCEIVER_IO_SET(vIND,TR_OUTPUT);
  837. SCSI_TARGET_ACTIVE() // (BSY), REQ, MSG, CD, IO output turned on
  838. // Set BSY to-when selected
  839. SCSI_BSY_ACTIVE(); // Turn only BSY output ON, ACTIVE
  840. // Wait until SEL becomes inactive
  841. while(isHigh(digitalRead(BOARD_SCSI_SEL))) {}
  842. // Ask for a TARGET-ID to respond
  843. m_id = 31 - __builtin_clz(scsiid);
  844. m_isBusReset = false;
  845. if (setjmp(m_resetJmpBuf) == 1) {
  846. LOGN("Reset, going to BusFree");
  847. goto BusFree;
  848. }
  849. enableResetJmp();
  850. // In SCSI-2 this is mandatory, but in SCSI-1 it's optional
  851. if(isHigh(digitalRead(BOARD_SCSI_ATN))) {
  852. SCSI_PHASE_CHANGE(SCSI_PHASE_MESSAGEOUT);
  853. // Bus settle delay 400ns. Following code was measured at 350ns before REQ asserted. Added another 50ns. STM32F103.
  854. SCSI_PHASE_CHANGE(SCSI_PHASE_MESSAGEOUT);// 28ns delay STM32F103
  855. SCSI_PHASE_CHANGE(SCSI_PHASE_MESSAGEOUT);// 28ns delay STM32F103
  856. bool syncenable = false;
  857. int syncperiod = 50;
  858. int syncoffset = 0;
  859. int msc = 0;
  860. while(isHigh(digitalRead(BOARD_SCSI_ATN)) && msc < 255) {
  861. m_msb[msc++] = readHandshake();
  862. }
  863. for(int i = 0; i < msc; i++) {
  864. // ABORT
  865. if (m_msb[i] == 0x06) {
  866. goto BusFree;
  867. }
  868. // BUS DEVICE RESET
  869. if (m_msb[i] == 0x0C) {
  870. syncoffset = 0;
  871. goto BusFree;
  872. }
  873. // IDENTIFY
  874. if (m_msb[i] >= 0x80) {
  875. m_lun = m_msb[i] & 0x1f;
  876. }
  877. // Extended message
  878. if (m_msb[i] == 0x01) {
  879. // Check only when synchronous transfer is possible
  880. if (!syncenable || m_msb[i + 2] != 0x01) {
  881. MsgIn2(0x07);
  882. break;
  883. }
  884. // Transfer period factor(50 x 4 = Limited to 200ns)
  885. syncperiod = m_msb[i + 3];
  886. if (syncperiod > 50) {
  887. syncperiod = 50;
  888. }
  889. // REQ/ACK offset(Limited to 16)
  890. syncoffset = m_msb[i + 4];
  891. if (syncoffset > 16) {
  892. syncoffset = 16;
  893. }
  894. // STDR response message generation
  895. MsgIn2(0x01);
  896. MsgIn2(0x03);
  897. MsgIn2(0x01);
  898. MsgIn2(syncperiod);
  899. MsgIn2(syncoffset);
  900. break;
  901. }
  902. }
  903. }
  904. LOG("CMD:");
  905. SCSI_PHASE_CHANGE(SCSI_PHASE_COMMAND);
  906. // Bus settle delay 400ns. The following code was measured at 20ns before REQ asserted. Added another 380ns. STM32F103.
  907. asm("nop;nop;nop;nop;nop;nop;nop;nop");// This asm causes some code reodering, which adds 270ns, plus 8 nop cycles for an additional 110ns. STM32F103
  908. int len;
  909. byte cmd[20];
  910. cmd[0] = readHandshake();
  911. // Atari ST ICD extension support
  912. // It sends a 0x1F as a indicator there is a
  913. // proper full size SCSI command byte to follow
  914. // so just read it and re-read it again to get the
  915. // real command byte
  916. if(cmd[0] == SCSI_ICD_EXTENDED_CMD) { cmd[0] = readHandshake(); }
  917. LOGHEX(cmd[0]);
  918. // Command length selection, reception
  919. static const int cmd_class_len[8]={6,10,10,6,6,12,6,6};
  920. len = cmd_class_len[cmd[0] >> 5];
  921. cmd[1] = readHandshake(); LOG(":");LOGHEX(cmd[1]);
  922. cmd[2] = readHandshake(); LOG(":");LOGHEX(cmd[2]);
  923. cmd[3] = readHandshake(); LOG(":");LOGHEX(cmd[3]);
  924. cmd[4] = readHandshake(); LOG(":");LOGHEX(cmd[4]);
  925. cmd[5] = readHandshake(); LOG(":");LOGHEX(cmd[5]);
  926. // Receive the remaining commands
  927. for(int i = 6; i < len; i++ ) {
  928. cmd[i] = readHandshake();
  929. LOG(":");
  930. LOGHEX(cmd[i]);
  931. }
  932. // LUN confirmation
  933. // if it wasn't set in the IDENTIFY then grab it from the CDB
  934. if(m_lun > MAX_SCSILUN)
  935. {
  936. m_lun = (cmd[1] & 0xe0) >> 5;
  937. }
  938. LOG(":ID ");
  939. LOG(m_id);
  940. LOG(":LUN ");
  941. LOG(m_lun);
  942. LOG(" ");
  943. // HDD Image selection
  944. if(m_lun >= NUM_SCSILUN)
  945. {
  946. m_sts = SCSI_STATUS_GOOD;
  947. // REQUEST SENSE and INQUIRY are handled different with invalid LUNs
  948. if(cmd[0] == SCSI_INQUIRY)
  949. {
  950. // Special INQUIRY handling for invalid LUNs
  951. LOGN("onInquiry - InvalidLUN");
  952. dev = &(scsi_device_list[m_id][0]);
  953. byte temp = dev->inquiry_block->raw[0];
  954. // If the LUN is invalid byte 0 of inquiry block needs to be 7fh
  955. dev->inquiry_block->raw[0] = 0x7f;
  956. // only write back what was asked for
  957. writeDataPhase(cmd[4], dev->inquiry_block->raw);
  958. // return it back to normal if it was altered
  959. dev->inquiry_block->raw[0] = temp;
  960. }
  961. else if(cmd[0] == SCSI_REQUEST_SENSE)
  962. {
  963. byte buf[18] = {
  964. 0x70, //CheckCondition
  965. 0, //Segment number
  966. SCSI_SENSE_ILLEGAL_REQUEST, //Sense key
  967. 0, 0, 0, 0, //information
  968. 10, //Additional data length
  969. 0, 0, 0, 0, // command specific information bytes
  970. (byte)(SCSI_ASC_LOGICAL_UNIT_NOT_SUPPORTED >> 8),
  971. (byte)SCSI_ASC_LOGICAL_UNIT_NOT_SUPPORTED,
  972. 0, 0, 0, 0,
  973. };
  974. writeDataPhase(cmd[4] < 18 ? cmd[4] : 18, buf);
  975. }
  976. else
  977. {
  978. m_sts = SCSI_STATUS_CHECK_CONDITION;
  979. }
  980. goto Status;
  981. }
  982. dev = &(scsi_device_list[m_id][m_lun]);
  983. if(!dev->m_file)
  984. {
  985. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  986. dev->m_additional_sense_code = SCSI_ASC_LOGICAL_UNIT_NOT_SUPPORTED;
  987. m_sts = SCSI_STATUS_CHECK_CONDITION;
  988. goto Status;
  989. }
  990. LED1_ON();
  991. m_sts = scsi_command_table[cmd[0]](dev, cmd);
  992. LED1_OFF();
  993. Status:
  994. LOG(" STS:"); LOGHEX(m_sts);
  995. SCSI_PHASE_CHANGE(SCSI_PHASE_STATUS);
  996. // Bus settle delay 400ns built in to writeHandshake
  997. writeHandshake(m_sts);
  998. LOG(" MI:"); LOGHEX(m_msg);
  999. SCSI_PHASE_CHANGE(SCSI_PHASE_MESSAGEIN);
  1000. // Bus settle delay 400ns built in to writeHandshake
  1001. writeHandshake(m_msg);
  1002. BusFree:
  1003. LOGN(" BF ");
  1004. m_isBusReset = false;
  1005. //SCSI_OUT(vREQ,inactive) // gpio_write(REQ, low);
  1006. //SCSI_OUT(vMSG,inactive) // gpio_write(MSG, low);
  1007. //SCSI_OUT(vCD ,inactive) // gpio_write(CD, low);
  1008. //SCSI_OUT(vIO ,inactive) // gpio_write(IO, low);
  1009. //SCSI_OUT(vBSY,inactive)
  1010. SCSI_TARGET_INACTIVE() // Turn off BSY, REQ, MSG, CD, IO output
  1011. TRANSCEIVER_IO_SET(vTAD,TR_INPUT);
  1012. TRANSCEIVER_IO_SET(vIND,TR_INPUT);
  1013. // Something in code linked after this function is performing better with a +4 alignment.
  1014. // Adding this nop is causing the next function (_GLOBAL__sub_I_SD) to have an address with a last digit of 0x4.
  1015. // Last digit of 0xc also works.
  1016. // This affects both with and without XCVR, currently without XCVR doesn't need any padding.
  1017. // Until the culprit can be tracked down and fixed, it may be necessary to do manual adjustment.
  1018. asm("nop.w");
  1019. }
  1020. static byte onUnimplemented(SCSI_DEVICE *dev, const byte *cdb)
  1021. {
  1022. // does nothing!
  1023. LOG("Unimplemented SCSI command: ");
  1024. LOGHEXN(cdb[0]);
  1025. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1026. dev->m_additional_sense_code = SCSI_ASC_INVALID_OPERATION_CODE;
  1027. return SCSI_STATUS_CHECK_CONDITION;
  1028. }
  1029. static byte onNOP(SCSI_DEVICE *dev, const byte *cdb)
  1030. {
  1031. dev->m_senseKey = 0;
  1032. dev->m_additional_sense_code = 0;
  1033. return SCSI_STATUS_GOOD;
  1034. }
  1035. /*
  1036. * INQUIRY command processing.
  1037. */
  1038. byte onInquiry(SCSI_DEVICE *dev, const byte *cdb)
  1039. {
  1040. writeDataPhase(cdb[4] < 47 ? cdb[4] : 47, dev->inquiry_block->raw);
  1041. return SCSI_STATUS_GOOD;
  1042. }
  1043. /*
  1044. * REQUEST SENSE command processing.
  1045. */
  1046. byte onRequestSense(SCSI_DEVICE *dev, const byte *cdb)
  1047. {
  1048. byte buf[18] = {
  1049. 0x70, //CheckCondition
  1050. 0, //Segment number
  1051. dev->m_senseKey, //Sense key
  1052. 0, 0, 0, 0, //information
  1053. 10, //Additional data length
  1054. 0, 0, 0, 0, // command specific information bytes
  1055. (byte)(dev->m_additional_sense_code >> 8),
  1056. (byte)dev->m_additional_sense_code,
  1057. 0, 0, 0, 0,
  1058. };
  1059. dev->m_senseKey = 0;
  1060. dev->m_additional_sense_code = 0;
  1061. writeDataPhase(cdb[4] < 18 ? cdb[4] : 18, buf);
  1062. return SCSI_STATUS_GOOD;
  1063. }
  1064. /*
  1065. * READ CAPACITY command processing.
  1066. */
  1067. byte onReadCapacity(SCSI_DEVICE *dev, const byte *cdb)
  1068. {
  1069. uint32_t lastlba = dev->m_blockcount - 1; // Points to last LBA
  1070. uint8_t buf[8] = {
  1071. (byte)(lastlba >> 24),
  1072. (byte)(lastlba >> 16),
  1073. (byte)(lastlba >> 8),
  1074. (byte)(lastlba),
  1075. (byte)(dev->m_blocksize >> 24),
  1076. (byte)(dev->m_blocksize >> 16),
  1077. (byte)(dev->m_blocksize >> 8),
  1078. (byte)(dev->m_blocksize)
  1079. };
  1080. writeDataPhase(sizeof(buf), buf);
  1081. return SCSI_STATUS_GOOD;
  1082. }
  1083. /*
  1084. * Check that the image file is present and the block range is valid.
  1085. */
  1086. byte checkBlockCommand(SCSI_DEVICE *dev, uint32_t adds, uint32_t len)
  1087. {
  1088. // Check block range is valid
  1089. if (adds >= dev->m_blockcount || (adds + len) > dev->m_blockcount) {
  1090. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1091. dev->m_additional_sense_code = SCSI_ASC_LOGICAL_BLOCK_ADDRESS_OUT_OF_RANGE;
  1092. return SCSI_STATUS_CHECK_CONDITION;
  1093. }
  1094. return SCSI_STATUS_GOOD;
  1095. }
  1096. /*
  1097. * READ6 / 10 Command processing.
  1098. */
  1099. static byte onRead6(SCSI_DEVICE *dev, const byte *cdb)
  1100. {
  1101. unsigned adds = (((uint32_t)cdb[1] & 0x1F) << 16) | ((uint32_t)cdb[2] << 8) | cdb[3];
  1102. unsigned len = (cdb[4] == 0) ? 0x100 : cdb[4];
  1103. /*
  1104. LOGN("onRead6");
  1105. LOG("-R ");
  1106. LOGHEX(adds);
  1107. LOG(":");
  1108. LOGHEXN(len);
  1109. */
  1110. byte sts = checkBlockCommand(dev, adds, len);
  1111. if (sts) {
  1112. return sts;
  1113. }
  1114. writeDataPhaseSD(dev, adds, len);
  1115. return SCSI_STATUS_GOOD;
  1116. }
  1117. static byte onRead10(SCSI_DEVICE *dev, const byte *cdb)
  1118. {
  1119. unsigned adds = ((uint32_t)cdb[2] << 24) | ((uint32_t)cdb[3] << 16) | ((uint32_t)cdb[4] << 8) | cdb[5];
  1120. unsigned len = ((uint32_t)cdb[7] << 8) | cdb[8];
  1121. LOG (" Read10 ");
  1122. LOG("A:");
  1123. LOGHEX(adds);
  1124. LOG(":");
  1125. LOGHEX(len);
  1126. LOG(" ");
  1127. byte sts = checkBlockCommand(dev, adds, len);
  1128. if (sts) {
  1129. return sts;
  1130. }
  1131. writeDataPhaseSD(dev, adds, len);
  1132. return SCSI_STATUS_GOOD;
  1133. }
  1134. /*
  1135. * WRITE6 / 10 Command processing.
  1136. */
  1137. static byte onWrite6(SCSI_DEVICE *dev, const byte *cdb)
  1138. {
  1139. unsigned adds = (((uint32_t)cdb[1] & 0x1F) << 16) | ((uint32_t)cdb[2] << 8) | cdb[3];
  1140. unsigned len = (cdb[4] == 0) ? 0x100 : cdb[4];
  1141. /*
  1142. LOGN("onWrite6");
  1143. LOG("-W ");
  1144. LOGHEX(adds);
  1145. LOG(":");
  1146. LOGHEXN(len);
  1147. */
  1148. if(dev->m_type == SCSI_DEVICE_OPTICAL)
  1149. {
  1150. dev->m_senseKey = SCSI_SENSE_HARDWARE_ERROR;
  1151. dev->m_additional_sense_code = SCSI_ASC_WRITE_PROTECTED; // Write Protect
  1152. return SCSI_STATUS_CHECK_CONDITION;
  1153. }
  1154. byte sts = checkBlockCommand(dev, adds, len);
  1155. if (sts) {
  1156. return sts;
  1157. }
  1158. readDataPhaseSD(dev, adds, len);
  1159. return SCSI_STATUS_GOOD;
  1160. }
  1161. static byte onWrite10(SCSI_DEVICE *dev, const byte *cdb)
  1162. {
  1163. unsigned adds = ((uint32_t)cdb[2] << 24) | ((uint32_t)cdb[3] << 16) | ((uint32_t)cdb[4] << 8) | cdb[5];
  1164. unsigned len = ((uint32_t)cdb[7] << 8) | cdb[8];
  1165. /*
  1166. LOGN("onWrite10");
  1167. LOG("-W ");
  1168. LOGHEX(adds);
  1169. LOG(":");
  1170. LOGHEXN(len);
  1171. */
  1172. if(dev->m_type == SCSI_DEVICE_OPTICAL)
  1173. {
  1174. dev->m_senseKey = SCSI_SENSE_HARDWARE_ERROR;
  1175. dev->m_additional_sense_code = SCSI_ASC_WRITE_PROTECTED; // Write Protect
  1176. return SCSI_STATUS_CHECK_CONDITION;
  1177. }
  1178. byte sts = checkBlockCommand(dev, adds, len);
  1179. if (sts) {
  1180. return sts;
  1181. }
  1182. readDataPhaseSD(dev, adds, len);
  1183. return SCSI_STATUS_GOOD;
  1184. }
  1185. /*
  1186. * VERIFY10 Command processing.
  1187. */
  1188. byte onVerify(SCSI_DEVICE *dev, const byte *cdb)
  1189. {
  1190. unsigned adds = ((uint32_t)cdb[2] << 24) | ((uint32_t)cdb[3] << 16) | ((uint32_t)cdb[4] << 8) | cdb[5];
  1191. unsigned len = ((uint32_t)cdb[7] << 8) | cdb[8];
  1192. byte sts = checkBlockCommand(dev, adds, len);
  1193. if (sts) {
  1194. return sts;
  1195. }
  1196. int bytchk = (cdb[1] >> 1) & 0x03;
  1197. if (bytchk != 0) {
  1198. if (bytchk == 3) {
  1199. // Data-Out buffer is single logical block for repeated verification.
  1200. len = dev->m_blocksize;
  1201. }
  1202. verifyDataPhaseSD(dev, adds, len);
  1203. }
  1204. return SCSI_STATUS_GOOD;
  1205. }
  1206. /*
  1207. * MODE SENSE command processing.
  1208. */
  1209. byte onModeSense(SCSI_DEVICE *dev, const byte *cdb)
  1210. {
  1211. const byte apple_magic[] = "APPLE COMPUTER, INC ";
  1212. int pageCode = cdb[2] & 0x3F;
  1213. int pageControl = cdb[2] >> 6;
  1214. byte dbd = cdb[1] & 0x8;
  1215. byte block_descriptor_length = 8;
  1216. // saving parameters is not allowed...yet!
  1217. if(pageControl == 3)
  1218. {
  1219. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1220. dev->m_additional_sense_code = SCSI_ASC_SAVING_PARAMETERS_NOT_SUPPORTED;
  1221. return SCSI_STATUS_CHECK_CONDITION;
  1222. }
  1223. // SCSI_MODE_SENSE6
  1224. int a = 4;
  1225. int length = cdb[4];
  1226. if(cdb[0] == SCSI_MODE_SENSE10) {
  1227. a = 8;
  1228. length = cdb[7];
  1229. length <<= 8;
  1230. length |= cdb[8];
  1231. if(length > 0x800) { length = 0x800; };
  1232. }
  1233. memset(m_buf, 0, length);
  1234. if(!dbd) {
  1235. byte c[8] = {
  1236. 0,//Density code
  1237. (byte)(dev->m_blockcount >> 16),
  1238. (byte)(dev->m_blockcount >> 8),
  1239. (byte)(dev->m_blockcount),
  1240. 0, //Reserve
  1241. (byte)(dev->m_blocksize >> 16),
  1242. (byte)(dev->m_blocksize >> 8),
  1243. (byte)(dev->m_blocksize),
  1244. };
  1245. memcpy(&m_buf[a], c, 8);
  1246. a += 8;
  1247. }
  1248. // HDD supports page codes 0x1 (Read/Write), 0x2, 0x3, 0x4
  1249. // CDROM supports page codes 0x1 (Read Only), 0x2, 0xD, 0xE, 0x30
  1250. if(dev->m_type == SCSI_DEVICE_HDD) {
  1251. switch(pageCode) {
  1252. case SCSI_SENSE_MODE_ALL:
  1253. case SCSI_SENSE_MODE_READ_WRITE_ERROR_RECOVERY:
  1254. m_buf[a + 0] = SCSI_SENSE_MODE_READ_WRITE_ERROR_RECOVERY;
  1255. m_buf[a + 1] = 0x0A;
  1256. a += 0x0C;
  1257. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1258. case SCSI_SENSE_MODE_DISCONNECT_RECONNECT:
  1259. m_buf[a + 0] = SCSI_SENSE_MODE_DISCONNECT_RECONNECT;
  1260. m_buf[a + 1] = 0x0A;
  1261. a += 0x0C;
  1262. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1263. case SCSI_SENSE_MODE_FORMAT_DEVICE: //Drive parameters
  1264. m_buf[a + 0] = SCSI_SENSE_MODE_FORMAT_DEVICE; //Page code
  1265. m_buf[a + 1] = 0x16; // Page length
  1266. if(pageControl != 1) {
  1267. m_buf[a + 11] = 0x3F;//Number of sectors / track
  1268. m_buf[a + 12] = (byte)(dev->m_blocksize >> 8);
  1269. m_buf[a + 13] = (byte)dev->m_blocksize;
  1270. m_buf[a + 15] = 0x1; // Interleave
  1271. }
  1272. a += 0x18;
  1273. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1274. case SCSI_SENSE_MODE_DISK_GEOMETRY: //Drive parameters
  1275. m_buf[a + 0] = SCSI_SENSE_MODE_DISK_GEOMETRY; //Page code
  1276. m_buf[a + 1] = 0x16; // Page length
  1277. if(pageControl != 1) {
  1278. unsigned cylinders = dev->m_blockcount / (16 * 63);
  1279. m_buf[a + 2] = (byte)(cylinders >> 16); // Cylinders
  1280. m_buf[a + 3] = (byte)(cylinders >> 8);
  1281. m_buf[a + 4] = (byte)cylinders;
  1282. m_buf[a + 5] = 16; //Number of heads
  1283. } else {
  1284. m_buf[a + 2] = 0xFF; // Cylinder length
  1285. m_buf[a + 3] = 0xFF;
  1286. m_buf[a + 4] = 0xFF;
  1287. m_buf[a + 5] = 16; //Number of heads
  1288. }
  1289. a += 0x18;
  1290. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1291. case SCSI_SENSE_MODE_FLEXABLE_GEOMETRY:
  1292. m_buf[a + 0] = SCSI_SENSE_MODE_FLEXABLE_GEOMETRY;
  1293. m_buf[a + 1] = 0x1E; // Page length
  1294. if(pageControl != 1) {
  1295. m_buf[a + 2] = 0x03;
  1296. m_buf[a + 3] = 0xE8; // Transfer rate 1 mbit/s
  1297. m_buf[a + 4] = 16; // Number of heads
  1298. m_buf[a + 5] = 63; // Sectors per track
  1299. m_buf[a + 6] = (byte)dev->m_blocksize >> 8;
  1300. m_buf[a + 7] = (byte)dev->m_blocksize & 0xff; // Data bytes per sector
  1301. }
  1302. a += 0x20;
  1303. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1304. case SCSI_SENSE_MODE_CACHING:
  1305. m_buf[a + 0] = SCSI_SENSE_MODE_CACHING;
  1306. m_buf[a + 1] = 0x0A; // Page length
  1307. if(pageControl != 1) {
  1308. m_buf[a + 2] = 0x01; // Disalbe Read Cache so no one asks for Cache Stats page.
  1309. }
  1310. a += 0x0C;
  1311. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1312. case SCSI_SENSE_MODE_VENDOR_APPLE:
  1313. {
  1314. if(pageControl != 1) {
  1315. m_buf[a + 0] = SCSI_SENSE_MODE_VENDOR_APPLE;
  1316. m_buf[a + 1] = sizeof(apple_magic); // Page length
  1317. memcpy(&m_buf[a + 2], apple_magic, sizeof(apple_magic));
  1318. a += sizeof(apple_magic) + 2;
  1319. }
  1320. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1321. }
  1322. break; // Don't want SCSI_SENSE_MODE_ALL falling through to error condition
  1323. default:
  1324. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1325. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1326. return SCSI_STATUS_CHECK_CONDITION;
  1327. break;
  1328. }
  1329. } else {
  1330. // OPTICAL
  1331. if(cdb[0] == SCSI_MODE_SENSE6) {
  1332. m_buf[2] = 1 << 7; // WP bit
  1333. } else {
  1334. m_buf[3] = 1 << 7; // WP bit
  1335. }
  1336. switch(pageCode) {
  1337. case SCSI_SENSE_MODE_ALL:
  1338. case SCSI_SENSE_MODE_READ_WRITE_ERROR_RECOVERY:
  1339. m_buf[a + 0] = SCSI_SENSE_MODE_READ_WRITE_ERROR_RECOVERY;
  1340. m_buf[a + 1] = 0x06;
  1341. m_buf[a + 3] = 0x01; // Retry Count
  1342. a += 0x08;
  1343. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1344. case SCSI_SENSE_MODE_DISCONNECT_RECONNECT:
  1345. m_buf[a + 0] = SCSI_SENSE_MODE_DISCONNECT_RECONNECT;
  1346. m_buf[a + 1] = 0x0A;
  1347. a += 0x0C;
  1348. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1349. case SCSI_SENSE_MODE_CDROM:
  1350. m_buf[a + 0] = SCSI_SENSE_MODE_CDROM;
  1351. m_buf[a + 1] = 0x06;
  1352. if(pageControl != 1)
  1353. {
  1354. // 2 seconds for inactive timer
  1355. m_buf[a + 3] = 0x05;
  1356. // MSF multiples are 60 and 75
  1357. m_buf[a + 5] = 60;
  1358. m_buf[a + 7] = 75;
  1359. }
  1360. a += 0x8;
  1361. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1362. case SCSI_SENSE_MODE_CDROM_AUDIO_CONTROL:
  1363. m_buf[a + 0] = SCSI_SENSE_MODE_CDROM_AUDIO_CONTROL;
  1364. m_buf[a + 1] = 0x0E;
  1365. a += 0x10;
  1366. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1367. case SCSI_SENSE_MODE_VENDOR_APPLE:
  1368. {
  1369. if(pageControl != 1) {
  1370. m_buf[a + 0] = SCSI_SENSE_MODE_VENDOR_APPLE;
  1371. m_buf[a + 1] = sizeof(apple_magic); // Page length
  1372. memcpy(&m_buf[a + 2], apple_magic, sizeof(apple_magic));
  1373. a += sizeof(apple_magic) + 2;
  1374. }
  1375. if(pageCode != SCSI_SENSE_MODE_ALL) break;
  1376. }
  1377. break; // Don't want SCSI_SENSE_MODE_ALL falling through to error condition
  1378. default:
  1379. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1380. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1381. return SCSI_STATUS_CHECK_CONDITION;
  1382. break;
  1383. }
  1384. }
  1385. if(cdb[0] == SCSI_MODE_SENSE10)
  1386. {
  1387. m_buf[1] = a - 2;
  1388. m_buf[7] = block_descriptor_length; // block descriptor length
  1389. }
  1390. else
  1391. {
  1392. m_buf[0] = a - 1;
  1393. m_buf[3] = block_descriptor_length; // block descriptor length
  1394. }
  1395. writeDataPhase(length < a ? length : a, m_buf);
  1396. return SCSI_STATUS_GOOD;
  1397. }
  1398. void setBlockLength(SCSI_DEVICE *dev, uint32_t length)
  1399. {
  1400. dev->m_blocksize = dev->m_rawblocksize = length;
  1401. dev->m_blockcount = dev->m_fileSize / dev->m_blocksize;
  1402. }
  1403. byte onModeSelect(SCSI_DEVICE *dev, const byte *cdb)
  1404. {
  1405. unsigned length = 0;
  1406. LOGN("onModeSelect");
  1407. // saving mode pages isn't supported yet
  1408. if(cdb[1] & 0x01)
  1409. {
  1410. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1411. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1412. return SCSI_STATUS_CHECK_CONDITION;
  1413. }
  1414. if(cdb[0] == SCSI_MODE_SELECT6)
  1415. {
  1416. length = cdb[4];
  1417. }
  1418. else /* SCSI_MODE_SELECT10 */
  1419. {
  1420. length = cdb[7] << 8;
  1421. length |= cdb[8];
  1422. if(length > 0x800) { length = 0x800; }
  1423. }
  1424. if(length == 0)
  1425. {
  1426. return SCSI_STATUS_GOOD;
  1427. }
  1428. memset(m_buf, 0, length);
  1429. readDataPhase(length, m_buf);
  1430. //Apple HD SC Setup sends:
  1431. //0 0 0 8 0 0 0 0 0 0 2 0 0 2 10 0 1 6 24 10 8 0 0 0
  1432. //I believe mode page 0 set to 10 00 is Disable Unit Attention
  1433. //Mode page 1 set to 24 10 08 00 00 00 is TB and PER set, read retry count 16, correction span 8
  1434. if(dev->m_type == SCSI_DEVICE_OPTICAL)
  1435. {
  1436. // check for a block descriptor
  1437. if(m_buf[3] == 8)
  1438. {
  1439. // Requested change of blocksize
  1440. // Only supporting 512 or 2048 for optical devices
  1441. uint32_t new_block_size = ((uint32_t)m_buf[8] << 16) | ((uint32_t)m_buf[10] << 8) | m_buf[9];
  1442. switch(new_block_size)
  1443. {
  1444. case 512: setBlockLength(dev, 512);
  1445. break;
  1446. case 2048: setBlockLength(dev, 2048);
  1447. break;
  1448. default: LOG("Err BlockSize:"); LOG(new_block_size); LOG(" ");
  1449. }
  1450. }
  1451. }
  1452. #if DEBUG > 0
  1453. for (unsigned i = 0; i < length; i++) {
  1454. LOGHEX(m_buf[i]);LOG(" ");
  1455. }
  1456. LOGN("");
  1457. #endif
  1458. return SCSI_STATUS_GOOD;
  1459. }
  1460. /*
  1461. * ReZero Unit - Move to Logical Block Zero in file.
  1462. */
  1463. byte onReZeroUnit(SCSI_DEVICE *dev, const byte *cdb) {
  1464. LOGN("-ReZeroUnit");
  1465. // Make sure we have an image with atleast a first byte.
  1466. // Actually seeking to the position wont do anything, so dont.
  1467. return checkBlockCommand(dev, 0, 0);
  1468. }
  1469. /*
  1470. * WriteBuffer - Used for testing buffer, no change to medium
  1471. */
  1472. byte onWriteBuffer(SCSI_DEVICE *dev, const byte *cdb)
  1473. {
  1474. byte mode = cdb[1] & 7;
  1475. uint32_t allocLength = ((uint32_t)cdb[6] << 16) | ((uint32_t)cdb[7] << 8) | cdb[8];
  1476. LOGN("-WriteBuffer");
  1477. LOGHEXN(mode);
  1478. LOGHEXN(allocLength);
  1479. if (mode == MODE_COMBINED_HEADER_DATA && (allocLength - 4) <= SCSI_BUF_SIZE)
  1480. {
  1481. byte tmp[allocLength];
  1482. readDataPhase(allocLength, tmp);
  1483. // Drop header
  1484. memcpy(m_scsi_buf, (&tmp[4]), allocLength - 4);
  1485. #if DEBUG > 0
  1486. for (unsigned i = 0; i < allocLength; i++) {
  1487. LOGHEX(tmp[i]);LOG(" ");
  1488. }
  1489. LOGN("");
  1490. #endif
  1491. return SCSI_STATUS_GOOD;
  1492. }
  1493. else if ( mode == MODE_DATA && allocLength <= SCSI_BUF_SIZE)
  1494. {
  1495. readDataPhase(allocLength, m_scsi_buf);
  1496. #if DEBUG > 0
  1497. for (unsigned i = 0; i < allocLength; i++) {
  1498. LOGHEX(m_scsi_buf[i]);LOG(" ");
  1499. }
  1500. LOGN("");
  1501. #endif
  1502. return SCSI_STATUS_GOOD;
  1503. }
  1504. else
  1505. {
  1506. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1507. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1508. return SCSI_STATUS_CHECK_CONDITION;
  1509. }
  1510. }
  1511. /*
  1512. * ReadBuffer - Used for testing buffer, no change to medium
  1513. */
  1514. byte onReadBuffer(SCSI_DEVICE *dev, const byte *cdb)
  1515. {
  1516. byte mode = cdb[1] & 7;
  1517. uint32_t allocLength = ((uint32_t)cdb[6] << 16) | ((uint32_t)cdb[7] << 8) | cdb[8];
  1518. LOGN("-ReadBuffer");
  1519. LOGHEXN(mode);
  1520. LOGHEXN(allocLength);
  1521. if (mode == MODE_COMBINED_HEADER_DATA)
  1522. {
  1523. memset(m_buf, 0, 4 + m_scsi_buf_size);
  1524. // four byte read buffer header
  1525. m_buf[0] = 0;
  1526. m_buf[1] = (SCSI_BUF_SIZE >> 16) & 0xff;
  1527. m_buf[2] = (SCSI_BUF_SIZE >> 8) & 0xff;
  1528. m_buf[3] = SCSI_BUF_SIZE & 0xff;
  1529. // actual data
  1530. memcpy((&m_buf[4]), m_scsi_buf, m_scsi_buf_size);
  1531. writeDataPhase(4 + m_scsi_buf_size, m_buf);
  1532. #if DEBUG > 0
  1533. for (unsigned i = 0; i < allocLength; i++) {
  1534. LOGHEX(m_scsi_buf[i]);LOG(" ");
  1535. }
  1536. LOGN("");
  1537. #endif
  1538. return SCSI_STATUS_GOOD;
  1539. }
  1540. else if (mode == MODE_DATA)
  1541. {
  1542. writeDataPhase(m_scsi_buf_size, m_scsi_buf);
  1543. #if DEBUG > 0
  1544. for (unsigned i = 0; i < allocLength; i++) {
  1545. LOGHEX(m_scsi_buf[i]);LOG(" ");
  1546. }
  1547. LOGN("");
  1548. #endif
  1549. return SCSI_STATUS_GOOD;
  1550. }
  1551. else
  1552. {
  1553. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1554. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1555. return SCSI_STATUS_CHECK_CONDITION;
  1556. }
  1557. }
  1558. /*
  1559. * On Send Diagnostic
  1560. */
  1561. byte onSendDiagnostic(SCSI_DEVICE *dev, const byte *cdb)
  1562. {
  1563. int self_test = cdb[1] & 0x4;
  1564. LOGN("-SendDiagnostic");
  1565. LOGHEXN(cdb[1]);
  1566. if(self_test)
  1567. {
  1568. // Don't actually do a test, we're good.
  1569. return SCSI_STATUS_GOOD;
  1570. }
  1571. else
  1572. {
  1573. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1574. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1575. return SCSI_STATUS_CHECK_CONDITION;
  1576. }
  1577. }
  1578. /*
  1579. * Read Defect Data
  1580. */
  1581. byte onReadDefectData(SCSI_DEVICE *dev, const byte *cdb)
  1582. {
  1583. byte response[4] = {
  1584. 0x0, // Reserved
  1585. cdb[2], // echo back Reserved, Plist, Glist, Defect list format
  1586. cdb[7], cdb[8] // echo back defect list length
  1587. };
  1588. writeDataPhase(4, response);
  1589. return SCSI_STATUS_GOOD;
  1590. }
  1591. static byte onReadTOC(SCSI_DEVICE *dev, const byte *cdb)
  1592. {
  1593. uint8_t msf = cdb[1] & 0x02;
  1594. uint8_t track = cdb[6];
  1595. unsigned len = ((uint32_t)cdb[7] << 8) | cdb[8];
  1596. memset(m_buf, 0, len);
  1597. // Doing just the error seemed to make MacOS unhappy
  1598. #if 0
  1599. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1600. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1601. return SCSI_STATUS_CHECK_CONDITION;
  1602. #endif
  1603. if(track > 1 || cdb[2] != 0)
  1604. {
  1605. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1606. dev->m_additional_sense_code = SCSI_ASC_INVALID_FIELD_IN_CDB;
  1607. return SCSI_STATUS_CHECK_CONDITION;
  1608. }
  1609. m_buf[1] = 18; // TOC length LSB
  1610. m_buf[2] = 1; // First Track
  1611. m_buf[3] = 1; // Last Track
  1612. // first track
  1613. m_buf[5] = 0x14; // data track
  1614. m_buf[6] = 1;
  1615. // leadout track
  1616. m_buf[13] = 0x14; // data track
  1617. m_buf[14] = 0xaa; // leadout track
  1618. if(msf)
  1619. {
  1620. LBAtoMSF(dev->m_blockcount, &m_buf[16]);
  1621. }
  1622. else
  1623. {
  1624. m_buf[16] = (byte)(dev->m_blockcount >> 24);
  1625. m_buf[17] = (byte)(dev->m_blockcount >> 16);
  1626. m_buf[18] = (byte)(dev->m_blockcount >> 8);
  1627. m_buf[20] = (byte)(dev->m_blockcount);
  1628. }
  1629. writeDataPhase(SCSI_TOC_LENGTH > len ? len : SCSI_TOC_LENGTH, m_buf);
  1630. return SCSI_STATUS_GOOD;
  1631. }
  1632. static byte onReadDiscInformation(SCSI_DEVICE *dev, const byte *cdb)
  1633. {
  1634. writeDataPhase((cdb[7] >> 8) | cdb[8], m_buf);
  1635. return SCSI_STATUS_GOOD;
  1636. }
  1637. static byte onReadDVDStructure(SCSI_DEVICE *dev, const byte *cdb)
  1638. {
  1639. dev->m_senseKey = SCSI_SENSE_ILLEGAL_REQUEST;
  1640. dev->m_additional_sense_code = SCSI_ASC_CANNOT_READ_MEDIUM_INCOMPATIBLE_FORMAT;
  1641. return SCSI_STATUS_CHECK_CONDITION;
  1642. }
  1643. // Thanks RaSCSI :D
  1644. // LBA→MSF Conversion
  1645. static inline void LBAtoMSF(const uint32_t lba, byte *msf)
  1646. {
  1647. uint32_t m, s, f;
  1648. // 75 and 75*60 get the remainder
  1649. m = lba / (75 * 60);
  1650. s = lba % (75 * 60);
  1651. f = s % 75;
  1652. s /= 75;
  1653. // The base point is M=0, S=2, F=0
  1654. s += 2;
  1655. if (s >= 60) {
  1656. s -= 60;
  1657. m++;
  1658. }
  1659. // Store
  1660. msf[0] = 0x00;
  1661. msf[1] = (byte)m;
  1662. msf[2] = (byte)s;
  1663. msf[3] = (byte)f;
  1664. }
  1665. static inline uint32_t MSFtoLBA(const byte *msf)
  1666. {
  1667. uint32_t lba;
  1668. // 1, 75, add up in multiples of 75*60
  1669. lba = msf[1];
  1670. lba *= 60;
  1671. lba += msf[2];
  1672. lba *= 75;
  1673. lba += msf[3];
  1674. // Since the base point is M=0, S=2, F=0, subtract 150
  1675. lba -= 150;
  1676. return lba;
  1677. }