×
Crocus
공부한 내용을 정리하는 블로그로 시작한
Crocus는 2014년 1월 14일 부터 시작하여
현재 월 6만명, 총 2,101,745명의 방문자 수를 기록하고 있습니다.
Donation
이제 많은 사용자들이 이용하는 만큼
더 다양한 서비스 개발/제공을 위해 후원금을 모금하고자 합니다.
후원을 해주시는 분들은 Donators 명단에 성명, 후원금을 기입해드리며
Crocus 블로그가 아닌 다른 곳에 정리해둔 저만의 내용을 공유해 드리고자 합니다.
Account
예금주 : 고관우
신한은행 : 110-334-866541
카카오뱅크 : 3333-01-7888060

👉 후원 페이지 바로가기 Donators
익명 : 5000원(Crocus응원합니다.)
busyhuman: 5000원(유용한 지식 감사합니다.)
익명 : 5000원(알고리즘 학습러)
반응형
Mips 어셈블리어로 factorial을 제작하는 코드이다.

Mips 코딩을 하는 동안에는 항상 asm코드 이전에 c코드로 어떻게 구상하는지 주석처리로 공개할 예정이다.

이 코드는 j 명령어로 이루어진 코드이다.(j명령어는 goto함수와 같다.)

# #include <stdio.h>


# int factorial(int i)

# {

#  if(i == 1)

#  {

#   return 1;

#  }


#  else if( i != 1 )

#  {

#   return i*factorial(i-1)

#  }


# }


# int main()

# {

#  int i;

#  int ans; 


#  scanf("%d",&i);


#  if(i == 0)

#  {

#   printf("%d",1);

#  }


#  ans = factorial(i);

#  printf("%d",ans);


# }




.text

.globl main


main:           # $t0 : i , $t1 : temp, $t2 : ans , $t7 : 1(0,1팩토리얼을 위한 값)

li $t7,1           # $t7에 1대입

li $t2,1            # $t2에 1대입


li $v0,5           # scanf 준비

syscall

move $t0,$v0     # $v0값을 $t0로 저장 


beq $t0,0,return0     # 0이면 return0으로

j return1           # 그게 아니면 return1로


return0:           # 1일때 결과 출력하는곳


li $v0,1           # print준비

move $a0,$t7     # $t7(1)값을 $a0로 저장

syscall

return1:

beq $t0,1,return0    # 1이면 return0으로


                      # 아래 코드는 2이상만 취급


mul $t2,$t2,$t0  # $t2에 $t2*$t0을 한것을 넣는다.


sub $t0,$t0,1  # $t0 = $t0 - 1


beq $t0,1,return2  # 여기서 $t0가 1이되면 return2로

j return1


return2:

li $v0,1          # print준비

move $a0,$t2   # $t7(1)값을 $a0로 저장

syscall

반응형