Last modified by Max on 2025/03/02 15:18

From version 2.14
edited by Max
on 2025/02/25 12:56
Change comment: (Autosaved)
To version 2.22
edited by Max
on 2025/02/25 13:36
Change comment: (Autosaved)

Summary

Details

Page properties
Content
... ... @@ -382,46 +382,50 @@
382 382  Command code 013, the command reads the TOC record into the internal memory area and switches the pointer to it for data transfer via DR. The TOC must be open before this.
383 383  
384 384  The procedure is as follows:
385 -• Сбросить контроллер.
386 -• Выдать в CSR команду "Прочитать запись оглавления" и дождаться ее окончания.
387 -• Выдать в CSR команду "Прочитать из памяти контроллера"
388 -• Прочитать из DR 11 слов записи оглавления
389 -\\Запись оглавления имеет формат:
390 -\\См. Имя Значение
391 -0 fSize Размер файла в байтах, младшее слово
392 -2 старшее слово
393 -4 fDate Дата в формате MS-DOS
394 -6 fTime Время в формате MS-DOS
395 -10 fAttr Атрибуты 1 байт
396 -11 fName ИМЯ.ТИП файла, 8+1+3+1 = 13 байт
397 -\\Смещения указаны восьмеричные. Формула в строке fName означает, что там сначала должно быть имя, максимально из восьми символов, далее должна быть точка, далее тип, до трёх символов, и завершающий нулевой байт 0х00. Если тип не указан, точка тоже не нужна.
398 -\\Атрибуты файлов в байте fAttr (восьмеричные):
385 +• Reset the controller.
386 +• Issue the command "Read the table of contents entry" to the CSR and wait for it to finish.
387 +• Issue the command "Read from controller memory" to the CSR
388 +• Read 11 words of the table of contents entry from DR
389 +\\The table of contents entry has the format:
390 +
391 +(% style="width:686px" %)
392 +|=(% style="width: 136px;" %)Offset (octal)|=(% style="width: 305px;" %)Name|=(% style="width: 242px;" %)Value
393 +|(% style="width:136px" %)0|(% style="width:305px" %)fSize|(% style="width:242px" %)File size in bytes, low word
394 +|(% style="width:136px" %)2|(% style="width:305px" %)fSize|(% style="width:242px" %)File size in bytes, high word
395 +|(% style="width:136px" %)4|(% style="width:305px" %)fDate|(% style="width:242px" %)Date in MS-DOS format
396 +|(% style="width:136px" %)6|(% style="width:305px" %)fTime|(% style="width:242px" %)Time in MS-DOS format
397 +|(% style="width:136px" %)10|(% style="width:305px" %)fAttr|(% style="width:242px" %)Attributes 1 byte
398 +|(% style="width:136px" %)10|(% style="width:305px" %)fName|(% style="width:242px" %)NAME.FILE TYPE, 8+1+3+1 = 13 bytes
399 +
400 +
401 +The offsets are specified in octal. The formula in the fName line means that there must first be a name, maximum of eight characters, then a period, then a type, up to three characters, and a terminating zero byte 0x00. If the type is not specified, the period is also not needed.
402 +\\File attributes in fAttr byte (octal):
399 399  \\001 - Read Only
400 400  002 - Hidden
401 401  004 - System
402 402  020 - Directory
403 403  040 - Archive
404 -\\Пример программы.
408 +\\Example program
405 405  
406 406  {{code language="assembler"}}
407 407  ;......................................
408 -RdDir = 013; код команды "Читать запись оглавления"
412 +RdDir = 013; command code "Read table of contents entry"
409 409  RdBuf = 015
410 410  
411 411   MOV #AZ$CSR,R3
412 412  
413 413  15$: CLR @R3;
414 - TSTB @R3; Сбросим контроллер
418 + TSTB @R3; Reset the controller
415 415   BPL 15$;
416 416  
417 - MOV #RdDir,@R3; Попросим контроллер
418 -16$: TSTB @R3; прочитать в свою память
419 - BPL 16$; запись оглавления
421 + MOV #RdDir,@R3; Ask the controller
422 +16$: TSTB @R3; to read into its memory
423 + BPL 16$; table of contents entry
420 420  
421 421   MOV @RdBuf,(R3)+;
422 - MOV DIRREC,R2; И перенесем ее к себе в
423 - MOV #11.,R1; область памяти, указатель
424 -17$: MOV @R3,(R2)+; на которую лежит в ячейке
426 + MOV DIRREC,R2; And transfer it to itself in
427 + MOV #11.,R1; memory area, pointer
428 +17$: MOV @R3,(R2)+; to which lies in cell
425 425   SOB R1,17$; DIRREC.
426 426  
427 427  ;......................................
... ... @@ -428,16 +428,16 @@
428 428  {{/code}}
429 429  
430 430  
431 -== **014: Размонтировать диск** ==
435 +== 014: Unmount disk ==
432 432  
433 -Код команды 014, чтобы размонтировать диск, следует сбросить контроллер, переслать в DR контроллера номер привода AZ, который следует размонтировать, и послать в CSR контроллера код 014, после чего дождаться окончания операции (она длительная) и проверить на ошибку. Ошибка выдается, если привод не был смонтирован.
434 -[[**//пример утилиты AZUMNT//**>>url:https://forum.maxiol.com/index.php?showtopic=5605&st=0&p=59418&#entry59418]]
437 +Command code 014, to unmount the disk, you should reset the controller, send the AZ drive number to the controller DR, which should be unmounted, and send the 014 code to the controller CSR, then wait for the operation to complete (it takes a long time) and check for an error. An error is issued if the drive has not been mounted.
438 +[[AZUMNT utility example>>url:https://forum.maxiol.com/index.php?showtopic=5605&st=0&p=59418&#entry59418]]
435 435  
436 436  
437 -== **015: Начать передачу считанного блока** ==
441 +== 015: Start transferring the read block ==
438 438  
439 -Код команды - 015. Получив эту команду, контроллер настраивается на пословную выдачу содержимого того самого встроенного буфера на 256 слов, которые будут выданы последовательно через регистр DR. Никаких ожиданий не требуется, просто пересылаем 256 раз слово из DR в последовательные ячейки памяти, и все. Если нужно меньше, чем 256 слов (последний укороченный блок файла), то остаток можно просто бросить, не считывая, сброс контроллера в начале следующей операции сбросит и этот остаток.
440 -\\Пример программы:
443 +The command code is 015. Having received this command, the controller is configured to output word by word the contents of the same built-in buffer for 256 words, which will be output sequentially through the DR register. No waiting is required, we simply send a word from DR to sequential memory cells 256 times, and that's it. If less than 256 words are needed (the last shortened block of the file), then the remainder can simply be discarded without reading, resetting the controller at the beginning of the next operation will also reset this remainder.
444 +\\Example program:
441 441  
442 442  {{code language="assembler"}}
443 443  ;..................................