section .data
rmodemsg db 10,'Processor is in Real Mode'
rmsg_len:equ $-rmodemsg
pmodemsg db 10,'Processor is in Protected Mode'
pmsg_len:equ $-pmodemsg
gdtmsg db 10,'GDT Contents are::'
gmsg_len:equ $-gdtmsg
ldtmsg db 10,'LDT Contents are::'
lmsg_len:equ $-ldtmsg
idtmsg db 10,'IDT Contents are::'
imsg_len:equ $-idtmsg
trmsg db 10,'Task Register Contents are::'
tmsg_len: equ $-trmsg
mswmsg db 10,'Machine Status Word::'
mmsg_len:equ $-mswmsg
colmsg db ':'
nwline db 10
;-------------------------.bss section------------------------------
section .bss
gdt resd 1
resw 1
ldt resw 1
idt resd 1
resw 1
tr resw 1
cr0_data resd 1
dnum_buff resb 04
%macro print 2
mov rax,01
mov rdi,01
mov rsi,%1
mov rdx,%2
syscall
%endmacro
;------------------------.text section -----------------------------
section .text
global _start
_start:
smsw eax ;Reading CR0. As MSW is 32-bit cannot use RAX register.
mov [cr0_data],rax
bt rax,1 ;Checking PE bit, if 1=Protected Mode, else Real Mode
jc prmode
print rmodemsg,rmsg_len
jmp nxt1
prmode: print pmodemsg,pmsg_len
nxt1: sgdt [gdt]
sldt [ldt]
sidt [idt]
str [tr]
print gdtmsg,gmsg_len
mov bx,[gdt+4]
call print_num
mov bx,[gdt+2]
call print_num
print colmsg,1
mov bx,[gdt]
call print_num
print ldtmsg,lmsg_len
mov bx,[ldt]
call print_num
print idtmsg,imsg_len
mov bx,[idt+4]
call print_num
mov bx,[idt+2]
call print_num
print colmsg,1
mov bx,[idt]
call print_num
print trmsg,tmsg_len
mov bx,[tr]
call print_num
print mswmsg,mmsg_len
mov bx,[cr0_data+2]
call print_num
mov bx,[cr0_data]
call print_num
print nwline,1
xor rdi,rdi
syscall
print_num:
mov rsi,dnum_buff ;point esi to buffer
mov rcx,04 ;load number of digits to printlay
up1:
rol bx,4 ;rotate number left by four bits
mov dl,bl ;move lower byte in dl
and dl,0fh ;mask upper digit of byte in dl
add dl,30h ;add 30h to calculate ASCII code
cmp dl,39h ;compare with 39h
jbe skip1 ;if less than 39h skip adding 07 more
add dl,07h ;else add 07
skip1:
mov [rsi],dl ;store ASCII code in buffer
inc rsi ;point to next byte
loop up1 ;decrement the count of digits to printlay
;if not zero jump to repeat
print dnum_buff,4 ;printlay the number from buffer
ret
c2VjdGlvbiAuZGF0YQoJcm1vZGVtc2cgZGIgMTAsJ1Byb2Nlc3NvciBpcyBpbiBSZWFsIE1vZGUnCglybXNnX2xlbjplcXUgJC1ybW9kZW1zZwoKCXBtb2RlbXNnIGRiIDEwLCdQcm9jZXNzb3IgaXMgaW4gUHJvdGVjdGVkIE1vZGUnCglwbXNnX2xlbjplcXUgJC1wbW9kZW1zZwoKCWdkdG1zZyBkYiAxMCwnR0RUIENvbnRlbnRzIGFyZTo6JwoJZ21zZ19sZW46ZXF1ICQtZ2R0bXNnCgoJbGR0bXNnIGRiIDEwLCdMRFQgQ29udGVudHMgYXJlOjonCglsbXNnX2xlbjplcXUgJC1sZHRtc2cKCglpZHRtc2cgZGIgMTAsJ0lEVCBDb250ZW50cyBhcmU6OicKCWltc2dfbGVuOmVxdSAkLWlkdG1zZwoKCXRybXNnIGRiIDEwLCdUYXNrIFJlZ2lzdGVyIENvbnRlbnRzIGFyZTo6JyAgCgl0bXNnX2xlbjogZXF1ICQtdHJtc2cKCgltc3dtc2cgZGIgMTAsJ01hY2hpbmUgU3RhdHVzIFdvcmQ6OicKCW1tc2dfbGVuOmVxdSAkLW1zd21zZwoKCWNvbG1zZyBkYiAnOicKCglud2xpbmUgZGIgMTAKOy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0uYnNzIHNlY3Rpb24tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc2VjdGlvbiAuYnNzCglnZHQgcmVzZCAxCgkgICAgcmVzdyAxCglsZHQgcmVzdyAxCglpZHQgcmVzZCAxCgkgICAgcmVzdyAxCgl0ciAgcmVzdyAxCgoJY3IwX2RhdGEgcmVzZCAxCgoJZG51bV9idWZmIHJlc2IgMDQKCiVtYWNybyBwcmludCAyCgltb3YgcmF4LDAxCgltb3YgcmRpLDAxCgltb3YgcnNpLCUxCgltb3YgcmR4LCUyCglzeXNjYWxsCiVlbmRtYWNybwoKOy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS50ZXh0IHNlY3Rpb24gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0Kc2VjdGlvbiAudGV4dApnbG9iYWwgX3N0YXJ0Cl9zdGFydDoJCglzbXN3IGVheAkJO1JlYWRpbmcgQ1IwLiBBcyBNU1cgaXMgMzItYml0IGNhbm5vdCB1c2UgUkFYIHJlZ2lzdGVyLiAKCgltb3YgW2NyMF9kYXRhXSxyYXgKCglidCByYXgsMQkJO0NoZWNraW5nIFBFIGJpdCwgaWYgMT1Qcm90ZWN0ZWQgTW9kZSwgZWxzZSBSZWFsIE1vZGUKCWpjIHBybW9kZQoJcHJpbnQgcm1vZGVtc2cscm1zZ19sZW4KCWptcCBueHQxCgpwcm1vZGU6CXByaW50IHBtb2RlbXNnLHBtc2dfbGVuCgpueHQxOglzZ2R0IFtnZHRdCglzbGR0IFtsZHRdCglzaWR0IFtpZHRdCglzdHIgW3RyXQoJcHJpbnQgZ2R0bXNnLGdtc2dfbGVuCgkKCW1vdiBieCxbZ2R0KzRdCgljYWxsIHByaW50X251bQoKCW1vdiBieCxbZ2R0KzJdCgljYWxsIHByaW50X251bQoKCXByaW50IGNvbG1zZywxCgoJbW92IGJ4LFtnZHRdCgljYWxsIHByaW50X251bQoKCXByaW50IGxkdG1zZyxsbXNnX2xlbgoJbW92IGJ4LFtsZHRdCgljYWxsIHByaW50X251bQoKCXByaW50IGlkdG1zZyxpbXNnX2xlbgoJCgltb3YgYngsW2lkdCs0XQoJY2FsbCBwcmludF9udW0KCgltb3YgYngsW2lkdCsyXQoJY2FsbCBwcmludF9udW0KCglwcmludCBjb2xtc2csMQoKCW1vdiBieCxbaWR0XQoJY2FsbCBwcmludF9udW0KCglwcmludCB0cm1zZyx0bXNnX2xlbgoJCgltb3YgYngsW3RyXQoJY2FsbCBwcmludF9udW0KCglwcmludCBtc3dtc2csbW1zZ19sZW4KCQoJbW92IGJ4LFtjcjBfZGF0YSsyXQoJY2FsbCBwcmludF9udW0KCgltb3YgYngsW2NyMF9kYXRhXQoJY2FsbCBwcmludF9udW0KCglwcmludCBud2xpbmUsMQoKZXhpdDoJbW92IHJheCw2MAoJeG9yIHJkaSxyZGkKCXN5c2NhbGwKCnByaW50X251bToKCW1vdiByc2ksZG51bV9idWZmCTtwb2ludCBlc2kgdG8gYnVmZmVyCgoJbW92IHJjeCwwNAkJO2xvYWQgbnVtYmVyIG9mIGRpZ2l0cyB0byBwcmludGxheSAKCnVwMToKCXJvbCBieCw0CQk7cm90YXRlIG51bWJlciBsZWZ0IGJ5IGZvdXIgYml0cwoJbW92IGRsLGJsCQk7bW92ZSBsb3dlciBieXRlIGluIGRsCglhbmQgZGwsMGZoCQk7bWFzayB1cHBlciBkaWdpdCBvZiBieXRlIGluIGRsCglhZGQgZGwsMzBoCQk7YWRkIDMwaCB0byBjYWxjdWxhdGUgQVNDSUkgY29kZQoJY21wIGRsLDM5aAkJO2NvbXBhcmUgd2l0aCAzOWgKCWpiZSBza2lwMQkJO2lmIGxlc3MgdGhhbiAzOWggc2tpcCBhZGRpbmcgMDcgbW9yZSAKCWFkZCBkbCwwN2gJCTtlbHNlIGFkZCAwNwpza2lwMToKCW1vdiBbcnNpXSxkbAk7c3RvcmUgQVNDSUkgY29kZSBpbiBidWZmZXIKCWluYyByc2kJCQk7cG9pbnQgdG8gbmV4dCBieXRlCglsb29wIHVwMQkJO2RlY3JlbWVudCB0aGUgY291bnQgb2YgZGlnaXRzIHRvIHByaW50bGF5CgkJCQkgICAgO2lmIG5vdCB6ZXJvIGp1bXAgdG8gcmVwZWF0CgoJcHJpbnQgZG51bV9idWZmLDQJO3ByaW50bGF5IHRoZSBudW1iZXIgZnJvbSBidWZmZXIKCQoJcmV0Cgo=