36941

Ознайомитись з програмною моделлю 32 розрядних процесорів Intel та оволодіти навиками створення програм, використовуючи 32 розрядний асемблер

Лабораторная работа

Информатика, кибернетика и программирование

model flt stdcll option csemp: none ; оголошення службових процедур макросів змінних констант include msm32 include windows.inc include msm32 include kernel32.inc include msm32 include msm32.inc include msm32 include debug.

Украинкский

2013-09-23

122.49 KB

7 чел.

Міністерство освіти і науки, молоді та спорту України

Національний університет “Львівська політехніка”

Кафедра ЕОМ

Лабораторна робота №1
дисципліни:”
Системне програмування

Виконав:

Ст.. гр. –КІ-32

Приймак Д.В.

Перевірив:

 Олексів М.В.

                      

Львів – 2011


Мета: Ознайомитись з програмною моделлю 32 розрядних процесорів Intel та оволодіти навиками створення програм, використовуючи 32 розрядний асемблер.

Теоретичні відомості : 

Регістри користувача

Як випливає з назви, призначеними для користувача регістри називаються тому, що програміст може використовувати їх при написанні своїх програм. До цих регістрів відносяться (рис.1):

  1.  вісім 32-бітових регістрів, які можуть використовуватися програмістами для зберігання даних і адрес (їх ще називають регістрами загального призначення (РЗП|)):
  2.  eax/ax/ah/al;
  3.  ebx/bx/bh/bl;
  4.  edx/dx/dh/dl;
  5.  ecx/cx/ch/cl;
  6.  ebp/bp;
  7.  esi/si;
  8.  edi/di;
  9.  esp/sp.
  10.  шість сегментних регістрів: cs, ds, ss, es, fs, gs;
  11.  регістри управління та стану:
  12.  регістр прапорів eflags/flags;
  13.  регістр покажчика команди eip/ip.

Чому багато з цих регістрів приведені з розділовою межею? (рис. 1)
Ні, це не різні регістри — це частини одного великого 32-розрядного регістра. Їх можна використовувати в програмі як окремі об'єкти. Так зроблено для забезпечення працездатності програм, написаних для молодших 16-розрядних моделей мікропроцесорів фірми Intel, починаючи з i8086. Мікропроцесори i486 і Pentium мають в основному 32-розрядні регістри. Їх кількість, за винятком сегментних регістрів, таке ж, як і у i8086, але розмірність більше, що і відбито в їх позначеннях — вони мають приставку
e (Extended).

 Регістри загального призначення

Всі регістри цієї групи дозволяють звертатися до своїх “молодших” частин (див. рис. 1).

Відмітимо, що використовувати для самостійної адресації можна тільки молодші 16 і 8-бітові частини цих регістрів. Старші 16 біт цих регістрів як самостійні об'єкти недоступні.

До РЗП відносяться|:

  1.  eax/ax/ah/al (Accumulator register) — акумулятор.

Застосовується для зберігання проміжних даних. У деяких командах використання цього регістра обов'язкове;

  1.  ebx/bx/bh/bl (Base register) — базовий регістр.

Застосовується для зберігання базової адреси деякого об'єкту в пам'яті;

  1.  ecx/cx/ch/cl (Count register) — регістр-лічильник.

Застосовується в командах, що проводять деякі дії, що повторюються. Його використання часто неявно і приховано в алгоритмі роботи відповідної команди.
Наприклад, команда організації циклу loop окрім передачі управління команді, що знаходиться за деякою адресою, аналізує і зменшує на одиницю значення регістра ecx/cx;

  1.  edx/dx/dh/dl (Data register) — регістр даних.

Так само, як і регістр eax/ax/ah/al, він зберігає проміжні дані. У деяких командах його використання обов'язково; для деяких команд це відбувається неявно.

Наступні два регістри використовуються для підтримки операцій, що проводять послідовну обробку ланцюжків елементів, кожний з яких може мати довжину 32, 16 або 8 біт:

  1.  esi/si (Source Index register) — індекс джерела.
  2.  edi/di (Destination Index register) — індекс приймача (одержувача).

У архітектурі мікропроцесора на програмно-апаратному рівні підтримується така структура даних, як стек. Для роботи із стеком в системі команд мікропроцесора є спеціальні команди, а в програмній моделі мікропроцесора для цього існують спеціальні регістри:

  1.  esp/sp (Stack Pointer register) — регістр покажчика стека.
    Містить покажчик вершини стека в поточному сегменті стека.
  2.  ebp/bp (Base Pointer register) — регістр покажчика бази кадру стека.
    Призначений для організації довільного доступу до даних усередині стека.

Використання жорсткого закріплення регістрів для деяких команд дозволяє компактніше кодувати їх машинне уявлення. Знання цих особливостей дозволить вам при необхідності хоч би на декілька байт заощадити пам'ять, займану кодом програми.

Завдання:

Варіант №22 : Знайти суму перших К елементів масиву A={a[i]}, що задовольняють умову 2*с <= a[i] <=3*d
Виконання роботи :

Програма виконує сумування елементів масиву при умові 2*с <= a[i] <=3*d, числа с і d задаються спочатку. Процес сумування показано на рис.1  ,у полі

Код програми :

 

.586

; використати плоску модель пам'яті і узгодження імен stdcall

