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
-
... ... @@ -529,26 +529,27 @@ 529 529 {{/code}} 530 530 531 531 532 -== 020: Getextendeddiagnosticcode==532 +== **020: Получить расширенный код диагностики** == 533 533 534 - Commandcode020,afterresettingthecontroller,youshouldissuethiscommand in theCSRandthenreadtwowordsofextendeddiagnosticsfromDR.Thecommand is instant,nowaitingis required.534 +Код команды 020, после сброса контроллера следует выдать эту команду в CSR и затем прочитать два слова расширенной диагностики из DR. Команда мгновенная, ожидание не требуется. 535 535 536 536 537 -== 027: GetfirmwareversionAZ STM32 ==537 +== **027: Получить версию firmware AZ STM32** == 538 538 539 -Command code 027, returns 2 words 540 -\\first word - 06404 = high byte 13. this is the firmware version, low byte 4. this is the hardware version - i.e. AZБК in this case second word - 037 = this is the maximum mountable disk - 31. 539 +Код команды 027, возвращает 2 слова 540 +\\первое слово - 06404 = старший байт 13. это версия прошивки, младший байт 4. это версия железа - те AZБК в данном случае 541 +второе слово - 037 = это максимальный монтируемый диск - 31. 541 541 542 542 543 543 {{code language="assembler"}} 544 544 ;------------------------------------------------------------- 545 -; gettingSTM32firmware version-resultinR1 R1=0error546 +; получение версии прошивки STM32 - результат в R1 R1=0 ошибка 546 546 GTSTMV: MOV #AZ$CSR,R1 547 -1$: CLR (R1) ; Send"Reset"command548 - TSTB (R1) ; Checkcontrollerreadinessконтроллера549 - BPL 1$ ; Ifnot ready,resetagain548 +1$: CLR (R1) ; Пошлем команду "Сброс" 549 + TSTB (R1) ; Проверим готовность контроллера 550 + BPL 1$ ; Если не готов, сбрасываем еще 550 550 mov #27,(R1) 551 - TST (R1)+ ; Checkforerror552 + TST (R1)+ ; Проверяем на ошибку 552 552 BMI 2$ 553 553 mov (R1),R1 554 554 return ... ... @@ -558,45 +558,45 @@ 558 558 {{/code}} 559 559 560 560 561 -== 030: Nooperation==562 +== **030: Нет операции** == 562 562 563 - Themainpurposeofthiscommandistosettheinterrupt enable bit from the controller.Thecommandtransferstheinterrupt enable bit,whichisinthesamewordwith it,butisnotpartofit(remember,thecommandislocatedin bitsD0 - D5,andtheinterruptenablebitisD6),tothecorrespondingtriggerofthecontrolleranddoesnotaffecttheprocesses in the controller in any other way.Controlofthistriggerworkseveninthe"Thinking,pleasedonot interfere"state,andthisisthemainfeature of the"nooperation"command.564 -\\ Thecommandhasthe code0030.Sendingthecode0130totheCSRwill enable interrupts from the controller,sendingthecode0030willdisable them.Anexampleisnotgivendue to its triviality.564 +Основное назначение этой команды - устанавливать бит разрешения прерываний от контроллера. Команда передает бит разрешения прерывания, который находится с ней в одном слове, но не входит в ее состав (напоминаем, команда располагается в битах D0 - D5, а бит разрешения прерываний - D6), в соответствующий триггер контроллера и больше никак не влияет на процессы в контроллере. Управление этим триггером работает даже в состоянии "Думаю, прошу не мешать", и это главная особенность команды "нет операции". 565 +\\Команда имеет код 0030. Посылка в CSR кода 0130 разрешит прерывания от контроллера, посылка кода 0030 запретит их. Пример не приводится вследствие тривиальности его. 565 565 566 566 567 -= Commandblockforworkingwithnon-volatilememory=568 += **Блок команд работы с энергонезависимой памятью** = 568 568 569 - TheinterfaceprovidesanyAZcontrollerwithaccess to255wordsofnon-volatile memory,allcommandssetthereadybitupon completion.Thisallowsyoutosaveusersettingsin non-volatile memory,forexample,thisisusedinAZBK??-therearesavedsettingsformorecomfortableoperation of the controller.570 +Интерфейс предоставляет любому AZ-контроллеру доступ к 255 словам энергонезависимой памяти, все команды устанавливают бит готовности по завершению. Это позволяет сохранять пользовательские настройки в энергонезависимой памяти, к примеру это используется в AZБК - там сохраняются настройки для более комфортной работы контроллера. 570 570 571 - Allcommandsinthisblockuseanon-volatilememorybufferfor their operation.572 +Все команды этого блока используют буфер энергонезависимой памяти для своей работы. 572 572 573 -== 021: Readnon-volatilememoryblockintobuffer==574 +== **021: Cчитать блок энергонезависимой памяти в буфер** == 574 574 575 575 (% class="wikigeneratedid" %) 576 - Commandcode021,thiscommandcausesablockofnon-volatilememorytoberead into the non-volatile memory buffer.577 +Код команды 021, данная команда вызывает чтение блока энергонезависимой памяти в буфер энергонезависимой памяти. 577 577 578 578 579 -== 022: Transferthereadblockofnon-volatilememoryfromthebuffer to the bus==580 +== **022: Отдать на шину считанный блок энергонезависимой памяти из буфера** == 580 580 581 581 (% class="wikigeneratedid" %) 582 - Commandcode022,thiscommandensuresthatthenon-volatilememorybufferistransferred to theDRregisterfor reading.583 +Код команды 022, данная команда обеспечивает передачу буфера энергонезависимой памяти в регистр DR для считывания. 583 583 584 584 (% class="wikigeneratedid" %) 585 - Exampleprogram586 +Пример программы 586 586 587 587 {{code language="assembler"}} 588 -AZ$CSR = 177220; commandandstatusregister(CSR)589 -AZ$DR = 177222; dataregister(DR)589 +AZ$CSR = 177220; регистр команд и состояния (CSR) 590 +AZ$DR = 177222; регистр данных (DR) 590 590 591 591 592 -; trap 50 - resetAZ593 +; trap 50 - cброс AZ 593 593 ; результат в R1 =0 ok 594 594 AZreset: MOV #AZ$CSR,R1 595 -1$: CLR (R1); Sendthe"Reset"command596 - TSTB (R1); Checkthecontroller readiness597 - BPL 1$; Ifnotready,resetagain598 -; onceandcheckagain599 - TST (R1); Checkforan error,596 +1$: CLR (R1); Пошлем команду "Сброс" 597 + TSTB (R1); Проверим готовность контроллера 598 + BPL 1$; Если не готов, сбрасываем еще 599 + ; раз и проверяем снова 600 + TST (R1); Проверим на ошибку, 600 600 BMI 0ERR$ 601 601 CLR R1 602 602 return ... ... @@ -605,30 +605,30 @@ 605 605 return 606 606 607 607 608 -; trap 54 - readingnon-volatilememoryofblock1 EEPROMtothebufferfromthe addressADREEPROMMEM609 -; resultR3 -address,ifR3=0error610 -; readstatusinR1 0 - ok611 -; 1 - sizedoesnotmatch saved612 -; 2 - versionerror613 -; 3 - checksum error609 +; trap 54 - чтение энергонезависимой памяти блока 1 EEPROM в буфер с адреса ADREEPROMMEM 610 +; результат R3 - адрес, если R3=0 ошибка 611 +; статус чтения в R1 0 - ok 612 +; 1 - размер не соответствует сохраненному 613 +; 2 - oшибка версии 614 +; 3 - oшибка контрольной суммы 614 614 ReadEEPROM: push R2 615 - call AZreset; reset616 + call AZreset; сбросим 616 616 tst R1 617 617 bne 0ERR$ 618 618 ; теперь читаем 619 619 MOV #AZ$CSR,R1 620 - mov #21,(R1); readblock1ofnon-volatilememoryinto buffer621 -0$: TSTB (R1); checkexecutionresult622 - BPL 0$; wait623 - mov #22,(R1); sendreadblockofnon-volatilememoryfrombuffertobus624 -1$: TSTB (R1); checkexecutionresult625 - BPL 1$; wait626 - TST (R1)+; increment621 + mov #21,(R1); считать блок 1 энергонезависимой памяти в буфер 622 +0$: TSTB (R1); проверяем результат выполнения 623 + BPL 0$; ждем 624 + mov #22,(R1); отдать на шину считанный блок энергонезависимой памяти из буфера 625 +1$: TSTB (R1); проверяем результат выполнения 626 + BPL 1$; ждем 627 + TST (R1)+; инкрементируем 627 627 mov #ADREEPROMMEM,R3 628 - mov #256.,R2; read256.words;firstwordisreadingresult629 -2$: mov (R1),(R3)+; readblockofwordsinto memory629 + mov #256.,R2; читаем 256. слов; первое слово - результат чтения 630 +2$: mov (R1),(R3)+; читаем блок слов в память 630 630 sob R2,2$ 631 - mov #ADREEPROMMEM,R3; successful632 + mov #ADREEPROMMEM,R3; успешно 632 632 mov (R3),R1 633 633 br 0END$ 634 634 0ERR$: CLR R3 ... ... @@ -636,39 +636,41 @@ 636 636 return 637 637 {{/code}} 638 638 639 -obviously, after reading the memory, it is necessary to check the result code in the first word - see the decoding of error codes 640 -\\Examples of returned data for commands 641 -\\sequentially issuing the command 021 and then 022 will allow reading 256 words from non-volatile memory 642 -Attention! The first word will be the reading success status 640 +очевидно, после считывания памяти необходимо проверить код результата в первом слове - см расшифровку кодов ошибок 641 +\\Примеры возвращаемых данных по командам 642 +\\последовательная подача команды 021 и затем 022 позволит считать 256. слов 643 +из энергонезависимой памяти 644 +**Внимание! **первое слово это будет статус успешности чтения 645 + 643 643 644 644 * 0 - ok 645 -* 1 - sizedoesnotmatch saved646 -* 2 - versionerror647 -* 3 - checksum error648 +* 1 - размер не соответствует сохраненному 649 +* 2 - oшибка версии 650 +* 3 - oшибка контрольной суммы 648 648 649 -== 023: Receivedatafromthebusintothebufferforsubsequentwritinginto the buffer==652 +== **023: Принять с шины в буфер данные для последующей записи в буфер** == 650 650 651 - Commandcode023,thiscommandallowsyoutofillthe non-volatile memory buffer654 +Код команды 023, данная команда позволяет наполнить буфер энергонезависимой памяти 652 652 653 -== 024: Writefrombuffertonon-volatilememoryblock==656 +== **024: Записать из буфера в блок энергонезависимой памяти** == 654 654 655 - Commandcode024,thiscommandcausesanon-volatilememoryblocktobewrittenfrom the non-volatile memory buffer.658 +Код команды 024, данная команда вызывает запись блока энергонезависимой памяти из буфера энергонезависимой памяти. 656 656 657 - Exampleprogram660 +Пример программы 658 658 659 659 {{code language="assembler"}} 660 -AZ$CSR = 177220; CommandandStatusRegister(CSR)661 -AZ$DR = 177222; DataRegister(DR)663 +AZ$CSR = 177220; регистр команд и состояния (CSR) 664 +AZ$DR = 177222; регистр данных (DR) 662 662 663 663 664 -; trap 50 - resetAZ667 +; trap 50 - cброс AZ 665 665 ; результат в R1 =0 ok 666 666 AZreset: MOV #AZ$CSR,R1 667 -1$: CLR (R1); Sendthe"Reset"command668 - TSTB (R1); Checkthecontroller readiness669 - BPL 1$; Ifnotready,resetagain670 -; onceandcheckagain671 - TST (R1); Checkforan error,670 +1$: CLR (R1); Пошлем команду "Сброс" 671 + TSTB (R1); Проверим готовность контроллера 672 + BPL 1$; Если не готов, сбрасываем еще 673 + ; раз и проверяем снова 674 + TST (R1); Проверим на ошибку, 672 672 BMI 0ERR$ 673 673 CLR R1 674 674 return ... ... @@ -676,27 +676,27 @@ 676 676 COM R1 677 677 return 678 678 679 -; trap 55 - writenon-volatilememoryfromthebufferataddressADREEPROMMEM в блок 1 EEPROM682 +; trap 55 - запись энергонезависимой памяти из буфера с адреса ADREEPROMMEM в блок 1 EEPROM 680 680 WriteEEPROM: push R1 681 681 push R2 682 682 push R3 683 - call AZreset; reset686 + call AZreset; сбросим 684 684 tst R1 685 685 bne 0ERR$ 686 686 687 687 MOV #AZ$CSR,R1 688 - mov #23,(R1); commandthatwewillwritedatatothe buffer689 -0$: TSTB (R1); checktheresult of executio690 - BPL 0$; wait691 - TST (R1)+; increment691 + mov #23,(R1); командуем что будем писать данные в буфер 692 +0$: TSTB (R1); проверяем результат выполнения 693 + BPL 0$; ждем 694 + TST (R1)+; инкрементируем 692 692 mov #ADREEPROMMEM+2,R3 693 - mov #255.,R2; write255.words;skipthefirstword-theresult of reading694 -1$: mov (R3)+,(R1); sendtothe controller696 + mov #255.,R2; пишем 255. слов; первое слово пропускаем - результат чтения 697 +1$: mov (R3)+,(R1); отдаем в контроллер 695 695 sob R2,1$ 696 - tst -(R1); decrement697 - mov #24,(R1); writefromthebuffertoblock1ofnon-volatile memory698 -2$: TSTB (R1); checktheresult of execution699 - BPL 2$; we are waiting699 + tst -(R1); декрементируем 700 + mov #24,(R1); записать из буфера в блок 1 энергонезависимой памяти 701 +2$: TSTB (R1); проверяем результат выполнения 702 + BPL 2$; ждем 700 700 br 0END$ 701 701 0ERR$: CLR R3 702 702 0END$: pop R3 ... ... @@ -705,21 +705,23 @@ 705 705 return 706 706 {{/code}} 707 707 708 -** Pleasenote**thatwhen recording,thebufferimmediatelycomeswith the data,i.e.thereisnofirstword with the statu711 +**Обращаю внимание**, при записи, буфер идет сразу с данными, те нет первого слова со статусом. 709 709 710 710 711 711 712 -= BlockofcommandsforworkingwithRTCandNTP =715 += Блок команд для работы с RTC и NTP = 713 713 714 - TheAZ®controllerhas2sourcesofdate-time,thefirstis theRTCbuiltintotheSTM32,thesecondistheclockin theTCP/IPstack.TheRTCclockworksautonomouslywitha2032battery installed.TheclockintheTCP/IPstackissetbasedondata from theNTPserver.717 +В контроллере AZ® есть 2 источника получения даты-времени, первый это RTC встроенный в STM32, второй это часы в стеке TCP/IP. Часы RTC работают автономно при наличии установленной батарейки 2032. Часы в стеке TCP/IP устанавливаются на основании данных с NTP-сервера. 715 715 716 716 717 -== Bufferformattimestamp (readable) ==720 +== Формат буфера timestamp (доступен по чтению) == 718 718 719 - The controllerAPIimmediatelypreparestimeinseveralformats,sothatitcanbeconvenientlyusedon thePDP-11side722 +API контроллера сразу готовит время в нескольких форматах, дабы его было удобно применить на стороне PDP-11 720 720 721 721 {{info}} 722 -datetime buffer format octal offset - those words datetime buffer format 725 +формат буфера даты-времени 726 +offset в восьмеричной системе - те слова 727 +формат буфера даты-времени 723 723 \\[0]=rtc_rt11date(); 724 724 [2]=rt11 time 50Hz big word; 725 725 [4]=rt11 time 50Hz little word; ... ... @@ -737,72 +737,72 @@ 737 737 {{/info}} 738 738 739 739 740 -== SimpleIN buffer format(whenwriting) ==745 +== Формат буфера SimpleIN (при записи) == 741 741 742 - theformatis simplified as much as possible,forworkwithPDP-11747 +формат максимально упрощен, для работы со стороны PDP-11 743 743 744 744 {{info}} 745 -offset inoctal-thosewords750 +offset в восьмеричной системе - те слова 746 746 747 -[0]=year, thelowertwodigitsare22andnot2022(!)748 -[2]=month; month749 -[4]=day; day750 -[6]=wday; dayof the week=0notset, 1Monday2 -Tuesdayetc.751 -[10]=hour; hour752 -[12]=min; minute753 -[14]=sec; second752 +[0]=year год, младшие две цифры - те 22 а не 2022(!) 753 +[2]=month; месяц 754 +[4]=day; день 755 +[6]=wday; день недели =0 не установлен, 1- понедельник 2 - вторник итд 756 +[10]=hour; час 757 +[12]=min; минута 758 +[14]=sec; секунда 754 754 {{/info}} 755 755 756 756 757 -== 031: GettimefromRTCtotimestampbuffer==762 +== **031: Получить время из RTC в буфер timestamp** == 758 758 759 - Commandcode031,thiscommandusesRTCclockasasourceof fillingthe timestampbuffer764 +Код команды 031, данная команда использует RTC часы как источник заполнения буфера timestamp 760 760 761 - Exampleprogram:766 +Пример программы: 762 762 763 763 {{code language="assembler"}} 764 -; trap 61 - readingclockdatafromautonomousRTCclock765 -; R3 - bufferaddresswheretoread766 -; resultinR3addressifsuccessful. R3=0iferror769 +; trap 61 - чтение данных часов из автономных часов RTC 770 +; R3 - адрес буфера куда надо считать 771 +; результат в R3 адрес, если успешно. R3=0 если ошибка 767 767 GetDateFromRTC: push R0 768 768 push R1 769 769 push R2 770 - call AZreset; reset775 + call AZreset; сбросим 771 771 tst R1 772 772 bne G60ERR 773 773 MOV #AZ$CSR,R1 774 774 mov #31,(R1) 775 - br G60; let'sgotherebecausefurthercode is the same780 + br G60; идем туда тк дальше код одинаковый 776 776 {{/code}} 777 777 778 -== 032: Gettimefromtimestampbuffer==783 +== **032: Получить время из буфера timestamp** == 779 779 780 - Commandcode032,thiscommandsendsthecontentsofthe timestampbuffer to the bus785 +Код команды 032, данная команда отдает на шину содержимое буфера timestamp 781 781 782 782 {{code language="assembler"}} 783 -; workingwithclock784 -; trap 60 - readingclockdatafromTCP/IPstack785 -; R3 - bufferaddresswheretoread786 -; resultinR3addressifsuccessful. R3=0iferror788 +; работа с часами 789 +; trap 60 - чтение данных часов из TCP/IP стека 790 +; R3 - адрес буфера куда надо считать 791 +; результат в R3 адрес, если успешно. R3=0 если ошибка 787 787 GetDateFromLAN: push R0 788 788 push R1 789 789 push R2 790 - call AZreset; reset795 + call AZreset; сбросим 791 791 tst R1 792 792 bne G60ERR 793 793 MOV #AZ$CSR,R1 794 794 mov #42,(R1) 795 -G60: TSTB (R1); checkexecutionresult796 - BPL G60; wait800 +G60: TSTB (R1); проверяем результат выполнения 801 + BPL G60; ждем 797 797 mov #32,(R1) 798 -1$: TSTB (R1); checkexecutionresult803 +1$: TSTB (R1); проверяем результат выполнения 799 799 BPL 1$; ждем 800 - TST (R1)+; increment801 - mov R3,R0; rememberR3address802 - mov #10.,R2; read10words803 -2$: mov (R1),(R3)+; readblockofwordsinto memory805 + TST (R1)+; инкрементируем 806 + mov R3,R0; запомним R3 - адрес 807 + mov #10.,R2; читаем 10 слов 808 +2$: mov (R1),(R3)+; читаем блок слов в память 804 804 sob R2,2$ 805 - mov R0,R3; successful,returnaddresstoR3810 + mov R0,R3; успешно, вернем адрес в R3 806 806 br 0END$ 807 807 G60ERR: CLR R3 808 808 0END$: pop R2 ... ... @@ -811,11 +811,11 @@ 811 811 return 812 812 {{/code}} 813 813 814 - Itisworthcheckingthe correctness of the received time:819 +Стоит проверить корректность полученного времени: 815 815 816 816 {{code language="assembler"}} 817 -; trap 63 - checktimecorrectness818 -; R3 - bufferaddress,resultinR3,ifbufferaddressthenOK, =0error822 +; trap 63 - проверка корректности времени 823 +; R3 - адрес буфера, результат в R3, если адрес буфера то OK, =0 ошибка 819 819 CheckDateTime: Cmp 6(r3),#2021. 820 820 Blos 1err 821 821 Cmp 6(r3),#2100. ... ... @@ -825,119 +825,119 @@ 825 825 return 826 826 {{/code}} 827 827 828 -== 033: Writetime-datetoSimpleINbuffer==833 +== **033: Запись времени-даты в буфер SimpleIN** == 829 829 830 - Commandcode033,thiscommandreceivesdatafromthebusinto theSimpleINbuffer835 +Код команды 033, данная команда принимает с шины данные в буфер SimpleIN 831 831 832 - Theoperationofthiscommandissimilar tothe operationofcommands023 and016.837 +Работа данной команды аналогична работе команд [[023>>doc:||anchor="H023:41F44043843D44F44244C44144843843D44B43243144344443544043443043D43D44B43543443B44F43F43E44143B43543444344E44943543943743043F438441438432431443444435440"]] и [[016>>doc:||anchor="H016:A041F44043843D44F44244C43143B43E43A43443043D43D44B445432431443444435440"]]. 833 833 834 -== 034: SetRTCbasedonbufferdata==839 +== **034: Установка RTC на основании данных из буфера** == 835 835 836 - Commandcode034,thiscommandsetstheRTCbasedonthedatain theSimpleINbuffer841 +Код команды 034, данная команда устанавливает RTC на основании данных в буфере SimpleIN 837 837 838 - Thiscommandexecutesquickly,buttoavoidproblems,awaitloopis recommended.843 +Данная команда выполняется быстро, но для исключения проблем цикл ожидания выполнения рекомендуется. 839 839 840 -== 035: StimulatetimerequestfromNTPserver,setbasedonresponse==845 +== **035: Стимуляция запроса времени с NTP сервера, установка на основании ответа** == 841 841 842 - Commandcode035,thiscommandsendsarequestto theNTPserver(setintheAZ.INIfileorreceivedfromDHCP)andsetstheclockintheTCP/IPstack.847 +Код команды 035, данная команда отправляет запрос на NTP cервер (установленный в AZ.INI файле или полученный от DHCP) и устанавливает часы в стеке TCP/IP. 843 843 844 - Exampleprogram:sendingarequesttosetthetime from anNTPserver849 +Пример программы: отсылка запроса на установку времени с NTP сервера 845 845 846 846 {{code language="assembler"}} 847 -; trap 62 - sendingarequesttosetthetime from theNTPserver852 +; trap 62 - отсылка запроса на установку времени с NTP сервера 848 848 GetDateNTPtoNET:push R1 849 - call AZreset; reset854 + call AZreset; сбросим 850 850 tst R1 851 851 bne 0ERR$ 852 852 MOV #AZ$CSR,R1 853 853 mov #35,(R1) 854 -0$: TSTB (R1); checktheresult of execution855 - BPL 0$; wait859 +0$: TSTB (R1); проверяем результат выполнения 860 + BPL 0$; ждем 856 856 0ERR$: pop R1 857 857 return 858 858 {{/code}} 859 859 860 - Thecommandexecutiontakes1-2secondsonaverage.ThiscommandrequirestheTCP/IPstack to work,sowaitingcyclesareneededwhenthe stack is enabled.865 +Выполнение команды занимает 1-2 секунды в среднем. Данная команда требует работы стека TCP/IP, соответственно нужны циклы ожидания при включенном стеке. 861 861 862 - Anexampleofapollingcycletogettime from the network867 +Пример цикла опроса с целью получить время с сети 863 863 864 864 {{code language="assembler"}} 865 -; date-time870 +; дата-время 866 866 mov #S_DateTime_0,R3; "Lan Date:" 867 867 trap 10 868 - mov #20,R4; numberofwait cycles869 -$datry: trap 62; sentarequestto theNTPserver870 - mov #110,@#AZ$CSR; enablethe network871 - trap 47; waiting872 - trap 47; waiting873 + mov #20,R4; количество циклов ожидания 874 +$datry: trap 62; отослали запрос к NTP серверу 875 + mov #110,@#AZ$CSR; включим сеть 876 + trap 47; ожидание 877 + trap 47; ожидание 873 873 mov #ADRTMPSTR,R3 874 - trap 60; readthedate-timeinto the buffer875 - trap 63; checkedthe date-time879 + trap 60; считали в буфер дату-время 880 + trap 63; проверили дату-время 876 876 tst R3 877 877 bne $ok 878 878 $sob: sob R4,$datry 879 - mov #S_DateTime_2,R3; printerror884 + mov #S_DateTime_2,R3; печать ошибки 880 880 trap 7 881 881 br $go 882 882 883 883 $ok: mov #ADRTMPSTR,R3 884 - trap 24; printdate885 - trap 25; time886 -$go: mov #110,@#AZ$CSR; let's turn on the network889 + trap 24; печать даты 890 + trap 25; времени 891 +$go: mov #110,@#AZ$CSR; включим сеть 887 887 {{/code}} 888 888 889 - Hereweexplicitlysendarequestto theNTPserver,thenturnonthenetworkandwait for the result,periodicallypollingandcheckingthecorrectness of the result.894 +Тут мы явно отсылаем запрос к NTP серверу, затем включаем работу сети и ждем результата, периодически опрашивая и проверяя корректность результата. 890 890 891 -== 036: SettingRTCbasedonTCP/IPstackclock==896 +== **036: Установка RTC на основании часов TCP/IP стека** == 892 892 893 - Commandcode036,thiscommandsetstheRTCbasedontheclock in theTCP/IPstack.Youmustfirstsetthe clock inTCP/IP -command036.898 +Код команды 036, данная команда устанавливает RTC на основании часов в TCP/IP стека. Предварительно надо установить часы в TCP/IP - команда 036. 894 894 895 - Exampleprogram:900 +Пример программы: 896 896 897 897 {{code language="assembler"}} 898 -; trap 64 - setRTCtimebasedonstack time899 -; R1 - resultR1=0 - OK900 -SetDateNETtoRTC:call AZreset; reset903 +; trap 64 - установка времени RTC на основании времени стека 904 +; R1 - результат R1=0 - OK 905 +SetDateNETtoRTC:call AZreset; сбросим 901 901 tst R1 902 902 bne 0ERR$ 903 903 MOV #AZ$CSR,R1 904 904 mov #36,(R1) 905 -0$: TSTB (R1); checkexecutionresult906 - BPL 0$; wait910 +0$: TSTB (R1); проверяем результат выполнения 911 + BPL 0$; ждем 907 907 clr R1 908 908 0ERR$: return 909 909 {{/code}} 910 910 911 -== 042: GettimefromTCP/IPstackclockintotimestampbuffer==916 +== **042: Получить время из часов TCP/IP стека в буфер timestamp** == 912 912 913 - Commandcode042,thiscommandusestheTCP/IPstackclockasasource for fillingthe timestampbuffer.918 +Код команды 042, данная команда использует часы TCP/IP стека как источник заполнения буфера timestamp. 914 914 915 - Exampleprogram:920 +Пример программы: 916 916 917 917 {{code language="assembler"}} 918 -; workingwithclock919 -; trap 60 - readingclockdatafromTCP/IPstack920 -; R3 - bufferaddresswheretoread921 -; resultinR3addressifsuccessful. R3=0iferror923 +; работа с часами 924 +; trap 60 - чтение данных часов из TCP/IP стека 925 +; R3 - адрес буфера куда надо считать 926 +; результат в R3 адрес, если успешно. R3=0 если ошибка 922 922 GetDateFromLAN: push R0 923 923 push R1 924 924 push R2 925 - call AZreset; reset930 + call AZreset; сбросим 926 926 tst R1 927 927 bne G60ERR 928 928 MOV #AZ$CSR,R1 929 929 mov #42,(R1) 930 -G60: TSTB (R1); checkexecutionresult931 - BPL G60; wait935 +G60: TSTB (R1); проверяем результат выполнения 936 + BPL G60; ждем 932 932 mov #32,(R1) 933 -1$: TSTB (R1); checkexecutionresult934 - BPL 1$; wait935 - TST (R1)+; increment936 - mov R3,R0; rememberR3address938 +1$: TSTB (R1); проверяем результат выполнения 939 + BPL 1$; ждем 940 + TST (R1)+; инкрементируем 941 + mov R3,R0; запомним R3 - адрес 937 937 mov #10.,R2; читаем 10 слов 938 -2$: mov (R1),(R3)+; readblockofwordsinto memory943 +2$: mov (R1),(R3)+; читаем блок слов в память 939 939 sob R2,2$ 940 - mov R0,R3; successful,returnaddresstoR3945 + mov R0,R3; успешно, вернем адрес в R3 941 941 br 0END$ 942 942 G60ERR: CLR R3 943 943 0END$: pop R2 ... ... @@ -946,50 +946,52 @@ 946 946 return 947 947 {{/code}} 948 948 949 - Allcommandssetthereadybitupon completion.954 +все команды устанавливают бит готовности по завершению. 950 950 951 951 952 -= **[[AZБК®>>doc:Контроллеры AZБК® для компьютеров БК-0010 БК-0010\.01 БК-0011М.WebHome]] specificcommands=957 += **Команды специфические для [[AZБК®>>doc:Контроллеры AZБК® для компьютеров БК-0010 БК-0010\.01 БК-0011М.WebHome]]** = 953 953 954 - Thesecommandsareintendedforoperationof theAZБК®controller,developedfortheBKseriesof computers-BK-0010/BK-0010.01/BK-0011M.959 +Данные команды предназначены для работы контроллера AZБК®, разработанного для серии компьютеров БК - БК-0010/БК-0010.01/БК-0011М. 955 955 956 - OtherAZ®controllersignorethese commands.961 +Другие контроллеры AZ® игнорируют эти команды 957 957 958 -== 037: Restartof the**[[AZБК®>>doc:Контроллеры AZБК® для компьютеров БК-0010 БК-0010\.01 БК-0011М.WebHome]] **controllerand the entire computer==963 +== **037: перезапуск контроллера [[AZБК®>>doc:Контроллеры AZБК® для компьютеров БК-0010 БК-0010\.01 БК-0011М.WebHome]] и всей БК** == 959 959 960 - Commandcode037,thiscommandrestartstheAZ®microcontroller,whichalsocausesarestartof the BK-0010/BK-0010.01/BK-0011M itself965 +Код команды 037, данная команда осуществляет перезапуск микроконтроллера AZ®, что вызывает и перезапуск самой БК-0010/БК-0010.01/БК-0011М 961 961 962 - Exampleprogram967 +Пример программы 963 963 964 964 {{code language="assembler"}} 965 -AZ$CSR = 177220; commandandstatusregister(CSR)966 -AZ$DR = 177222; dataregister(DR)970 +AZ$CSR = 177220; регистр команд и состояния (CSR) 971 +AZ$DR = 177222; регистр данных (DR) 967 967 968 968 969 -; trap 57 - fullrestart970 -AZcouldReboot: call AZreset; resetAZsoitisreadytoreceive974 +; trap 57 - перезапуск БК полный 975 +AZcouldReboot: call AZreset; сбросим AZ дабы он был готов принимать команды 971 971 mov #037,@#AZ$CSR 972 972 return 973 973 {{/code}} 974 974 975 -== 044: Savingascreenshottoa file==980 +== **044: Cохранение скриншота в файл** == 976 976 977 -Command code 044, this command is designed to take a memory image of the specified size (or determined automatically based on saved parameters) technically, the command can serve as a debugging tool because it is capable of taking a memory image the general limitation on taking a memory image is 2MB per image 978 -\\service memory page 76(8) is used as parameters 982 +Код команды 044, данная команда предназначена для снятия образа памяти указанного размера (или определенного автоматически на основании сохраненных параметров) 983 +технически команда может служить как средство отладки ибо способная снимать образ памяти 984 +общее ограничение на снятие образа памяти - 2МБ на один образ 985 +\\в качестве параметров используется служебная страница памяти 76(8) 979 979 980 - Structureoffillinginformationabouta screenshot987 +Структура заполнения информации о скриншоте 981 981 982 982 {{code language="c"}} 983 -// screenshotheaderstructure990 +// структура хидера скриншота 984 984 typedef __packed struct screen_header 985 985 { 986 - unsigned short int tag; //mustbeequalto0240993 + unsigned short int tag; // должен быть равен 0240 987 987 988 - startaddressinwords-forwardtaskinphysicaladdresses989 - unsigned int length; // lengthinwords-forwardtaskinphysicaladdresses995 + unsigned int begin_adress; // начальный адрес в словах - прямая задача в физических адресах 996 + unsigned int length; // длина в словах - прямая задача в физических адресах 990 990 991 - unsigned short int begin_page; startpage-number-forwardtaskinpagenumbers992 - unsigned short int len_pages; numberofpages-forwardtaskinpagenumbers998 + unsigned short int begin_page; // начальная страница - номер - прямая задача в номерах страниц 999 + unsigned short int len_pages; // количество страниц - прямая задача в номерах страниц 993 993 994 994 unsigned short int R177300; // 995 995 unsigned short int R177302; // ... ... @@ -1007,56 +1007,57 @@ 1007 1007 unsigned short int R177332; // 1008 1008 unsigned short int R177334; // 1009 1009 unsigned short int R177336; // 1010 - unsigned short int R177340; // - Windowactivationcontrolregister-windowmasks1011 - unsigned short int R177342; // - Controlregisterr/operwindow1012 - unsigned short int R177344; // - Shadowwindowcontrol register-windowmasks1013 - unsigned short int R177346; // - Mappercontrolregister1014 - unsigned short int R177350; // - copybyrecordregister177130inmemorymanagementwritemodeinSMK1015 - copybyrecordregister177716inmemorymanagementwritemodeinBK11M1017 + unsigned short int R177340; // - Регистр управления активацией окно - маски окон 1018 + unsigned short int R177342; // - Регистр управления r/o на окно 1019 + unsigned short int R177344; // - Регистр управления shadow окон - маски окон 1020 + unsigned short int R177346; // - Регистр управления маппером 1021 + unsigned short int R177350; // - регистр копия по записи 177130 в режиме записи управления памятью в SMK 1022 + unsigned short int R177352; // - регистр копия по записи 177716 в режиме записи управления памятью в БК11М 1016 1016 1017 - unsigned short int R177230; // - controlregister1018 - unsigned short int R177232; // - displaystartpagenumberregister-upperpage(layer0)1019 - unsigned short int R177240; // - displaystartpagenumberregister-upperpage(layer1)1020 - unsigned short int R177242; // - displaystartpagenumberregister-upperpage(layer2)1021 - unsigned short int R177244; // - verticalscrollregisterlayer21022 - unsigned short int R177246; // - verticalscrollregisterlayer11023 - unsigned short int R177250; // - verticalscrollregisterlayer01024 - unsigned short int R177252; // - horizontalscrollregisterlayer01025 - unsigned short int R177254; // - horizontalscrollregisterlayer11026 - unsigned short int R177256; // - horizontalscrollregisterlayer21024 + unsigned short int R177230; // - регистр управления 1025 + unsigned short int R177232; // - регистр номера страницы начала отображения - верхняя страница (слой 0) 1026 + unsigned short int R177240; // - регистр номера страницы начала отображения - средняя страница (слой 1) 1027 + unsigned short int R177242; // - регистр номера страницы начала отображения - нижняя страница (слой 2) 1028 + unsigned short int R177244; // - регистр вертикального скролинга слой 2 1029 + unsigned short int R177246; // - регистр вертикального скролинга слой 1 1030 + unsigned short int R177250; // - регистр вертикального скролинга слой 0 1031 + unsigned short int R177252; // - регистр гозизонтального скролинга слой 0 1032 + unsigned short int R177254; // - регистр гозизонтального скролинга слой 1 1033 + unsigned short int R177256; // - регистр гозизонтального скролинга слой 2 1027 1027 1028 1028 unsigned short int paldata[338]; // 1029 1029 } screen_header_t; 1030 1030 {{/code}} 1031 1031 1032 - Examplecodeforfillingamemory page1039 +Пример кода для заполнения страницы памяти 1033 1033 1034 1034 {{code language="assembler"}} 1035 1035 ;-------------------------------------------------- 1036 -; 76 thpagemap-wepreparedataforthescreenshotcommand there1037 -SCR_PAGE = 130000 ;wetemporarilyattachthe76thpagetothe77th-thatis,intothe130000window1038 -SCR_TAG = SCR_PAGE+0 ;hereistheinput- 240 - 1word1039 -SCR_ADDR_CONF = SCR_TAG+2 ;hereisthecommandwithaddresses-address+length24bits- 4words1040 -SCR_PAGE_CONF = SCR_ADDR_CONF+8. ; hereisthecommandwith pages-thestartingpageandthenumber of pages- 2words1041 -SCR_MEM_CONF = SCR_PAGE_CONF+4. ; here is the memoryconfigurationfromtheregisters- 22words1042 -SCR_VGA_CONF = SCR_MEM_CONF+44. ; herevideocontrollerconfiguration- 10words1043 -SCR_PAL = SCR_VGA_CONF+20. ; here338.values ??(words)ofpalette338words1043 +; карта 76й страницы - туда мы готовим данные для команды скринщотов 1044 + SCR_PAGE = 130000 ; 76ую страницу цепляем на место 77й временно - те в окно 130000 1045 + SCR_TAG = SCR_PAGE+0 ; тут вход - 240 - 1 слово 1046 + SCR_ADDR_CONF = SCR_TAG+2 ; сюда команду с адресами - адрес+длина 24 бита - 4 слова 1047 + SCR_PAGE_CONF = SCR_ADDR_CONF+8. ; сюда команду со страницами - начальная страница и количество страниц - 2 слова 1048 + SCR_MEM_CONF = SCR_PAGE_CONF+4. ; cюда конфигурацию памяти из регистров - 22 слова 1049 + SCR_VGA_CONF = SCR_MEM_CONF+44. ; сюда конфигурацию видеоконтроллера - 10 cлов 1050 + SCR_PAL = SCR_VGA_CONF+20. ; сюда 338. значений(слов) палитры 338 слов 1044 1044 ;-------------------------------------------------- 1045 1045 1046 -; trap 41 - preparation of default information for screenshot functionality 1047 -PrepSRC: jsr R5, PUSHA ; batch saving of registers 1048 - mov @#177326,-(SP) ; save page 130k which was before the call 1049 - mov #76,@#177326 ; hook 76th page into window 1050 1050 1051 - mov #100377,R3 ; constant-filler 1054 +; trap 41 - подготовка дефолтной информации для работы функционала скриншотов 1055 +PrepSRC: jsr R5, PUSHA ; пакетное сохранение регистров 1056 + mov @#177326,-(SP) ; сохраним страницу 130k которая была до вызова 1057 + mov #76,@#177326 ; цепляем 76ую страницу в окно 1058 + 1059 + mov #100377,R3 ; константа-заполнитель 1052 1052 mov #SCR_PAGE,R4 1053 1053 mov #2047.,R2 1054 1054 4$: mov R3,(R4)+ 1055 1055 sob R2,4$ 1056 1056 1057 - mov #240,@#SCR_TAG ; putthe tag1065 + mov #240,@#SCR_TAG ; проставляем тег 1058 1058 1059 - ; cleantheaddresssection-defaultisautomaticaddress detection1067 + ; чистим участок адресов - дефолтно автоматическое определение адресов 1060 1060 clr R3 1061 1061 mov #SCR_ADDR_CONF,R4 1062 1062 mov #10,R2 ... ... @@ -1063,7 +1063,7 @@ 1063 1063 2$: mov R3,(R4)+ 1064 1064 sob R2,2$ 1065 1065 1066 - ; memoryconfiguration-default1074 + ;конфигурация памяти - дефолтная 1067 1067 mov #SCR_MEM_CONF,R4 1068 1068 mov #30,(R4)+ ;177300 1069 1069 mov #31,(R4)+ ;177302 ... ... @@ -1082,29 +1082,29 @@ 1082 1082 mov #110,(R4)+ ;177334 1083 1083 mov #100,(R4)+ ;177336 1084 1084 1085 - mov #170000,(R4)+ ;177340 1086 - mov R3,(R4)+ ;177342 1087 - mov #7777,(R4)+ ;177344 1088 - mov #40404,(R4)+ ;177346 1089 - mov R3,(R4)+ ;177350 1090 - mov #16000,(R4)+ ;177352 1093 + mov #170000,(R4)+ ;177340 - Регистр управления активацией окно - маски окон 1094 + mov R3,(R4)+ ;177342 - Регистр управления r/o на окно 1095 + mov #7777,(R4)+ ;177344 - Регистр управления shadow окон - маски окон 1096 + mov #40404,(R4)+ ;177346 - Регистр управления маппером 1097 + mov R3,(R4)+ ;177350 - регистр копия по записи 177130 в режиме записи управления памятью в SMK 1098 + mov #16000,(R4)+ ;177352 - регистр копия по записи 177716 в режиме записи управления памятью в БК11М 1091 1091 1092 - ; Videocontrollerconfiguration-default1100 + ;конфигурация видеоконтроллера - дефолтная 1093 1093 ; 177230-177256 1094 1094 mov #SCR_VGA_CONF,R4 1095 1095 1096 - mov #12201,(R4)+ ;177230 1097 - mov #4,(R4)+ ;177232 1098 - mov R3,(R4)+ ;177240 1099 - mov R3,(R4)+ ;177242 1100 - mov R3,(R4)+ ;177244 1101 - mov R3,(R4)+ ;177246 1102 - mov R3,(R4)+ ;177250 1103 - mov R3,(R4)+ ;177252 1104 - mov R3,(R4)+ ;177254 1105 - mov R3,(R4)+ ;177256 1104 + mov #12201,(R4)+ ;177230 - регистр управления 1105 + mov #4,(R4)+ ;177232 - регистр номера страницы начала отображения - верхняя страница (слой 0) 1106 + mov R3,(R4)+ ;177240 - регистр номера страницы начала отображения - средняя страница (слой 1) "под спрайты" 1107 + mov R3,(R4)+ ;177242 - регистр номера страницы начала отображения - нижняя страница (слой 2) "под фон" 1108 + mov R3,(R4)+ ;177244 - регистр вертикального скролинга слой 2 1109 + mov R3,(R4)+ ;177246 - регистр вертикального скролинга слой 1 1110 + mov R3,(R4)+ ;177250 - регистр вертикального скролинга слой 0 1111 + mov R3,(R4)+ ;177252 - регистр гозизонтального скролинга слой 0 1112 + mov R3,(R4)+ ;177254 - регистр гозизонтального скролинга слой 1 1113 + mov R3,(R4)+ ;177256 - регистр гозизонтального скролинга слой 2 1106 1106 1107 - ; downloadthepalette-takethedefaultonefrom this ROM1115 + ; закачиваем палитру - берем дефолтную из этой ПЗУшки 1108 1108 mov #SCR_PAL,R4 1109 1109 mov #PalData,R2 1110 1110 mov #338.,R3 ... ... @@ -1111,31 +1111,32 @@ 1111 1111 1$: mov (R2)+,(R4)+ 1112 1112 sob R3,1$ 1113 1113 1114 - mov (SP)+,@#177326; returnthepagefromwhichthe call was made1122 + mov (SP)+,@#177326; вернем страницу с которой был вызов 1115 1115 return 1116 1116 {{/code}} 1117 1117 1118 - Therearethreeoptionsfor specifying memory areas.1126 +Вариантов указания участков памяти три 1119 1119 1120 -1. specifytheaddressandlength24-bit-seeformat,iftheyarenot there-thesystemlooks further1121 -1. specifythepagenumberandpage quantity,ifthey are not there1122 -1. thesystemlooksfurther-thatis,itmakesascreenshotbasedonthe data about registers177230,etc.1128 +1. указать адрес и длину 24х битные - cм формат, если их нет - система смотрит дальше 1129 +1. указать номер страницы и количество страницы, если их нет 1130 +1. система смотрит дальше - те делает скриншот на основании данных о регистрах 177230 и т.д.. 1123 1123 1124 - Thescreenshotissaved in the format1125 -- page76 -itsfirstkilobyte1126 -- thememoryimageitself(ifthemodeis layered-thenallthreelayers)1132 +Cкриншот сохраняется в формате 1133 +- страница 76 - ее первый килобайт 1134 +- сам образ памяти (если режим слоеный - то все три слоя) 1127 1127 1128 1128 1129 -Before calling the command, you can load the file name for saving the screenshot [in the cmosmem buffer], but if it is missing (there will be no name in the buffer - a line ending with 0), the system will generate its own name based on the following rule: default path for saving screenshots 1137 +Перед вызовом команды можно загрузить имя файла для сохранения скриншота [в cmosmem буфер], однако при его отсутствии (в буфере не будет имени - строки заканчивающейся 0) система сформирует свое имя, на основании следующего правила: 1138 +дефолтный путь для сохранения скриншотов 1130 1130 0:/SCREENS/ 1131 - nameformat- DDHHMISS.SCR1132 - whereDDistwodigitsofthe day of the month, HHisthe hour, MIisthe minute, SSis the second1133 -\\ Ifanerroroccursduringthecommandexecution,thenamewillbe"ERROR *"1134 - forexample1140 +формат имени - DDHHMISS.SCR 1141 +где DD - две цифры дня месяца, HH - час, MI - минута, SS-секунда 1142 +\\Если в процессе выполнения команды возникнет ошибка - вместо имени будет "ERROR *" 1143 +к примеру 1135 1135 "ERROR f_open 6" 1136 1136 1137 1137 1138 - Exampleprogram1147 +Пример программы 1139 1139 1140 1140 {{code language="assembler"}} 1141 1141 ; обновим информацию в хидере скриншота