Changes for page API контроллеров AZ®
Last modified by Max on 2025/03/02 15:18
Summary
-
Page properties (1 modified, 0 added, 0 removed)
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,45 +437,46 @@ 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отпредыдущегофрагментаосталсяадресCSR450 +; 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 474 + 479 479 == **016: Принять блок данных в буфер** == 480 480 481 481 Код команды 016. Команда настраивает контроллер на прием блока данных и помещении его в буфер. Следующие 256 циклов записи в DR поместят данные, переданные через МПИ, в буфер.