.model flat, stdcall

option casemap: none

; оголошення службових процедур, макросів, змінних, констант

include \masm32\include\windows.inc

include \masm32\include\kernel32.inc

include \masm32\include\masm32.inc

include \masm32\include\debug.inc

; підключення службових бібліотек

includelib \masm32\lib\kernel32.lib

includelib \masm32\lib\masm32.lib

includelib \masm32\lib\debug.lib

; оголошення масиву даних

.data

Arr  dd 4,8,5,6,10,7

var_c dd 2

var_d dd 3

var_K dd 3

Sum dd 0

.code

start:

    mov ecx,6

    mov edx,0

     mov eax,3

     mul var_d

     PrintDec eax,"Tob bound"

     mov var_d,eax

     mov eax,2

     mul var_c

     PrintDec eax,"Bottom bound"

     mov var_c,eax

     mov ebx,var_K

     PrintDec ebx,"K"

     

checking:

     cmp ebx,0                     ; перевірка чи K!=0

     jz exit

     mov eax,[Arr+edx*4]

     PrintDec eax,"Arr value"

     cmp eax,var_c                     ; перевірка чи не менше С

     jb  again                ; пропуск даного числа масиву ,оскільки

     cmp eax,var_d             ; перевірка чи не більше d

     ja  again

     add Sum, eax

     dec ebx

     PrintDec Sum, "Sum"

     

again:

     inc edx

     dec ecx

     cmp ecx,0

     jnz checking

exit:     

invoke ExitProcess, NULL ; виклик процедури завершення процесу

end start

Рис. 1

Висновок : в дані лабораторні роботі я ознайомився з програмування з використанням 32 розрядного асемблера, виконавши задачу завдання, в якому необхідно було знайти суму елементів масиву за певною умовою.


 

А также другие работы, которые могут Вас заинтересовать

47564. Понятие предмет и метод экономического анализа 47 KB
  Методом ЭА является системное комплексное изучение, измерение и обобщение влияние факторов на результаты деятельности предприятия путем обработки специальными приемами системных показателей, плана, учета, отчетности и других источников информации с целью повышения эффективности производства.
47566. Методические указания. Менеджмент организаций 156.5 KB
  Лобачевского МЕТОДИЧЕСКИЕ УКАЗАНИЯ по выполнению дипломной работы студентами всех форм обучения по специальности Менеджмент организации Нижний Новгород 2008 Методические указания по выполнению дипломной работы студентами всех форм обучения по специальности Менеджмент организаций. Методические указания содержат рекомендации по выполнению дипломной работы...
47567. Экономика и организация отрасли. Методические указания 560 KB
  На основе данных из справочника Госкомстата Торговля в России заполните приведенные ниже таблицы и сделайте вывод о вкладе торговли в российскую экономику. вес в общем объеме Таблица 10 Экономическая ситуация и ее изменение в организациях торговли Розничная торговля Оптовая торговля 2005 2008 2009 2010 2005 2008 2009 2010 Экономическая ситуация Благоприятная Удовлетворительная Неблагоприятная Баланс оценок Изменение экономической ситуации Улучшение Без изменений Ухудшение Баланс оценок Семинар 3. Структура торговой отрасли Тест по ГОСТам в...
47568. ЗАДАНИЯ И МЕТОДИЧЕСКИЕ УКАЗАНИЯ. ЭЛЕКТРИЧЕСКИЕ СЕТИ И СИСТЕМЫ 1.02 MB
  Задания и методические указания для выполнения курсового проекта по дисциплине Электрические сети и системы ГОС – 2000. Морозова Введение Основная цель выполнения курсового проекта по дисциплине Электрические системы и сети заключается в понимании и усвоении принципов проектирования сетей электрических систем методов расчета и анализа их установившихся режимов.1 Содержание курсового проекта Для заданного варианта расположения и мощности потребителей выбрать схему развития районной электрической сети при соблюдении...
47569. Методические рекомендации. Финансы и кредит 229 KB
  Учет и операционная деятельность в банках для специальности Учет и операционная деятельность в банках для специальности Тема 2 Особенности организации проведения операций банка с собственными векселями Уставный капитал банка его структура функции и порядок отражения в бухгалтерском учете
47570. Методичні рекомендації. Правознавство 280 KB
  Особлива увага присвячена вибору теми дослідження роботі з джерелами та літературою побудові структури та оформленню роботи підготовці до попереднього захисту та захисту магістерської роботи в Державній екзаменаційній комісії. Методичні рекомендації містять пояснювальну записку основні етапи виконання магістерської роботи правила оформлення та захисту магістерської роботи додатки а також список літератури. Головною метою даних методичних рекомендацій є надання допомоги студентудипломнику у вирішенні поставленних завдань щодо...
47572. Методические рекомендации по оформлению выпускной квалификационной работы студентов факультета туризма и гостеприимства 163.5 KB
  Структура выпускной квалификационной дипломной работы Структура выпускной квалификационной дипломной работы должна включать следующие основные разделы: титульный лист установленного образца приложение 1 оглавление введение основная часть дветри главы заключение список использованной литературы и источников приложения. Оглавление в дипломе курсовой реферате и других работах представляет собой перечень разделов работы с указанием страниц на которых они расположены. По правилам оформления оглавление содержание...