기타
[MIPS] Pipeline Hazard 종류 / Structure / Data / Control
서상혁
2019. 12. 1. 15:36
Hazard 란
pipeline 형식에서 어떠한 문제가 발생해서 다음 사이클의 다음 명령을 실행할 수 없는 경우를 뜻한다.
Structure Hazard
물리적인 원인에 의하여 발생하는 hazard 로, 메모리를 1개만 쓴다던지 포트가 하나라던지 하는 이유로 발생한다. 1개의 메모리로 읽고 쓰는 게 동시에 진행되려할 때 발생한다.
해결방법 :
1. 메모리 수를 늘린다. (물리적으로 하드웨어를 추가해준다.)
2. 해당 기능 사용 가능한 시점까지 지연시킨다.
Data Hazard
Instruction 의 식 실행을 위해 필요한 데이터가 아직 만들어지지 않은 경우!
해결방법 :
1. 계산되자마자 MEM 과 WB를 거지 않고 바로 결과값을 넘겨준다. (Forwarding or Bypassing)
2. 소프트웨어적으로 코드순서를 재배열해준다. code scheduling
Control Hazard
다음 instruction 의 부정확함에 의해 발생한다. 주로 branch outcome 이 나오지 않은 상황으로 인해 발생한다.
beq 조건 에서 True 인경우 beq 바로 밑에 나오는 명령들과 beq 로 인해 branch 되는 명령과 겹친다.
해결방법 :
728x90