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

From version 2.16
edited by Max
on 2025/02/25 13:06
Change comment: (Autosaved)
To version 2.29
edited by Max
on 2025/02/25 14:00
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -388,49 +388,44 @@
388 388  • Read 11 words of the table of contents entry from DR
389 389  \\The table of contents entry has the format:
390 390  
391 -|= |= |=
392 -| | |
393 -| | |
394 -| | |
395 -| | |
396 -| | |
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
397 397  
398 398  
399 -Смещение  Имя Значение
400 -0 fSize Размер файла в байтах, младшее слово
401 -2 старшее слово
402 -4 fDate Дата в формате MS-DOS
403 -6 fTime Время в формате MS-DOS
404 -10 fAttr Атрибуты 1 байт
405 -11 fName ИМЯ.ТИП файла, 8+1+3+1 = 13 байт
406 -\\Смещения указаны восьмеричные. Формула в строке fName означает, что там сначала должно быть имя, максимально из восьми символов, далее должна быть точка, далее тип, до трёх символов, и завершающий нулевой байт 0х00. Если тип не указан, точка тоже не нужна.
407 -\\Атрибуты файлов в байте fAttr (восьмеричные):
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):
408 408  \\001 - Read Only
409 409  002 - Hidden
410 410  004 - System
411 411  020 - Directory
412 412  040 - Archive
413 -\\Пример программы.
408 +\\Example program
414 414  
415 415  {{code language="assembler"}}
416 416  ;......................................
417 -RdDir = 013; код команды "Читать запись оглавления"
412 +RdDir = 013; command code "Read table of contents entry"
418 418  RdBuf = 015
419 419  
420 420   MOV #AZ$CSR,R3
421 421  
422 422  15$: CLR @R3;
423 - TSTB @R3; Сбросим контроллер
418 + TSTB @R3; Reset the controller
424 424   BPL 15$;
425 425  
426 - MOV #RdDir,@R3; Попросим контроллер
427 -16$: TSTB @R3; прочитать в свою память
428 - 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
429 429  
430 430   MOV @RdBuf,(R3)+;
431 - MOV DIRREC,R2; И перенесем ее к себе в
432 - MOV #11.,R1; область памяти, указатель
433 -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
434 434   SOB R1,17$; DIRREC.
435 435  
436 436  ;......................................
... ... @@ -437,96 +437,97 @@
437 437  {{/code}}
438 438  
439 439  
440 -== **014: Размонтировать диск** ==
435 +== 014: Unmount disk ==
441 441  
442 -Код команды 014, чтобы размонтировать диск, следует сбросить контроллер, переслать в DR контроллера номер привода AZ, который следует размонтировать, и послать в CSR контроллера код 014, после чего дождаться окончания операции (она длительная) и проверить на ошибку. Ошибка выдается, если привод не был смонтирован.
443 -[[**//пример утилиты 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]]
444 444  
445 445  
446 -== **015: Начать передачу считанного блока** ==
441 +== 015: Start transferring the read block ==
447 447  
448 -Код команды - 015. Получив эту команду, контроллер настраивается на пословную выдачу содержимого того самого встроенного буфера на 256 слов, которые будут выданы последовательно через регистр DR. Никаких ожиданий не требуется, просто пересылаем 256 раз слово из DR в последовательные ячейки памяти, и все. Если нужно меньше, чем 256 слов (последний укороченный блок файла), то остаток можно просто бросить, не считывая, сброс контроллера в начале следующей операции сбросит и этот остаток.
449 -\\Пример программы:
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:
450 450  
451 451  {{code language="assembler"}}
452 452  ;..................................
453 -RdBuf=015; символическое наименование команды
448 +RdBuf=015; symbolic name of the command
454 454  
455 -; В R3 от предыдущего фрагмента остался адрес CSR
450 +; In R3 from the previous fragment there is the address of the CSR
456 456  ; (177220)
457 457  
458 -; Считаем, что у нас в R2 находится адрес первого слова
459 -; памяти, куда следует разместить прочитанный блок.
460 -; Программа получения этого адреса не приводится.
453 +; We assume that in R2 we have the address of the first word
454 +; of memory, where the read block should be placed.
455 +; The program for obtaining this address is not given.
461 461  
462 - MOV #400,R1; Готовим счетчик слов
457 + MOV #400,R1; Prepare the word counter
463 463   ; 0400 oct = 256 dec
464 464  
465 - MOV #RdBuf,(R3)+; и пересылаем команду
466 -; RdBuf в CSR. Адрес в R3 укажет на DR (177222).
460 + MOV #RdBuf,(R3)+; and send the command
461 +; RdBuf to the CSR. The address in R3 will point to DR (177222).
467 467  
468 -3$: MOV @R3,(R2)+;перешлем очередное слово в
469 - ; память
470 - SOB R1,3$; и повторим это 256 (0400)
471 - ; раз
463 +3$: MOV @R3,(R2)+we will send the next word to
464 +; memory
465 + SOB R1,3$; and repeat this 256 (0400)
466 + ; times
472 472  ;..................................
473 473  {{/code}}
474 474  
475 -Всё, чтение закончено.
476 -\\Для записи наоборот, требуется сначала перенести весь блок данных из памяти ЦП в контроллер и потом выдать команду "Записать содержимое буфера на диск"
470 +That's it, reading is complete.
477 477  
472 +To write the opposite way, you first need to transfer the entire data block from the CPU memory to the controller and then issue the command "Write the contents of the buffer to disk"
478 478  
479 -== **016: Принять блок данных в буфер** ==
480 480  
481 -Код команды 016. Команда настраивает контроллер на прием блока данных и помещении его в буфер. Следующие 256 циклов записи в DR поместят данные, переданные через МПИ, в буфер.
482 -\\Пример программы.
475 +== 016: Receive data block into buffer ==
483 483  
477 +Command code 016. The command sets the controller to receive a block of data and place it in the buffer. The next 256 write cycles to DR will place the data transferred via the QBUS in the buffer.
478 +\\Example program:
479 +
484 484  {{code language="assembler"}}
485 485  ;..................................
486 486  
487 -WrBuf=016; Символическое наименование команды
483 +WrBuf=016; Symbolic name of the command
488 488  
489 -; Перед записью нужно выполнить те же действия, что и в
490 -; пп. 3.1.-3.3. Обычно, это одна и та же программа,
491 -; просто после пункта 3.3. выполняется проверка "Что
492 -; требуется: чтение или запись?" и разветвление на
493 -; программу чтения или записи.
485 +; Before writing, you need to perform the same actions as in
486 +; pp. 3.1.-3.3. Usually, this is the same program,
487 +; just after point 3.3. a check is performed "What
488 +; is required: reading or writing?" and a branch is made to the
489 +; reading or writing program.
494 494  
495 -; После фрагмента в п. 3.3. в R3 остался адрес CSR
496 -; (177220). Будем считать, что в R2 находится адрес в
497 -; памяти ЦП, где находится блок, подлежащий записи.
498 -; Программа получения этого адреса не показана.
491 +; After the fragment in point 3.3., the CSR address
492 +; (177220) remains in R3. We will assume that R2 contains the address in the CPU
493 +; memory where the block to be written is located.
494 +; The program for obtaining this address is not shown.
499 499  
500 - MOV #400,R1; Готовим счетчик
496 + MOV #400,R1; Preparing the counter
501 501  
502 - MOV #WrBuf,(R3)+; Перешлем команду в CSR и
503 - ; переключим адрес в R3 на
504 - ; DR
498 + MOV #WrBuf,(R3)+; Let's forward the command to the CSR and
499 +; switch the address in R3 to
500 +; DR
505 505  
506 -4$: MOV (R2)+,@R3; Перешлем очередное слово
507 - ; данных
508 - SOB R1,4$; и повторим это 256 раз
502 +4$: MOV (R2)+,@R3; Let's forward the next word
503 +; data
504 + SOB R1,4$; and repeat this 256 times
509 509  ;..................................
510 510  {{/code}}
511 511  
512 -== **017: Получить размер псевдодиска, большой** ==
508 +== 017: Get ramdisk size, large ==
513 513  
514 -Есть две команды получения размера псевдодиска, т.е. смонтированного на выбранный псевдопривод AZn файл-образа.
515 -\\Если используемая ОС (или программа, работающая с дисками без ОС) умеет работать с большими (больше 32М) дисками, следует пользоваться командой с кодом 017. Последовательность действий: сбросить контроллер (п. 3.1), выбрать накопитель (п. 3.2) и переслать в CSR код 017, а затем, без каких-либо ожиданий, считать из DR сначала младшее, и следом за ним старшее слово размера выбранного накопителя (файл-образа).
516 -\\Если используемая ОС не умеет работать с дисками бОльшими, чем 32М (RT-11), следует пользоваться командой 007 - получить размер псевдодиска с ограничением до 32М. Действия похожие: сбрасываем контроллер, выбираем диск, посылаем в CSR код [[007>>doc:||anchor="H007:41F43E43B44344743844244C44043043743C43544043F44143543243443E43443844143A430"]] и считываем из DR одно слово размера псевдодиска. Если размер файл-образа, смонтированного на выбранный псевдопривод, больше 65534 блоков, вместо этого "большого" размера, контроллер возвращает число 65534. Напоминаем, что число 65535 кое-где используется в специальных целях и не может быть размером диска.
517 -\\Также напоминаем, что если на этот накопитель не смонтирован файл-образ, последовательность действий не пройдет (команда 001 выбор устройства) и исполнение программы до этого места просто не дойдет. Поэтому ошибок у этих команд не предусмотрено.
518 -\\Пример программы с большими дисками
510 +There are two commands to get the size of a pseudo-disk, i.e. the AZn file-image mounted on the selected pseudo-drive.
511 +\\If the OS being used (or a program working with disks without an OS) can work with large (more than 32M) disks, you should use the command with the code 017. The sequence of actions: reset the controller (p. 3.1), select the drive (p. 3.2) and send the code 017 to the CSR, and then, without any waiting, read from DR first the lower word, and then the higher word of the size of the selected drive (image file).
512 +\\If the OS you are using cannot work with disks larger than 32M (RT-11), you should use the 007 command - get the pseudo-disk size with a limit of up to 32M. The steps are similar: reset the controller, select the disk, send the 007 code to the CSR and read one word of the pseudo-disk size from DR. If the size of the image file mounted on the selected pseudo-drive is larger than 65534 blocks, the controller returns the number 65534 instead of this "large" size. We remind you that the number 65535 is used in some places for special purposes and cannot be the disk size.
513 +\\We also remind you that if the image file is not mounted on this drive, the sequence of actions will not work (command 001 select device) and the program execution will simply not reach this point. Therefore, these commands do not provide for errors.
514 +\\Example of a program with large disks
519 519  
520 520  {{code language="assembler"}}
521 521  ;......................................
522 522  
523 -GetBig=017; Получить "большой" размер диска
519 +GetBig=017; Get the "big" disk size
524 524  
525 -; От фрагмента 3.2 (выбор диска) у нас в R3 остался
526 -; адрес DR (177222)
521 +; From fragment 3.2 (disk selection) we have in R3
522 +; DR address (177222)
527 527  
528 - MOV #GetBig,-(R3); пошлем команду
529 - TST (R3)+; вернем адрес в R3 назад, на DR
524 + MOV #GetBig,-(R3); send the command
525 + TST (R3)+; return the address in R3 back to DR
530 530   MOV @R3,BigSiz
531 531   MOV @R3,BigSiz+2
532 532  ;......................................