-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfpu_fxam.asm
81 lines (65 loc) · 2.69 KB
/
fpu_fxam.asm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
;-----------------------------------------------------------------------------
; Precteni stavoveho slova matematickeho koprocesoru
;
; Tento demonstracni priklad je pouzity v serialu o programovani
; grafickych dem a her na PC v DOSu:
; https://www.root.cz/serialy/vyvoj-her-a-grafickych-dem-pro-platformu-pc/
;
; Clanek, kde je tento demonstracni priklad pouzit:
; Matematické koprocesory na platformě x86: vše se komplikuje
; https://www.root.cz/clanky/matematicke-koprocesory-na-platforme-x86-vse-se-komplikuje/
;
;-----------------------------------------------------------------------------
BITS 16 ; 16bitovy vystup pro DOS
;-----------------------------------------------------------------------------
org 0x100 ; zacatek kodu pro programy typu COM (vzdy se zacina na 256)
start:
jmp main ; skok na zacatek kodu
%include "io.asm" ; nacist symboly, makra a podprogramy
%include "print.asm" ; nacist symboly, makra a podprogramy
main:
fninit ; inicializace koprocesoru
fldz ; uložení konstanty 0 na zásobník
fxam
call print_status_word ; tisk stavového slova
fninit ; inicializace koprocesoru
fld1 ; uložení konstanty 1 na zásobník
fxam
call print_status_word ; tisk stavového slova
fninit ; inicializace koprocesoru
fldpi ; uložení konstanty Pi na zásobník
fxam
call print_status_word ; tisk stavového slova
fninit ; inicializace koprocesoru
fld1
fchs ; změna znaménka původní konstanty 1
fxam
call print_status_word ; tisk stavového slova
fninit ; inicializace koprocesoru
fld1
fldz
fdiv ; podíl 1/0
fxam
call print_status_word ; tisk stavového slova
fninit ; inicializace koprocesoru
fldz
fldz
fdiv ; podíl 0/0
fxam
call print_status_word ; tisk stavového slova
fninit ; inicializace koprocesoru
fld1
fchs ; změna znaménka
fsqrt ; odmocnina z -1
fxam
call print_status_word ; tisk stavového slova
wait_key ; cekani na klavesu
exit ; navrat do DOSu
;-----------------------------------------------------------------------------
print_status_word:
fnstsw word [test_word] ; ulozeni stavoveho slova
mov ax, word [test_word]
print_hex_16 ax ; tisk stavoveho slova v hexadecimalnim formatu
ret
; datova cast
test_word: dw 0