معجم التجميع:
المصرف: هو برنامج يقوم بتحويل كود مصدري (ملف نصي، أما
للتجميع، فالملف يكون ذو توسع .asm) إلى كود الآلة، يعني خلق ملف ثنائي
(ملف ذو توسع .obj أو .exe أو .com).
الست عشري (Hexadecimal): في
نظام العد المتداول بين الناس، نستعمل الأرقام العربية، والمحصورة بين 0
والـ 9، إذن ما مجموعه 10 أرقام، والرقم الأكبر هو 9 (10-1). نقول إذن عن
هذا النظام أنه نظام عشري decimal. فالعدد 451 يمكننا تفكيكه على شكل:
( 4×100) + (5×10) + (1×1)= 4×10 2 + 5×10 1 + 1×10 0.
النظام
الست عشري ينتهي عند 16، والسبب الذي دفع إلى ذلك هو تمثيل النظام الثنائي
بأقل عدد ممكن من الأرقام. فكما نعلم جميعا، فالنظام الثنائي يتكون من
رقمين فقط، وهما الـ 0 والـ 1، ولتكوين أي رقم آخر، فإننا نكتب متوالية من
الأصفار والوحدات على شاكلة 01101001 وهذا الرقم يمثل 105 في نظام عدنا
الذي نستعمله يوميا، ولكن لتمثيل أعداد كبيرة نحتاج إلى أصفار ووحدات
كثيرة، مما يسبب العديد من الأخطاء ويضيع الوقت، ويعقد الفهم، لهذا جاء
دور النظام الست عشري ليحل الإشكال، ويعوض كل أربعة أرقام ثنائية برقم ست
عشري واحد.
01101001 = 1001 و 0110 = 9 و 6 = 69 في النظام الست عشري.
النظام
الست عشري يبدأ من الـ 0 وينتهي عند الـ 15، ولكن الأرقام الستة الأخيرة
(من 10 إلى 15) تتكون من وحدتين، وهذا ما سيخلط الأمور، لهذا تم تعويضها
بحروف، كما يشير الجدول الآتي إلى ذلك:
النظام الست عشري
النظام الثماني
النظام الثنائي
النظام العشري
0
1
2
3
4
5
6
7
8
9
0
1
2
3
4
5
6
7
10
11
0
1
10
11
100
101
110
111
1000
1001
0
1
2
3
4
5
6
7
8
9
A
B
C
D
E
F
12
13
14
15
16
17
1010
1011
1100
1101
1110
1111
10
11
12
13
14
15
ملاحظة: يشار للرقم في النظام الست عشري بعدة رموز:
ففي
لغة السي نشير إلى الرقم بالسابقة 0x، أما في لغة الباسكال، فيسبق الرقم
رمز الدولار، وفي لغة التجميع يشار إلى الرقم أنه ست عشري من خلال اللاحقة
h
Ox14 في لغة السي = $14 في لغة الباسكال = 14h في لغة التجميع.
ملاحظة: لغويا، العدد هو الكتابة الحرفية للرقم، والرقم هو الكتابة الرمزية للعدد.
البايت
(Byte): البايت هو متوالية من ثمانية بتات (8 bits)، فإذا كان البايت
مرمّزا (signed) فإنه يمكنه أخذ قيمة محصورة بين –128 و +127 (128= 2 8-1
= 2 7 ، و127= 2 (8-1)-1)، إذن تحتل القيم المحصورة 7 بتات فقط، والبت
الأخير يستخدم للإشارة (السلب أو الإيجاب)، إما إذا كان البايت غير مرمّز
فإنه بإمكانه أخذ قيمة محصورة بين 0 و 255، أي 256 حالة = 2 8.
الكلمة (Word): بما أن البايت يشغل 8 بتات، فإن الكلمة تشغل 16 بتا، وبالتالي يمكن القول أن الكلمة تحوي 2 بايت.
إذا
كانت الكلمة مرمزة، فإنها قادرة على احتواء قيمة محصورة بين –32768 أي (2
15)، و 32767 أي (2 15 - 1)، أما إذا كانت غير مرمزة، فالقيمة المحتواة
تكون محصورة بين 0 و65535 (2 16 -1).
الكلمة المضاعفة (Double Word
أو DWord) : وتشغل الكلمة من هذا النوع قيم ذات 4 بايت. إذن إذا كانت
مرمزة، فإنها تكون بين –2147483648 أي (2 31)، و +2147483647 (2 31 –1)،
أما إذا كانت غير مرمزة، فبإمكانها حصر قيمة تتراوح بين 0 و 4294967295.
السجل
(Register): هو فراغ ذاكري موجود بصفة فيزيائية في قلب المعالج
(Processor)، والذي تحفظ فيه القيم أثناء معالجتها. في البداية كانت
السجلات تعمل على ثمانية بتات (بايت واحد)، وكانت تسمى آنذاك ?L (حيث يمكن
للرمز " ?" أن يكون A أو B أو C أو D)، ثم تطورت السجلات إلى 16 بت
(كلمة)، وصارت مسماة بـ ?X، الشيء العجيب في هذا، هو أننا لو قمنا بتغيير
قيمة ?L فإننا نكون بذلك قد غيرنا الجزء المنخفض من السجل ?X. بمعنى آخر،
?X مكون من بايت ومن ?L (ويقال أيضا من جزء مرتفع وجزء منخفض). ثم بعد
وصول معالجات 386، تم الانتقال إلى سجلات 32 بت، وصارت بالتالي تسمى بـ E
?X، وهنا إذا ما قمنا بتغيير قيمة ?L أو ?X فإننا نكون بذلك قد قمنا
بتغيير الجزء E ?X.
السجلات القاعدية هي السجلات AX، BX، CX و
DX، وهي سجلات ذات 16 بت (= 2 بايت)، وأجزاءها المنخفضة (Low) هي AL، BL،
CL و DL أما أجزاءها المرتفعة (High) فهي AH، BH، CH و DH.
إذا كان
AX معدوما (null)، فهذا يعني أن AL =0 و AH =0 أيضا. وإذا ما قمنا بغيير
قيمة AX فإننا نغير قيمتي AH و AL معا، أما لو قمنا بتغيير قيمة AL فهذا
يعني أن قيمة AX تغيرت أما قيمة AH فمازالت كما هي. (الرسم السابق يوضح
الصورة أكثر).
لنلاحظ هذا المثال:
al = 15
ah = 10
=> ax = al + ah*256 = 15 + 10*256 = 2575
لمزيد من التفاصيل راجع قائمة السجلات.
القطاع
والفرع (Segment & Offset): العناوين الذاكرية (مواقع البايتات على
صفائح الذاكرة) هي معرفة بسجّلين، القطاع (الجزء المرتفع من العنوان)،
وبالفرع (الجزء المنخفض من العنوان). نشير أن العنوان يحدد بـ Segment
:[Offset] (حيث أن النقطتين ":" هما الفاصل، في حين يعتبر المجالان "]" و
"[" غير إجباريين). مثال: DS :[DI]
مع وصول الـ 386، تطورت الفروع
إلى 32 بت، من أجل الوصول إلى أقصى الذاكرة (16 ميغا بايت)، وظهرت بذلك
الفروع بالسابقة E، مثل (ESI, EDI, ESP, EBP)، هذا بالنسبة لسجلات 32 بت،
ونفس الشيء كان مع سجلات 16 بت، حيث كانت الفروع SI, DI, SP, SB. لمزيد من
التفاصيل، راجع قائمة السجلات.
المقاطعة (Interruption): يمكن وصف
المقاطعة على أنها برنامج صغير مخزّن في الذاكرة، ويتم طلبه عدة مرات
لأداء مهمة محدّدة ، وبوثيرة متزايدة أو متناقصة. يوجد على الأكثر 256
مقاطعة، فالأولى منها مدمجة في البيوس (BIOS، وهو برنامج ينفذ عند تشغيل
الحاسب، والذي يسيّر العتاد: القرص الصلب، الوصول إلى الذاكرة ...)، مثل
مقاطعات بطاقة الفيديو ولوحة المفاتيح.
بعض المقاطعات يتم طلبها
بوثيرة ثابتة: المقاطعة 1Ch مثلا والتي هي عدّاد يزيد في القيمة 18.6
مرة/ثانية (أي يضيف 1 للقيمة المعنية). البعض الآخر يتم طلبه فقط في حالة
ما إذا أردناها: المقاطعة 09h الخاصة بلوحة المفاتيح، يتم طلبها في كل مرة
يقوم المستخدم بالضغط على زر ما أو عند تحريره.
المكدس (Stack): في
المكدس نقوم بإضافة القيم بفضل التعليمة PUSH، ونقوم بحذفها من خلال
التعليمة POP. في قمّة المكدس نجد قيمة السجل [E]BP. ويمكننا بذلك معرفة
ما هو موجود في الطابق X من خلال التعليمة "mov AX, [Bp-4]"، ولكن ليس
لحذف هذه القيمة، لأننا لو قمنا بحذف قيمة من وسط المكدس، فإن هذه الأخيرة
تتقهقر، وهذا ما يؤدي إلى توقف الحاسب عن العمل.
الراية (Flag): الرايات هي بتات موجودة بداخل المعالج. راجع قائمة الرايات.