Курсовая работа: Монітор використання ресурсів комп'ютера
Название: Монітор використання ресурсів комп'ютера Раздел: Рефераты по информатике, программированию Тип: курсовая работа |
Міністерство освіти і науки України Кiровоградський Державний Технiчний Унiверситет Факультет автоматики енергетики та програмування Кафедра програмного забезпечення Курсовая работа з дисципліни “ASM-86 ” на тему: "Монітор використання ресурсів комп'ютера" Зміст 1. Вступ 2. Постановка задачі 3. Обґрунтування вибору методів розв’язку задачі 4. Алгоритм програми 5. Реалізація програми 6. Системні вимоги 7. Інструкція для користувача 8. Висновки 9. Використана література Додаток 1. ВступТепер комп’ютери відіграють у житті людини все більшу та більш роль. Раніше, коли ще не було комп’ютерів, чи вони були мало розповсюдженні, все робилося вручну. Коли комп’ютери одержали широке розповсюдження, комп’ютер став допомагати людині, бо він може багато операцій робити набагато швидше, ніж людина. Але є багато типів комп'ютерів, які розрізняються своїми можливостями. Щоб досконаліше знати можливості свого комп'ютера, призначені програми, які виводять на екран характеристики машини. 2. Постановка задачіРозробити програму “Монітор використання ресурсів комп’ютера" на мові програмування ASM-86. 3. Обґрунтування вибору методів розв’язку задачіОтже, необхідно написати програму, яка виводе на екран ресурси комп’ютера. При виборі алгоритму програми у мене виникло багато варіантів, бо ресурси машини можна знаходити різними засобами. Але на мою думку, я вибрав алгоритми, які більш-менш прості та зрозумілі користувачу. 4. Алгоритм програмиАлгоритм головної програми: Очищення екрану Виведення рамки Аналізує і виводить тип комп'ютера Аналізує і виводить версію MS-DOS Аналізує і виводить день тижня Аналізує і виводить поточну дату Підготовка виводу системного часу Аналізує і виводить розмір пам'яті Аналізує і виводить інформацію про диск Аналізує і виводить інформацію про мікропроцесор Виклик процедури виводу часу Читання порту клавіатури Порівняння з ESC 14Якщо не ESC, продовження виводу часу 15. Закінчити програму. 5. Реалізація програмиПрограма написана на мові ASM-86 з використанням команд процесора 86/286. Вона складається з головної програми, яка викликає процедури, та процедур, які виконують необхідні дії по визначенню ресурсів машини. Для визначення системної дати та дня тижня я використовував функцію 2AH переривання 21H. Для визначення системного часу я використовував функцію 2СH переривання 21H. Для визначення розміру пам'яті я використовував пам'ять CMOS, порти 70h та 71h. Для визначення метки тому, формату FAT я читав BOOT-сектор диску, та аналізував інформацію в ньому. Читання сектору я проводив за допомогою переривання 25H. Для визначення вільного місця, кількості загальних та вільних кластерів я використовував функцію 36H переривання 21H. Для визначення версії DOS я використовував функцію 30H переривання 21H. Для визначення типу комп'ютера я використовував байт пам'яті, який знаходиться по адресу: 0F000H: 0FFFEH. Програма компілюється Turbo Assembler, зв’язується за допомогою TLINK. 6. Системні вимогиIBM сумісний комп’ютер із мікропроцесором Intel 80086 або старшим. Операційна система - ДОС Пам’ять - 640 К і вище 7. Інструкція для користувачаДля запуску програми-монітору використання ресурсів комп’ютера, потрібно в командному рядку набрати kurs1. exe та натиснути Enter. Програма аналізує та виводе на екран відомості про тип комп'ютера, поточну дату, день тижня, розмір пам'яті, розмір розширеної пам'яті, версію MS-DOS, метку тому диска, формат FAT диску, вільне місце на диску, кількість вільних кластерів на диску та тип процесора. Також програма виводе на екран поточний час до тих пір, поки користувач не натисне клавішу ESC. 8. ВисновкиОтже, на мові ASM-86 створено програму-монітор використання ресурсів комп’ютера. 9. Використана література1. Р. Джордейн “Справочник программиста персональных компьютеров типа IBM PC” М: Мир, 1991р. 2. П. Абель “Мова асемблера для IBM PC та програмування." М.: Вища школа, 1992. 3. “Основи мови” Асемблер” В.I. Криволап. Москва 1997р. ст.309 4. “Ассемблер для початкiвцiв” М.П. Шукiн. Київ 1980р. ст.155 5. “Турбо Асемблер” Л.В. Захаров. Харків 1995 р ст.178 6. “Макро Асемблер” К.С. Кропiйко, О.Д. Богатирова. Київ - “Наука” 1991р. 7. Електронний довідник BOOK. ДодатокЛістинг програмиSTACKSG SEGMENT PARA STACK 'Stack'; Стек DW 32 DUP (?) STACKSG ENDS ; - --------------------------------------------------- DATASG SEGMENT PARA 'Data'; Данные saved_cpuid dd? vendor_id db 12 dup (?) cpu_type db? themodel db? stepping db? id_flag db 0 intel_proc db 0 id_msg db "Ця система маэ: $" c8086 db "8086/8088 мiкропроцессор$" c286 db "Intel 286 мiкропроцнссор$" c386 db "Intel386 (TM) мiкропроцессор$" c486 db "Intel486 (TM) DX мiкропроцессор$" Pentium db "Pentium (TM) мiкропроцессор", 13, 10, '$' intel db " Genuine Intel Processor", 13, 10, "$" modelmsg db "Модель: $" steppingmsg db "Шаг: $" familymsg db "Процессор сiмейства: $" period db ". ",13,10,"$" dataCR db?,13,10,"$" intel_id db "GenuineIntel" TYPEC DB 'Тип комп"ютера','$' MJR DB 'PCjr ','$' MPC DB 'PC','$' MXT DB 'XT','$' MAT DB 'AT','$' VER DB 'ВЕРСIЯ MS-DOS ','$' STAR DB 2 DUP (?) TOCH DB '. ' MLAD DB 2 DUP (?) TOCH1 DB '. ','$' SDAT DB 'СИСТЕМНA ДАТА ','$' GOD1 DB 2 DUP (?) GOD2 DB 2 DUP (?),'-' MUNS DB 2 DUP (?),'-' DAY DB 2 DUP (?) TOCH2 DB '. ','$' MEMMS DB 'Розмiр пам"ятi','$' MEMMS1 DB 'Розмiр розширеноi пам"ятi','$' MEM1 DB 2 DUP (?) MEM2 DB 2 DUP (?),'$' DENTIG DB 'День тиждня','$' NED DB 'Недiля',13,10,'$' PON DB 'Понедiлок',13,10,'$' VIV DB 'Вiвторок',13,10,'$' SER DB 'Середа',13,10,'$' CHE DB 'Четверг',13,10,'$' PYA DB 'П"ятниця',13,10,'$' SUB DB 'Субота',13,10,'$' TIME DB 'Системний час','$' HOUR DB 2 DUP (?),': ' MIN DB 2 DUP (?),': ' SEC DB 2 DUP (?),'$' COL DB 00 ROW DB 00 chast dw 00 sit db 10 dup ('$'); строка для вывода Space dw 00h; long dw 00h Buffer dw 17000 dup (00); prompt1 db 13,10,' Кiлькiсть вiльних кластерiв на диску = ','$' prompt2 db 13,10,' Доступне дискове пространство = ','$' prompt3 db 13,10,' Кiлькiсть всього кластерiв на диску = ','$' prompt4 db 13,10,' Загальне дискове пространство = ','$' MetkaToma db 13,10,' Метка тому = ',11 dup (0),'$' RFAT db 13,10,' Формат FAT = ',8 dup (0),'$' Sectors_Per_Cluster dw 00h free_cluster dw 00 zag_cluster dw 00 fat_format dw 00 crlf db 13,10,'$' mnoj dd 00h for_eax dd 00h for_eax1 dd 00h ostt dd 00h memo dd 0ah DATASG ENDS ; - --------------------------------------------------- CODESG SEGMENT PARA 'Code'; Код программы BEGIN PROC FAR ASSUME CS: CODESG,DS: DATASG,SS: STACKSG,ES: DATASG PUSH DS SUB AX,AX; Обнуление AX PUSH AX MOV AX,DATASG; Загрузка сегмента данных MOV DS,AX MOV ES,AX MOV AX,0600H CALL Q10SCR; Очистить экран CALL Q20CURS; Установить курсор CALL TABL; Выводит рамку CALL COMP1; Анализирует и выводит тип компютера CALL MSDOSVER; Анализирует и выводит версию MS-DOS CALL SYSTDAT; Анализирует и выводит день недели CALL SMM1; Анализирует и выводит текущую дату CALL TIME1; Подготовка вывода системного времени CALL MEMORY2; Анализирует и выводит размер памяти CALL DISC; Анализирует и выводит информацию о диске CALL CPUID; Анализирует и выводит информацию о микропроцессоре AS: CALL TIME2; Вызов процедуры вывода времени in al,60h; Чтение порта клавиатуры cmp al,1; Сравнение с ESC jne as; Если не ESC, продолжение вывода времени mov ah,004ch; Выход из программы int 21h RET BEGIN ENDP CPUID PROC .8086; This part of the program must run on an 8086 call get_cpuid call print RET CPUID ENDP get_cpuid proc ; 8086 CPU check ; Bits 12-15 are always set on the 8086 processor check_8086: pushf; save FLAGS pop bx; store FLAGS in BX mov ax, 0fffh; clear bits 12-15 and ax, bx; in FLAGS push ax; store new FLAGS calue on stack popf; replace current FLAGS value pushf; set new flags pop ax; store new flags in AX and ax, 0f000h; if bits 12-15 are set, then CPU cmp ax, 0f000h; is an 8086/8088 mov cpu_type, 0; save the CPU type je END1 JMP FF1 END1: RET FF1: ; Intel 286 CPU check ; Bits 12-15 are always clear on the Intel processor. check_80286: .286 or bx, 0f000h; try to set bits 12-15 push bx popf pushf pop ax and ax, 0f000h; if bits 12-15 are cleared, ; CPU=Intel 286 mov cpu_type, 2; turn on Intel 286 Cpu flag jz END2; if CPU is intel 286, check JMP FF2; for Intel 287 math coprocessor END2: RET FF2: ; Intel386 CPU check ; The AC bit (bit 18), is a new bit introduced in the EFLAGS ; register on the Intel486 DX CPU to generate alignment faults. ; This bit can not be set on the Intel386 CPU. ; check_intel386: .386 pushfd pop eax; get original EFLAGS mov ecx,eax; save original EFLAGS xor eax,40000h; flip AC bit in EFLAGS push eax; save for EFLAGS popfd; copy to EFLAGS pushfd; push EFLAGS pop eax; get new EFLAGS value xor eax,ecx; can't toggle AC bit, CPU=Intel386 mov cpu_type, 3; turn on Intel386 CPU flag je end_get_cpuid; if CPU is Intel386, now check ; for an Intel 287 or Intel387 MCP ; Intel486 DX CPU, Intel 487 SX MCP, and Intel486 SX CPU checking ; ; Checking for the ability to set/clear the ID flag (bit 21) in EFLAGS ; which diferentiates between Pentium (or greater) and the Intel486. ; If the ID flag is set then the CPUID instruction can be used to ; determine the final version of the chip, else it's a 486 ; ; check_Intel486: .486 mov cpu_type, 4; turn on Intel486 CPU flag pushfd; push original EFLAGS pop eax; get original EFLAGS in eax mov ecx,eax; save original EFLAGS in ecx or eax, 200000h; flip ID bit in EFLAGS push eax; save for EFLAGS popfd; copy to EFLAGS pushfd; push EFLAGS pop eax; get new EFLAGS value xor eax,ecx je end_get_cpuid; if ID bit cannot be changed, ; CPU=Intel486 without CPUID ; instruction functionality ; Otherwise, execute CPUID instruction to determine vendor, ; family, model and stepping. check_vendor: .586 mov id_flag, 1; set flag for indicating use of ; CPUID inst mov eax, 0; set up for CPUID instruction cpuid mov dword ptr vendor_id, ebx; Test for "GenuineIntel" vendor id. mov dword ptr vendor_id [+4], edx mov dword ptr vendor_id [+8], ecx mov si, offset vendor_id mov di, offset intel_id mov cx, length intel_id compare: repe cmpsb cmp cx, 0; must be a GenuineIntel if ecx =0 jne cpuid_data intel_processor: mov intel_proc, 1 mov [intel-1], '¦'; add a space so the Genuine Intel ; message prints out. cpuid_data: mov eax, 1 cpuid mov saved_cpuid,eax; save for future use and eax, 0F00H; mask everything but family shr eax, 8 mov cpu_type, al; set cpu_type with family mov eax,saved_cpuid; restore data mov stepping, al and stepping, 0FH; isolate stepping info mov eax, saved_cpuid mov themodel, al and themodel, 0F0H; isolate model info shr themodel, 4 end_get_cpuid: .8086 ret get_cpuid endp ; ; This procedure prints the appropriate cpuid string ; If the CPUID instruction was supported, it prints out ; the cpuid info. print proc push ax push bx push cx push dx MOV COL,2 MOV ROW,15 CALL Q20CURS mov dx, offset id_msg mov ah, 9h int 21h; print initial message cmp id_flag, 1; if set to 1, cpu supported CPUID ; instruction ; print detailed CPUID information je print1 print_86: cmp cpu_type, 0 jne print_286 MOV COL,30 MOV ROW,16 CALL Q20CURS mov dx, offset c8086 mov ah, 9h int 21h jmp end_print print1: jmp print_cpuid_data print_286: cmp cpu_type, 2 jne print_386 MOV COL,30 MOV ROW,16 CALL Q20CURS mov dx, offset c286 mov ah, 9h int 21h jmp end_print print_386: cmp cpu_type, 3 jne print_486 MOV COL,30 MOV ROW,16 CALL Q20CURS mov dx, offset c386 mov ah, 9h int 21h jmp end_print print_486: MOV COL,30 MOV ROW,16 CALL Q20CURS mov dx, offset c486 mov ah, 9h int 21h jmp end_print print_cpuid_data: cmp cpu_type, 5 jne print_cpuid_cont MOV COL,30 MOV ROW,16 CALL Q20CURS mov dx, offset Pentium mov ah, 9 int 21h print_cpuid_cont: MOV COL,2 MOV ROW,16 CALL Q20CURS mov dx, offset familymsg; print family msg mov ah, 9h int 21h mov al, cpu_type mov byte ptr dataCR, al add byte ptr dataCR, 30H; convert to ASCII MOV COL,30 MOV ROW,17 CALL Q20CURS mov dx, offset dataCR; print family info mov ah, 9h int 21h MOV COL,2 MOV ROW,18 CALL Q20CURS mov dx, offset steppingmsg; print stepping msg mov ah, 9h int 21h mov al, stepping mov byte ptr dataCR, al add byte ptr dataCR, 30H; convert to ASCII MOV COL,30 MOV ROW,18 CALL Q20CURS mov dx, offset dataCR; print stepping info mov ah, 9h int 21h MOV COL,2 MOV ROW, 19 CALL Q20CURS mov dx, offset modelmsg; print model msg mov ah, 9h int 21h mov al, themodel mov byte ptr dataCR, al add byte ptr dataCR, 30H; convert to ASCII MOV COL,30 MOV ROW, 19 CALL Q20CURS mov dx, offset dataCR; print stepping info mov ah, 9h int 21h end_print: pop dx pop cx pop bx pop ax RET print endp TABL PROC; Процедура вывода рамки MOV CX,78; Количество симв. для верт. линии рамки MOV COL,1 MOV ROW,0 CALL Q20CURS LINE: MOV AH,02H MOV DL, 205; Вывод верт. верхней линии рамки INT 21H LOOP LINE MOV CX,22; Количество симв. для гориз. линии рамки MOV DH,1 LINE2: MOV COL,0 MOV ROW,DH CALL Q20CURS; Установка курсора MOV AH,02H MOV DL,186; Вывод гориз. левой линии рамки INT 21H INC DH LOOP LINE2 MOV CX,22 MOV DH,1 LINE3: MOV COL,79 MOV ROW,DH CALL Q20CURS MOV AH,02H MOV DL,186; Вывод гориз. правой линии рамки INT 21H INC DH LOOP LINE3 MOV CX,78 MOV COL,1 MOV ROW,23 CALL Q20CURS LINE1: MOV AH,02H MOV DL, 205; Вывод вертик. нижней линии рамки INT 21H LOOP LINE1 MOV COL,79; Вывод углов рамки MOV ROW,0 CALL Q20CURS MOV AH,02H MOV DL,187 INT 21H MOV COL,0 MOV ROW,0 CALL Q20CURS MOV AH,02H MOV DL, 201 INT 21H MOV COL,0 MOV ROW,23 CALL Q20CURS MOV AH,02H MOV DL, 200 INT 21H MOV COL,79 MOV ROW,23 CALL Q20CURS MOV AH,02H MOV DL,188 INT 21H RET TABL ENDP COMP1 PROC; Процедура анализирования и вывода ; информации про тип компютера MOV COL,1 MOV ROW,1 CALL Q20CURS; Установка курсора LEA DX,TYPEC; Вывод сообщения о типе MOV AH,09H INT 21H MOV AX,0F000H; Чтение типа комп. по адресу 0F000H: 0FFFEH MOV ES,AX MOV AL,ES: [0FFFEH] CMP AL,0FDH; Проверка на JR JE JR CMP AL,0FFH; Проверка на PC JE PC CMP AL,0FEH; Проверка на XT JE XT CMP AL,0FCH; Проверка на AT JE AT; Переход на вывод AT JR: MOV COL,30 MOV ROW,1 CALL Q20CURS; Установка курсора LEA DX,MJR; Вывод JR MOV AH,09H INT 21H RET PC: MOV COL,30 MOV ROW,1 CALL Q20CURS; Установка курсора LEA DX,MPC; Вывод PC MOV AH,09H INT 21H RET XT: MOV COL,30 MOV ROW,1 CALL Q20CURS; Установка курсора LEA DX,MXT; Вывод XT MOV AH,09H INT 21H RET AT: MOV COL,30 MOV ROW,1 CALL Q20CURS; Установка курсора LEA DX,MAT; Вывод AT MOV AH,09H INT 21H RET COMP1 ENDP MSDOSVER PROC; Процедура анализирования и вывода версии MS-DOS MOV AH,30H INT 21H; читаем номер версии DOS MOV STAR,AL; переводим старшую часть версии в символ OR STAR,30H MOV AX,0000; переводим младшую часть версии в символы MOV AL,AH MOV BH,0ah DIV BH OR AL,30H OR AH,30H MOV MLAD,AL MOV [MLAD+1],AH MOV COL,1; Столбец 1 MOV ROW,2; Строка 2 CALL Q20CURS; Установка курсора LEA DX,VER; вывод младшей части версии MOV AH,09H INT 21H MOV COL,30 MOV ROW,2 CALL Q20CURS; Установка курсора LEA DX,STAR; вывод старшей части версии MOV AH,09H INT 21H RET MSDOSVER ENDP SYSTDAT PROC; Процедура анализирования и вывода дня недели MOV COL,1 MOV ROW,3 CALL Q20CURS; Установка курсора LEA DX,DENTIG; Вывод сообщения MOV AH,09H INT 21H MOV AH,2AH INT 21H; Чтение даты и дня недели CMP AL,0; Проверка на воскресене JE VOS; Переход на вывод воскр. CMP AL,1 JE PO CMP AL,2 JE VT CMP AL,3 JE SR CMP AL,4 JE CHT CMP AL,5; Проверка на пятницу JNE mq jmp PT mq: CMP AL,6; Проверка на суботу MOV COL,30 MOV ROW,3 CALL Q20CURS; Установка курсора LEA DX,SUB MOV AH,09H INT 21H RET VOS: MOV COL,30 MOV ROW,3 CALL Q20CURS; Установка курсора LEA DX,NED MOV AH,09H INT 21H; Вывод воскр. RET PO: MOV COL,30 MOV ROW,3 CALL Q20CURS LEA DX,PON MOV AH,09H INT 21H; Вывод пон. RET VT: MOV COL,30 MOV ROW,3 CALL Q20CURS; Установка курсора LEA DX,DENTIG MOV AH,09H INT 21H LEA DX,VIV MOV AH,09H INT 21H; Вывод вт. RET SR: MOV COL,30 MOV ROW,3 CALL Q20CURS; Установка курсора LEA DX,SER MOV AH,09H INT 21H; Вывод ср. RET CHT: MOV COL,30 MOV ROW,3 CALL Q20CURS; Установка курсора LEA DX,CHE MOV AH,09H INT 21H; Вывод четверг RET PT: MOV COL,30 MOV ROW,3 CALL Q20CURS; Установка курсора LEA DX,PYA MOV AH,09H INT 21H; Вывод пятницы RET SYSTDAT ENDP SMM1 PROC; Процедура анализирования и вывода текущей даты MOV AH,2AH INT 21H; Чтение даты MOV AX,0000; Перевод числа в символьный вид MOV AL,DL MOV BH,0ah DIV BH OR AL,30H OR AH,30H MOV DAY,AL MOV [DAY+1],AH MOV AH,2AH; Чтение даты INT 21H MOV AX,0000; Перевод месяца в символьный вид MOV AL,DH MOV BH,0ah DIV BH OR AL,30H OR AH,30H MOV MUNS,AL MOV [MUNS+1],AH MOV AH,2AH INT 21H; Чтение даты MOV COL,1 MOV ROW,4 CALL Q20CURS; Установка курсора LEA DX,SDAT; Вывод сообщения о дате MOV AH,09H INT 21H MOV COL,30 MOV ROW,4 CALL Q20CURS; Установка курсора mov dx,cx call dec16out; Перевод года в символьный вид и его вывод LEA DX,MUNS-1; Вывод месяца и числа MOV AH,09H INT 21H RET SMM1 ENDP TIME1 PROC MOV COL,1 MOV ROW,5 CALL Q20CURS; Установка курсора LEA DX,TIME; Вывод сообщения о времени MOV AH,09H INT 21H RET TIME1 ENDP TIME2 PROC; Процедура анализирования и вывода текущего времени mov ah,1 mov ch,10h mov cl,0 int 10h; Скрытие курсора MOV AH,2CH; Чтение текущего времени INT 21H MOV AX,0000; Перевод часов в символьный вид MOV AL,CH MOV BH,0ah DIV BH OR AL,30H OR AH,30H MOV HOUR,AL MOV [HOUR+1],AH MOV AH,2CH INT 21H; Чтение текущего времени MOV AX,0000; Перевод минут в символьный вид MOV AL,CL MOV BH,0ah DIV BH OR AL,30H OR AH,30H MOV MIN,AL MOV [MIN+1],AH MOV AH,2CH INT 21H; Чтение текущего времени MOV AX,0000; Перевод секунд в символьный вид MOV AL,DH MOV BH,0ah DIV BH OR AL,30H OR AH,30H MOV SEC,AL MOV [SEC+1],AH MOV COL,30 MOV ROW,5 CALL Q20CURS; Установка курсора LEA DX,HOUR; Вывод текущего времени MOV AH,09H INT 21H RET TIME2 ENDP space_count proc; Процедура анализирования ; свободного места на диске ; Free_Space=ax*cx*bx; mov ah,36h mov dl,0 int 21h; читаем размер свободного пространства .386 mov Sectors_Per_Cluster,ax; сохранение значения секторов на кластер mov free_cluster,bx; сохранение значения свободных кластеров mov zag_cluster,dx; сохранение значения всего кластеров mul bx; результат - в DX: AX mov word ptr for_eax,dx mov word ptr for_eax1,ax xor eax,eax mov eax,dword ptr for_eax shl eax,16 or eax,dword ptr for_eax1 mov word ptr mnoj,cx; EDX: EAX mul mnoj call perevod; перевод числа в строку ret space_count endp perevod proc; Процедура перевода числа в строку .386 lea si,sit xor cx,cx; counter jmp oop1 onz: mov edx,dword ptr space mov eax,ebx oop1: xor ebx,ebx; part of result oop: cmp edx,00 jne dely cmp eax,memo jl yes dely: sub eax,memo sbb edx,00 add ebx,1 adc space,0 jmp oop yes: mov dword ptr ostt,eax mov dx,word ptr ostt or dl,30h; перевести в символьный вид mov [si],dl; сохранить символьный вид 10-ой цифры в строке inc si; перейти к следующей позиции inc cx cmp dword ptr space,00h; проверка на наличие 10-ых знаков для вывода jne onz; продолжение выделения отдельных цифр cmp ebx,00h jne onz dec si ret perevod endp disp_c proc; Процедура вывода свободного места на диске mov ah,9; вывести сообщение о свободном месте lea dx,prompt2 int 21h okp: mov ah,2h; функция вывода символов mov dl, [si] ; int 21h; Вывод свободного места dec si loop okp ret disp_c endp vyv_dec1 proc; Процедура анализирования и вывода количества ; свободных кластеров lea si,sit xor cx,cx mov al,0ah cbw mov bx,ax mov ax,free_cluster mov chast,ax mmm: xor dx,dx mov ax,chast div bx mov chast,ax; octatok - in dx or dl,30h mov [si],dl inc si inc cx cmp chast,00h jne mmm dec si m1: mov dl, [si] mov ah,2h int 21h dec si loop m1 ret vyv_dec1 endp vyv_dec2 proc; Процедура анализирования и вывода количества ; свободных кластеров lea si,sit xor cx,cx mov al,0ah cbw mov bx,ax mov ax,zag_cluster mov chast,ax mmmqw: xor dx,dx mov ax,chast div bx mov chast,ax; octatok - in dx or dl,30h mov [si],dl inc si inc cx cmp chast,00h jne mmmqw dec si m1qw: mov dl, [si] mov ah,2h int 21h dec si loop m1qw ret vyv_dec2 endp clust_count proc; Процедура анализирования и вывода количества ; свободных кластеров mov ah,9h; функция вывода lea dx,prompt1; сообщения о своб. кластерах int 21h; вызов DOS call vyv_dec1; Вызов процедуры вывода свободных кластеров mov ah,9h; функция вывода lea dx,prompt3; сообщения о своб. кластерах int 21h; вызов DOS call vyv_dec2; Вызов процедуры вывода свободных кластеров ret clust_count endp get_logic_boot proc; Процедура анализирования BOOT-сектора mov dx,0 mov cx,0ffffh lea bx,Buffer mov dword ptr Buffer,0; с какого сектора начинать чтение mov word ptr Buffer+4,1; количество секторов для чтения mov word ptr Buffer+6,bx; Адрес буфера (смещение) mov ax,ds mov word ptr Buffer+8,ax; Адрес буфера (сегмент) mov al,3; функция чтения int 25h; Чтение BOOT-сектора pop dx; восстановление стека после int 25h cld; установка направления вперед для movsb push ds; установка es на сегмент данных pop es mov si,offset Buffer [43] ; регистр si - смещение Buffer [43] -метка тома mov di,offset MetkaToma [16] ; регистр di - смещение MetkaToma [16] -метка тома mov cx,11; колич. символов в метке тома rep movsb; копирование метки тома в переменную mov dx,offset MetkaToma; Вывод метки тома mov ah,9 int 21h mov si,offset Buffer [54] ; регистр si - смещение Buffer [54] -тип FAT mov di,offset RFAT [16] ; регистр di - смещение RFAT [16] -тип FAT mov cx,8; колич. символов в типе FAT rep movsb; копирование типа FAT в переменную mov dx,offset RFAT; Вывод типа FAT mov ah,9 int 21h ret get_logic_boot endp DISC PROC; Процедура анализирования и вывода информации о диске call get_logic_boot; Вызов процедуры анализирования BOOT-сектора call space_count; Вызов процедуры анализирования свободного места call disp_c; Вызов процедуры вывода свободного места call clust_count; Вызов процедуры анализирования и вывода количества ; свободных кластеров RET DISC ENDP Q10SCR PROC NEAR; Процедура прокрутки экрана ; AX установлен при вызове MOV BH,31; Цвет (07 для ч/б) SUB CX,CX MOV DX,184FH INT 10H; прокрутка экрана RET Q10SCR ENDP Q20CURS PROC NEAR; Процедура установки курсора MOV AH,02 SUB BH,BH MOV DH,ROW MOV DL,COL INT 10H; Установка курсора RET Q20CURS ENDP MEMORY2 PROC; Процедура анализирования и вывода размера памяти MOV COL,2 MOV ROW,6 CALL Q20CURS; Установка курсора LEA DX,MEMMS; Вывод сообщения о памяти MOV AH,09H INT 21H MOV COL,30 MOV ROW,6 CALL Q20CURS; Установка курсора mov al,15h; Установка для чтения из CMOS out 70h,al; младшего байта размера памяти nop xor ax,ax in al,71h; Чтение из CMOS размера памяти mov bx,ax mov al,16h; Установка для чтения из CMOS out 70h,al; старшего байта размера памяти nop xor ax,ax in al,71h; Чтение из CMOS размера памяти shl ax,8 add bx,ax mov dx,bx call dec16out; Перевод размера памяти в строку и его вывод MOV COL,2 MOV ROW,7 CALL Q20CURS; Установка курсора LEA DX,MEMMS1; Вывод сообщения о расширенной памяти MOV AH,09H INT 21H MOV COL,30 MOV ROW,7 CALL Q20CURS; Установка курсора mov al,17h; Установка для чтения из CMOS out 70h,al; младшего байта размера расширенной памяти nop xor ax,ax in al,71h; Чтение из CMOS размера расширенной памяти mov bx,ax mov al,18h; Установка для чтения из CMOS out 70h,al; старшего байта размера расширенной памяти nop xor ax,ax in al,71h; Чтение из CMOS размера расширенной памяти shl ax,8 add bx,ax mov dx,bx call dec16out; Перевод расширенного размера памяти в строку ; и его вывод RET MEMORY2 ENDP dec16out proc near; Процедура перевода 16-битного кода в строку ; DX-число для перевода dec16out0: push ds; сохраняем используемые регистры в стеке push di push dx push cx push ax ; помещение символьных цифр во временный буфер mov cx,0 mov di, offset cs: tbuff; адрес временного буфера dec16out1: push cx; сохранить cx mov ax,dx mov dx,0 mov cx,10 div cx; деление на 10 xchg ax,dx; получение остатка add al,30h; перевод цифры в символ mov cs: [di],al; поместить символ в буфер inc di; переход к следующему символу pop cx; восстановить cx inc cx; увеличить количество цифр cmp dx,0; проверка частного на 0 jnz dec16out1; если не равно, продолжать выделение цифр dec16out2: dec di; вывод символов буфера в обратном порядке mov al,cs: [di] call stdout; Вызов процедуры вывода символа на экран loop dec16out2 pop ax; восстанавливаем сохраненные регистры из стека pop cx pop dx pop di pop ds ret dec16out endp stdout proc near; Процедура вывода символа на экран push dx mov dl,al; mov ah,2; функция вывода символа на экран int 21h; вывод символа pop dx ret tbuff db 255 dup ('$') stdout endp CODESG ENDS END BEGIN |