ArchiSys/TP/TP3/main.s

67 lines
989 B
ArmAsm
Raw Normal View History

2024-05-24 22:44:43 +02:00
! This programs checks if a number n>1 is prime
! it checks for divisors from 2 to n-1, but does not terminate if n=1
_EXIT = 1
_WRITE = 4
_STDOUT = 1
.SECT .TEXT
start:
MOV BX,37 ! hardcoded number to check
CALL check_prime
PUSH 2
PUSH _EXIT
SYS
! n is loaded from BX
check_prime:
MOV CX,2 ! number to start at for primality check
l: CMP CX,BX
JE end_is_prime ! if CX=BX, exit, n is prime
! operate division (DX/CX) <=> (num/current)
XOR DX,DX ! will store remainder
MOV AX,BX
DIV CX
CMP DX,0 ! check if CX divides BX
JE end_is_not_prime
INC CX ! continue loop
JMP l
end_is_prime:
PUSH 6
PUSH is_prime
PUSH _STDOUT
PUSH _WRITE
SYS
SUB SP,8
PUSH 0
PUSH _EXIT
SYS
end_is_not_prime:
PUSH 10
PUSH not_prime
PUSH _STDOUT
PUSH _WRITE
SYS
SUB SP,8
PUSH 1
PUSH _EXIT
SYS
.SECT .DATA
is_prime:
.ASCII "prime\n"
not_prime:
.ASCII "not prime\n"
.SECT .BSS