Microsoft MVP성태의 닷넷 이야기
mips 어셈블리 연산 다시 질문드려요 (첨부파일 갱신됨) [링크 복사], [링크+제목 복사],
조회: 6265
글쓴 사람
ocm
홈페이지
첨부 파일

안녕하세요 정성태님 저는 이전 글을 쓴 학생입니다. 약간 헷갈리는부분이 있어 질문드립니다. 제가 첨부한 파일이 컴퓨터구조 책에 있는 내용인데요. 레지스터 변수를 sw를 통해 스택에 레지스터 값을 할당한 다음 lw를 하지 않고 바로 산술연산을 한다음에 lw를 통해 스택에 할당된 공간을 원상복구하는 예제입니다.
이해가 안되는 부분은 레지스터 변수에 sw를 한 다음 바로 그 변수들을 통해 어떻게 산술연산이 가능한지의 부분인데요. 이게 어떤 이유에서 가능한지가 궁금해요...
그래서 제가 추측한 바로는 sw를 하면 스택(메모리)에 레지스터 변수 값을 할당한 다음에 연산을 할 때 스택에서 필요할 때 lw도 없이 자동으로 스택에서 꺼내서 쓰는것인지?
아니면 레지스터 변수가 sw를 하면 레지스터 값을 스택으로 이동시키는 게 아니라 레지스터 값을 복사해서 스택에 저장을 함으로써 레지스터 값은 레지스터에도 존재하고 메모리에도 값이 존재함으로 연산이 가능한 걸까요? 그런데 밑에 경우는 레지스터 변수 개수가 초과되는 문제를 해결하지는 못할 것 같습니다. 왜냐면 레지스터 변수 값을 넣을 공간이 없어서 스택에 할당하는걸로 알고있는데 레지스터 변수 값을 복사해서 레지스터에도 값이 있고 스택에도 값이 있으면 레지스터 크기 부족은 여전할거 같아서입니다.








[최초 등록일: ]
[최종 수정일: 6/15/2021]


비밀번호

댓글 작성자
 



2021-06-15 01시57분
이전의 글에도 답변을 더 했으니 그것도 참고하시고.

위의 답변을 드리자면, 레지스터 값을 스택에도 복사해 저장하는 것이 맞습니다. 그리고, 레지스터 변수 개수가 초과되는 문제를 해결합니다. 왜냐하면 (예를 들어 $a1) 레지스터 값을 스택에 넣어두었으면 $a1 레지스터를 다른 변수를 담는 용도로 쓸 수 있기 때문입니다. 이후, $a1의 이전 값이 필요하면 스택으로부터 $a1에 lw로 복원해 사용하면 그만입니다.
정성태
2021-06-15 01시59분
[ocm] 정말 감사합니다!!!
[guest]

... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
4749강준8/11/201612452ElementHost Memory Leak 현상 [6]
4748Bere...8/3/201611323그냥 생각이 들어서 여기 글 써봅니다. [1]
4746힘찬도약8/2/201611603[asp.net] local에서 cookies값이 읽혀지지 않는 경우 [1]
4747힘찬도약8/3/201612337    답변글 [예제 첨부]: [asp.net] local에서 cookies값이 읽혀지지 않는 경우 [3]파일 다운로드1
4745힘찬도약7/27/201612423.NET 자식창 데이터를 부모창에 전달시 오류 질문드립니다. [4]파일 다운로드1
4744변찬연7/27/201612140안녕하세요 그 edge를 이용하는 데 조금 불편함이 있어서 문의드립니다 [1]
4743딸랑구아빠7/26/201611153IE 사용 시 인증 정보 계속 보내기? [1]
4741차가워7/20/201612829UWP 에서 COM 참조 불가능한가요? [6]
4740luna...7/19/201613253clickonce manifest 파일 질문 [1]
4739윤똘씨7/19/201612689정말 감동적입니다... [7]
4738닷넷초보7/7/201611580안녕하세요. C#의 개체 전달방식(참조)에 관련해서 질문 있습니다. [3]파일 다운로드1
4737beau...7/6/201613889python embedding 한 c++ 프로그램의 배포에 관해서 질문드리고 싶습니다. [1]
4736spow...7/6/201610745Property Lambda에 대한 심층 분석을 의뢰합니다 [7]
4735힘찬도약7/5/201611897.Net/Web.config에서 MSSQL을 쓰는데, MysqlSiteMap 참조오류 [3]파일 다운로드1
4734spow...6/28/201611510Visual Studio 2015 + Windows Forms 환경에서 컴파일 할 때 드물게 개발환경이 Crash 됩니다 [1]
4733feel...6/15/201611949타 서버로 소스 이전 중 [3]파일 다운로드1
4732구봉근6/14/201610704안녕하세요 [1]파일 다운로드1
4731초급개발자6/7/201613203Windows Form Application는 사라질까요? [2]
4730김시현6/4/201611256책으로 공부하던 도중 생성자에 대해서 궁금한게 생겼는데 혹시 답변좀 해주실수 있나요? [1]
4729Jeah...6/3/201612721C#.Net 프로그램에서 C++로 만들어진 dll 파일 이용관련 문의 하나 드립니다. [3]
4727링거5/30/201611389WPF MediaElement 파일 실행 후 삭제시 오류 문의 [1]파일 다운로드1
4728링거5/30/201611757    답변글 [답변]: WPF MediaElement 파일 실행 후 삭제시 오류 문의 [2]파일 다운로드1
4726spow...5/25/201611178덧글을 달고 나서 F5를 눌렀을 때 똑같은 덧글이 달리는 현상 고쳐주세요 [4]
4725Futu...5/23/201611639책 잘보고 있습니다. Task관련 질문을!!! [1]
4724학생15/23/201612937웹소켓과 소켓 관련해서 질문 드립니다. [2]
4722지나가던...5/15/201614744Part 3 pdf파일 그림 재수정 문의 [1]
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...