แอสเซมบลี - รีจิสเตอร์
การทำงานของโปรเซสเซอร์ส่วนใหญ่เกี่ยวข้องกับการประมวลผลข้อมูล ข้อมูลนี้สามารถเก็บไว้ในหน่วยความจำและเข้าถึงได้จากที่นั่น อย่างไรก็ตามการอ่านข้อมูลจากและจัดเก็บข้อมูลลงในหน่วยความจำจะทำให้โปรเซสเซอร์ช้าลงเนื่องจากเกี่ยวข้องกับกระบวนการที่ซับซ้อนในการส่งคำขอข้อมูลผ่านบัสควบคุมและไปยังหน่วยเก็บข้อมูลหน่วยความจำและรับข้อมูลผ่านช่องทางเดียวกัน
เพื่อเพิ่มความเร็วในการทำงานของโปรเซสเซอร์โปรเซสเซอร์จะมีที่เก็บหน่วยความจำภายในที่เรียกว่า registers.
รีจิสเตอร์เก็บองค์ประกอบข้อมูลสำหรับการประมวลผลโดยไม่ต้องเข้าถึงหน่วยความจำ ชิปประมวลผลมีการลงทะเบียนจำนวน จำกัด
รีจิสเตอร์โปรเซสเซอร์
มีการลงทะเบียนโปรเซสเซอร์ 32 บิตและ 16 บิตหกตัวในสถาปัตยกรรม IA-32 การลงทะเบียนแบ่งออกเป็นสามประเภท -
- ทะเบียนทั่วไป
- ทะเบียนควบคุมและ
- การลงทะเบียนกลุ่ม
การลงทะเบียนทั่วไปแบ่งออกเป็นกลุ่มต่อไปนี้ -
- การลงทะเบียนข้อมูล
- ตัวชี้ลงทะเบียนและ
- ดัชนีรีจิสเตอร์
รีจิสเตอร์ข้อมูล
การลงทะเบียนข้อมูล 32 บิตสี่ตัวใช้สำหรับการคำนวณทางคณิตศาสตร์ตรรกะและการดำเนินการอื่น ๆ การลงทะเบียน 32 บิตเหล่านี้สามารถใช้ได้สามวิธี -
ตามการลงทะเบียนข้อมูล 32 บิตที่สมบูรณ์: EAX, EBX, ECX, EDX
ครึ่งล่างของรีจิสเตอร์ 32 บิตสามารถใช้เป็นรีจิสเตอร์ข้อมูล 16 บิตสี่ตัว ได้แก่ AX, BX, CX และ DX
ครึ่งล่างและสูงกว่าของรีจิสเตอร์ 16 บิตสี่ตัวที่กล่าวถึงข้างต้นสามารถใช้เป็นรีจิสเตอร์ข้อมูล 8 บิต 8 ตัว: AH, AL, BH, BL, CH, CL, DH และ DL
การลงทะเบียนข้อมูลเหล่านี้บางส่วนมีการใช้งานเฉพาะในการคำนวณทางคณิตศาสตร์
AX is the primary accumulator; ใช้ในอินพุต / เอาต์พุตและคำแนะนำทางคณิตศาสตร์ส่วนใหญ่ ตัวอย่างเช่นในการดำเนินการคูณตัวถูกดำเนินการหนึ่งตัวถูกเก็บไว้ในทะเบียน EAX หรือ AX หรือ AL ตามขนาดของตัวถูกดำเนินการ
BX is known as the base registerเนื่องจากสามารถใช้ในการจัดทำดัชนีแอดเดรส
CX is known as the count registerในฐานะที่เป็น ECX CX จะบันทึกการนับลูปในการดำเนินการซ้ำ
DX is known as the data register. นอกจากนี้ยังใช้ในการดำเนินการอินพุต / เอาต์พุต นอกจากนี้ยังใช้กับการลงทะเบียน AX พร้อมกับ DX สำหรับการคูณและหารการดำเนินการที่เกี่ยวข้องกับค่าขนาดใหญ่
ตัวชี้รีจิสเตอร์
ตัวชี้รีจิสเตอร์คือรีจิสเตอร์ EIP, ESP และ EBP แบบ 32 บิตและส่วน IP, SP และ BP ที่เหมาะสม 16 บิต พอยน์เตอร์รีจิสเตอร์มีสามประเภท -
Instruction Pointer (IP)- การลงทะเบียน IP 16 บิตจะเก็บที่อยู่ออฟเซ็ตของคำสั่งถัดไปที่จะดำเนินการ IP ที่เชื่อมโยงกับทะเบียน CS (เป็น CS: IP) ให้ที่อยู่ที่สมบูรณ์ของคำสั่งปัจจุบันในส่วนรหัส
Stack Pointer (SP)- การลงทะเบียน SP 16 บิตให้ค่าออฟเซ็ตภายในสแตกโปรแกรม SP ที่เชื่อมโยงกับ SS register (SS: SP) หมายถึงตำแหน่งปัจจุบันของข้อมูลหรือแอดเดรสภายในสแตกโปรแกรม
Base Pointer (BP)- การลงทะเบียน BP 16 บิตส่วนใหญ่ช่วยในการอ้างอิงตัวแปรพารามิเตอร์ที่ส่งผ่านไปยังรูทีนย่อย ที่อยู่ใน SS register จะรวมกับค่าชดเชยใน BP เพื่อรับตำแหน่งของพารามิเตอร์ BP ยังสามารถใช้ร่วมกับ DI และ SI เป็นทะเบียนฐานสำหรับการระบุแอดเดรสพิเศษ
ดัชนีรีจิสเตอร์
ดัชนี 32 บิตลงทะเบียน ESI และ EDI และส่วนขวาสุด 16 บิต SI และ DI ใช้สำหรับการกำหนดแอดเดรสที่จัดทำดัชนีและบางครั้งใช้ในการบวกและการลบ ตัวชี้ดัชนีมีสองชุด -
Source Index (SI) - ใช้เป็นดัชนีต้นทางสำหรับการดำเนินการสตริง
Destination Index (DI) - ใช้เป็นดัชนีปลายทางสำหรับการดำเนินการสตริง
รีจิสเตอร์ควบคุม
การลงทะเบียนตัวชี้คำสั่ง 32 บิตและการลงทะเบียนแฟล็ก 32 บิตรวมกันถือเป็นการลงทะเบียนควบคุม
คำสั่งจำนวนมากเกี่ยวข้องกับการเปรียบเทียบและการคำนวณทางคณิตศาสตร์และเปลี่ยนสถานะของแฟล็กและคำแนะนำตามเงื่อนไขอื่น ๆ จะทดสอบค่าของแฟล็กสถานะเหล่านี้เพื่อนำโฟลว์การควบคุมไปยังตำแหน่งอื่น
แฟล็กบิตทั่วไปคือ:
Overflow Flag (OF) - แสดงถึงการล้นของบิตลำดับสูง (บิตซ้ายสุด) ของข้อมูลหลังจากการดำเนินการทางคณิตศาสตร์ที่ลงนาม
Direction Flag (DF)- กำหนดทิศทางซ้ายหรือขวาสำหรับการย้ายหรือเปรียบเทียบข้อมูลสตริง เมื่อค่า DF เป็น 0 การดำเนินการสตริงจะใช้ทิศทางซ้ายไปขวาและเมื่อตั้งค่าเป็น 1 การดำเนินการสตริงจะใช้ทิศทางจากขวาไปซ้าย
Interrupt Flag (IF)- กำหนดว่าการขัดจังหวะภายนอกเช่นรายการแป้นพิมพ์ ฯลฯ จะถูกละเว้นหรือประมวลผล ปิดใช้งานการขัดจังหวะภายนอกเมื่อค่าเป็น 0 และเปิดใช้งานการขัดจังหวะเมื่อตั้งค่าเป็น 1
Trap Flag (TF)- อนุญาตให้ตั้งค่าการทำงานของโปรเซสเซอร์ในโหมดขั้นตอนเดียว โปรแกรมดีบักที่เราใช้ตั้งค่าแฟล็กกับดักดังนั้นเราจึงสามารถดำเนินการทีละคำสั่งได้
Sign Flag (SF)- แสดงสัญลักษณ์ของผลลัพธ์ของการดำเนินการทางคณิตศาสตร์ แฟล็กนี้ถูกตั้งค่าตามสัญลักษณ์ของรายการข้อมูลหลังจากการดำเนินการทางคณิตศาสตร์ เครื่องหมายถูกระบุโดยลำดับสูงของบิตซ้ายสุด ผลลัพธ์ที่เป็นบวกจะล้างค่าของ SF เป็น 0 และผลลัพธ์ที่เป็นลบจะตั้งค่าเป็น 1
Zero Flag (ZF)- บ่งชี้ผลลัพธ์ของการคำนวณทางคณิตศาสตร์หรือการเปรียบเทียบ ผลลัพธ์ที่ไม่ใช่ศูนย์จะล้างแฟล็กศูนย์เป็น 0 และผลลัพธ์ที่เป็นศูนย์จะตั้งค่าเป็น 1
Auxiliary Carry Flag (AF)- มีการดำเนินการจากบิต 3 ถึงบิต 4 หลังจากการดำเนินการทางคณิตศาสตร์ ใช้สำหรับการคำนวณเฉพาะทาง AF ถูกตั้งค่าเมื่อการดำเนินการทางคณิตศาสตร์ 1 ไบต์ทำให้การดำเนินการจากบิต 3 เป็นบิต 4
Parity Flag (PF)- ระบุจำนวน 1 บิตทั้งหมดในผลลัพธ์ที่ได้จากการคำนวณทางคณิตศาสตร์ จำนวนคู่ของ 1 บิตจะล้างแฟล็กพาริตีเป็น 0 และจำนวนคี่ของ 1 บิตตั้งค่าแฟล็กพาริตีเป็น 1
Carry Flag (CF)- มีการดำเนินการ 0 หรือ 1 จากบิตลำดับสูง (ซ้ายสุด) หลังจากการดำเนินการทางคณิตศาสตร์ นอกจากนี้ยังเก็บเนื้อหาของการดำเนินการกะหรือหมุนครั้งสุดท้าย
ตารางต่อไปนี้ระบุตำแหน่งของแฟล็กบิตในการลงทะเบียนแฟล็ก 16 บิต:
ธง: | โอ | ง | ผม | ที | ส | Z | ก | ป | ค | |||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
บิตไม่: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
ส่วนรีจิสเตอร์
เซ็กเมนต์คือพื้นที่เฉพาะที่กำหนดไว้ในโปรแกรมสำหรับบรรจุข้อมูลโค้ดและสแต็ก มีสามส่วนหลัก -
Code Segment- มีคำแนะนำทั้งหมดที่จะดำเนินการ การลงทะเบียนกลุ่มรหัส 16 บิตหรือทะเบียน CS จะเก็บที่อยู่เริ่มต้นของส่วนรหัส
Data Segment- ประกอบด้วยข้อมูลค่าคงที่และพื้นที่ทำงาน การลงทะเบียนกลุ่มข้อมูล 16 บิตหรือการลงทะเบียน DS เก็บที่อยู่เริ่มต้นของส่วนข้อมูล
Stack Segment- ประกอบด้วยข้อมูลและที่อยู่ที่ส่งคืนของโพรซีเดอร์หรือรูทีนย่อย มันถูกนำไปใช้เป็นโครงสร้างข้อมูล 'สแตก' การลงทะเบียนกลุ่มสแตกหรือทะเบียน SS เก็บที่อยู่เริ่มต้นของสแต็ก
นอกเหนือจากการลงทะเบียน DS, CS และ SS แล้วยังมีการลงทะเบียนเซ็กเมนต์พิเศษอื่น ๆ - ES (เซ็กเมนต์พิเศษ), FS และ GS ซึ่งมีเซ็กเมนต์เพิ่มเติมสำหรับการจัดเก็บข้อมูล
ในการเขียนโปรแกรมแอสเซมบลีโปรแกรมจำเป็นต้องเข้าถึงตำแหน่งหน่วยความจำ ตำแหน่งหน่วยความจำทั้งหมดภายในเซ็กเมนต์สัมพันธ์กับที่อยู่เริ่มต้นของเซ็กเมนต์ เซ็กเมนต์เริ่มต้นด้วยแอดเดรสที่หารด้วย 16 หรือเลขฐานสิบหก 10 เท่า ๆ กันดังนั้นเลขฐานสิบหกขวาสุดในที่อยู่หน่วยความจำทั้งหมดจะเป็น 0 ซึ่งโดยทั่วไปจะไม่ถูกเก็บไว้ในการลงทะเบียนเซ็กเมนต์
เซ็กเมนต์ลงทะเบียนเก็บที่อยู่เริ่มต้นของเซ็กเมนต์ ในการรับตำแหน่งที่แน่นอนของข้อมูลหรือคำสั่งภายในเซ็กเมนต์จำเป็นต้องมีค่าออฟเซ็ต (หรือการกระจัด) ในการอ้างอิงตำแหน่งหน่วยความจำใด ๆ ในเซ็กเมนต์โปรเซสเซอร์จะรวมแอดเดรสเซ็กเมนต์ในการลงทะเบียนเซ็กเมนต์กับค่าออฟเซ็ตของตำแหน่ง
ตัวอย่าง
ดูโปรแกรมง่ายๆต่อไปนี้เพื่อทำความเข้าใจการใช้รีจิสเตอร์ในการเขียนโปรแกรมแอสเซมบลี โปรแกรมนี้แสดงดาว 9 ดวงบนหน้าจอพร้อมกับข้อความง่ายๆ -
section .text
global _start ;must be declared for linker (gcc)
_start: ;tell linker entry point
mov edx,len ;message length
mov ecx,msg ;message to write
mov ebx,1 ;file descriptor (stdout)
mov eax,4 ;system call number (sys_write)
int 0x80 ;call kernel
mov edx,9 ;message length
mov ecx,s2 ;message to write
mov ebx,1 ;file descriptor (stdout)
mov eax,4 ;system call number (sys_write)
int 0x80 ;call kernel
mov eax,1 ;system call number (sys_exit)
int 0x80 ;call kernel
section .data
msg db 'Displaying 9 stars',0xa ;a message
len equ $ - msg ;length of message
s2 times 9 db '*'
เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานโค้ดจะได้ผลลัพธ์ดังนี้ -
Displaying 9 stars
*********