-
Notifications
You must be signed in to change notification settings - Fork 0
/
func.asm
690 lines (591 loc) · 8.85 KB
/
func.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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
.8086
.model small
.stack 100h
.data
.code
public lectura
public atr
public rta
public len
public buscar
public isLet
public isnum
public printNum
public random8
public random16
public randomOp
public generateOp
public multNum
public limpiaString
public play
;IMPORT
extrn delay:proc
;CAJA DE LECTURA DE NUMEROS!!!
;Variable por stack y se devuelve en la variable el input
;Devuelve por ch el signo ingresado (0=+//1=-)
lectura proc
push bp
mov bp, sp
mov si, ss:[bp + 4]
push bx
push ax
;limpio string
push si
call limpiaString
;el si lo popea la funcion
xor cx, cx
xor bx, bx
lect:
;lectura sin eco
mov ah, 08h
int 21h
;compara "-"
cmp al, 2Dh
je sign
;compara enter
cmp al, 0dh
je endlect
cmp al, 08h
je rest
cmp bx, 5
je lect
call isNum
cmp dl, 0
je lect
eco:
mov ah, 02h
mov dl, al
int 21h
mov [si + bx], al
inc bx
jmp lect
sign:
cmp bx, 0
jne lect
cmp cl, 1
je lect
mov ah, 02h
mov dl, 2Dh
int 21h
mov ch, 1
mov cl, 1
jmp lect
rest:
cmp bx, 0
je limpiaSign
mov byte ptr [si + bx], 24h
mov ah, 02h
mov dl, al
int 21h
mov dl, 20h
int 21h
mov dl, 08h
int 21h
dec bx
jmp lect
limpiaSign:
cmp cl, 0
je lect
mov ah, 02h
mov dl, 08h
int 21h
mov dl, 20h
int 21h
mov dl, 08h
int 21h
mov cl, 0
mov ch, 0
jmp lect
endlect:
cmp bx, 0
je lect
lea bx, [si]
push bx
call len
cmp dl, 0
jne isN0
jmp is0
isN0:
cmp dl, 1
je is1
cmp dl, 2
je is2
cmp dl, 3
je is3
cmp dl, 4
je is4
;is5
jmp fin
is4:
mov al, [si + 3]
mov [si + 4], al
mov al, [si + 2]
mov [si + 3], al
mov al, [si + 1]
mov [si + 2], al
mov al, [si]
mov [si + 1], al
mov byte ptr [si], 30h
jmp fin
is3:
;Save number
mov al, [si + 2]
mov [si + 4], al
mov al, [si + 1]
mov [si + 3], al
mov al, [si]
mov [si + 2], al
mov byte ptr [si + 1], 30h
mov byte ptr [si], 30h
jmp fin
is2:
mov al, [si + 1]
mov [si + 4], al
mov al, [si]
mov [si + 3], al
mov byte ptr [si + 2], 30h
mov byte ptr [si + 1], 30h
mov byte ptr [si], 30h
jmp fin
is1:
mov al, [si]
mov [si + 4], al
mov byte ptr [si + 3], 30h
mov byte ptr [si + 2], 30h
mov byte ptr [si + 1], 30h
mov byte ptr [si], 30h
jmp fin
is0:
mov byte ptr [si], 30h
mov byte ptr [si + 1], 30h
mov byte ptr [si + 2], 30h
mov byte ptr [si + 3], 30h
mov byte ptr [si + 4], 30h
jmp fin
fin:
pop ax
pop bx
pop bp
ret 2
lectura endp
;ASCII TO REG
;Devuelve el REG por DI
atr proc
push bp
mov bp, sp
push si
push ax
push cx
mov si, ss:[bp + 4]
;UNIDAD
xor ax, ax
mov al, [si + 4]
sub ax, 30h
mov di, ax
;DECENA
xor ah, ah
mov al, [si + 3]
sub ax, 30h
mov cx, 10
mul cx
add di, ax
;CENTENA
xor ah, ah
mov al, [si + 2]
sub ax, 30h
mov cx, 100
mul cx
add di, ax
;MILENIO
xor ah, ah
mov al, [si + 1]
sub ax, 30h
mov cx, 1000
mul cx
add di, ax
;MIL MILENIO
xor ah, ah
mov al, [si]
sub ax, 30h
mov cx, 10000
mul cx
add di, ax
pop cx
pop ax
pop si
pop bp
ret 2
atr endp
;REG TO ASCII
;Se ingresa primero el ASCII y luego el REG por STACK
rta proc
push bp
mov bp, sp
push ax
push cx
push si
push di
push dx
xor si, si
xor di, di
mov si, ss:[bp + 4] ;REG
mov di, ss:[bp + 6] ;ASCII
mov ax, [si]
add di, 4
mov cx, 5
mov bx, 10
divide:
xor dx, dx
div bx
add dl, 30h
mov [di], dl
dec di
loop divide
pop dx
pop di
pop si
pop cx
pop ax
pop bp
ret 4
rta endp
;.LENGHT
;Parametro por stack devuelve el counter por DL en REG
len proc
push bp
mov bp, sp
push si
push bx
mov si, ss:[bp + 4]
xor dl, dl
xor bx, bx
scan:
cmp byte ptr [si + bx], 24h
je endScan
add dl, 1
inc bx
jmp scan
endScan:
pop bx
pop si
pop bp
ret 2
len endp
;CONTAR UN CARACTER EN UN STRING
;TEXTO POR STACK
;CARACTER A BUSCAR POR DL
;POR CL DEVUELVE LA CANTIDAD
buscar proc
push bp
mov bp, sp
mov si, ss:[bp + 4]
xor bx, bx
busca:
cmp byte ptr [si + bx], 24h
je endBusca
cmp [si + bx], dl ;Se manda el caracter a comparar por dl
je add1
incbx:
inc bx
jmp busca
add1:
add cl, 1
jmp incbx
endBusca:
pop bp
ret 2
buscar endp
;MAYUS MINUS
;se pasa por AL el caracter a buscar
;DL se devuelve 0 para noLetra, 1 para mayus y 2 para minus
isLet proc
push bp
mov bp, sp
push ax
cmp al, 7Ah
ja noLet
cmp al, 41h
jb noLet
cmp al, 41h
jae casiMayus
noLet:
mov dl, 0
jmp endIsLet
casiMayus:
cmp al, 5Ah
jbe mayus
cmp al, 61h
jae minus
jmp noLet
mayus:
mov dl, 1
jmp endIsLet
minus:
mov dl, 2
endIsLet:
pop ax
pop bp
ret
isLet endp
;CHECK IF NUMBER
isNum proc
push bp
mov bp, sp
;RECIVE DATO POR AL
;DEVUELVE en DL 1 si es numero 0 si no
cmp al, 30h
jb notNum
cmp al, 39h
ja notNum
mov dl, 1
jmp finNum
notNum:
mov dl, 0
finNum:
pop bp
ret
isNum endp
;escribe un string de numeros ignorando los ceros a la izquierda
;recibe por stack el offset del string
printNum proc
push bp
mov bp, sp
push ax
push si
push dx
mov si, ss:[bp + 4]
mov al, 0
escritura:
mov dl, [si]
cmp dl, 30h
ja primerNum
sigue1:
cmp dl, 30h
je esCero
sigue2:
mov ah, 02h
int 21h
ceroIzq:
inc si
cmp byte ptr [si], 24h
je fuera
jmp escritura
primerNum:
mov al, 1
jmp sigue1
esCero:
cmp al, 0
je ceroIzq
jmp sigue2
fuera:
cmp al, 0
je todo0
jmp termina
todo0:
mov dl, 30h
mov ah, 02h
int 21h
termina:
pop dx
pop si
pop ax
pop bp
ret 2
printNum endp
;Devuelve random num por AX de 8 bits
random8 proc
push bp
mov bp, sp
mov ah, 00h
int 1Ah
mov ax, dx
mov si, 15
int 81h
mov al, ah
xor ah, ah
mov di, ax
pop bp
ret
random8 endp
random16 proc
push bp
mov bp, sp
mov ah, 00h
int 1Ah
mov ax, dx
mov si, 3
int 81h
mov al, ah
xor ah, ah
mov di, ax
pop bp
ret
random16 endp
randomOp proc
push ax
push di
push si
call random8
cmp ax, 3Fh
jbe suma
cmp ax, 7Fh
jbe resta
cmp ax, 0CFh
jbe multi
;cmp ax, FF Siempre
;mov cl, "/"
;jmp finRandomOp
suma:
mov cl, "+"
jmp finRandomOp
resta:
mov cl, "-"
jmp finRandomOp
multi:
mov cl, "*"
jmp finRandomOp
finRandomOp:
pop si
pop di
pop ax
ret
randomOp endp
;Se ingresan 2 variables y el signo de la primera por stack, hace una operación aleatoria entre ellas
;Devuelve resultado por BX
;Devuelve operación por DL
;Devuelve signo del resultado por DH (1=-//0=+)
generateOp proc
push bp
mov bp, sp
push cx
push ax
push si
push di
mov bx, ss:[bp + 8] ;signo del primer numero
mov si, ss:[bp + 6] ;primer numero
mov di, ss:[bp + 4] ;segundo numero
;Genera operacion aleatoria
;AGREGAR DIVISIÓN
call randomOp
mov dl, cl
xor dh, dh
push dx ;mando operación a stack
cmp cl, "+"
je sumaGeneratedOp
cmp cl, "-"
je restaGeneratedOp
cmp cl, "*"
je multGeneratedOp
sumaGeneratedOp:
mov ax, word ptr[si]
add ax, word ptr[di]
js esNeg
pop dx
jmp endOp
restaGeneratedOp:
mov ax, word ptr[si]
sub ax, word ptr[di]
js esNeg
pop dx
jmp endOp
;Multiplica numeros de 3 digitos
multGeneratedOp:
mov ax, [di]
call multNum
mov [di], ax
mov cx, [si]
mul cx
cmp bx, 1
je esNeg
pop dx
jmp endOp
esNeg:
pop dx
mov dh, 1
endOp:
mov bx, ax
pop di
pop si
pop ax
pop cx
pop bp
ret 6
generateOp endp
multNum proc
push bp
mov bp, sp
cmp ax, 35d
jbe cero
cmp ax, 90d
jbe uno
cmp ax, 145d
jbe dos
cmp ax, 200d
jbe cinco
cmp ax, 255d
jbe diez
cero:
mov ax, 0
jmp endNum
uno:
mov ax, 1
jmp endNum
dos:
mov ax, 2
jmp endNum
cinco:
mov ax, 5
diez:
mov ax, 10
jmp endNum
endNum:
pop bp
ret
multNum endp
limpiaString proc
push bp
mov bp, sp
push bx
mov bx, ss:[bp + 4]
limpia:
cmp byte ptr [bx], 24h
je finLimpia
mov byte ptr [bx], 24h
inc bx
jmp limpia
finLimpia:
pop bx
pop bp
ret 2
limpiaString endp
play proc
play:
push ax
push cx
push bx
mov ax, cx
out 42h, al
mov al, ah
out 42h, al
in al, 61h
or al, 00000011b
out 61h, al
pause1:
mov cx, 65535
pause2:
dec cx
jne pause2
dec bx
jne pause1
in al, 61h
and al, 11111100b
out 61h, al
pop bx
pop cx
pop ax
ret
play endp
winSound proc
winSound endp
;END PROGRAMA
end