[완료]커널(어셈블) 초보 effective address 및 배열에 대한 질문이요 ^^*
공부하다가 궁금한게 있어 질문드립니다..^^
소스는 다음과 같습니다.
mov eax, [CurrentTask] ; Task Struct의 리스트를 만든다.
add eax, TaskList
lea edx, [User1regs]
mov [eax], edx
add eax, 4
lea edx, [User2regs]
mov [eax], edx
add eax, 4
lea edx, [User3regs]
mov [eax], edx
add eax, 4
lea edx, [User4regs]
mov [eax], edx
add eax, 4
lea edx, [User5regs]
mov [eax], edx
mov eax, [CurrentTask] ; 첫 번째 Task를 선택한다. (CurrentTask = 0)
add eax, TaskList
mov ebx, [eax]
jmp sched
CurrentTask dd 0 ; 현재 실행 중인 태스크 번호
NumTask dd 20 ; 모든 태스크의 수
TaskList: times 5 dd 0 ; 각 태스크 저장영역의 포인터 배열
이 소스는 TaskList에 각각의 유저 영역 태스크가 사용하는 레지스터 저장 영역과 포인터를 넣어주는데,
32비트 포인터이므로 저장 후 4를 더하여 다음 포인터를 저장한다고 합니다.
그런데 이 과정이 잘 이해가 되지 않네요. 어떤식으로 배열을 사용한 것인지..ㅜㅜ
그리고 하나 더 질문이 있는데요.
mov eax, [CurrentTask]
lea edx, [User1regs]
[ ]가 들어가면 effective address를 불러 온다고 알고 있는데
lea 는 Load Effective Address명령어로 같은 역할을 수행하는것 같습니다.
이 차이가 먼지.. 확실히 개념이 안잡히네요 ㅠㅠ
조언 부탁드립니다..
즐거운 하루 되시길요 ^^
답변이 될지는 모르겠지만.
우선 C에서 "int name[10];" 과 같은 배열선언은 10개의 int형 변수를 저장할 수 있는 메모리 공간을 확보하죠. 그리고 변수명 name은 그 확보한 메모리 공간의 시작 주소를 가리키고요.
위의 어셈코드 중 "TaskList: times 5 dd 0"는 C에서 "int TaskList[5];"와 같은 코드가 되겠죠. TaskList는 레이블이니 역시 메모리 주소를 나타내고요. 그리고 4byte(32bit)를 더한다는 것은 배열내에서 다음 번째 항목(?)으로 포인트를 이동시키는 것이고요. 즉 C에서 배열포인터를 어셈에서는 그런 방식으로 사용합니다.
- 배열포인터 강좌
http://winapi.co.kr/clec/cpp1/11-3-1.htm
두번째 질문에서
mov eax, [CurrentTask] -> CurrentTask의 메모리 주소에 있는 "값"을 가져오게 됩니다. 즉, eax = 0
lea edx, [User1regs] -> User1regs의 메모리 "주소"를 가져옵니다. 즉, edx = User1regs의 어드레스
- effective address
http://courses.ece.uiuc.edu/ece390/books/labmanual/nasm-effaddr.html
http://cafe.naver.com/cheatenginekorea.cafe?iframe_url=/ArticleRead.nhn%3Farticleid=2125
촌놈.
lea 명령을 쓰면 []에
lea 명령을 쓰면 []에 들어간 레지스터 조합 등을 고려해서 계산된 주소가 dest. 레지스터에 들어옵니다.
단지 계산만 해줍니다. (메모리 액세스는 일어나지 않음).
mov 명령에 쓰이는 []는 바로 메모리 주소가 됩니다. mov명령에서 그 메모리 주소로 접근해서
값을 가져옵니다.
실제 하드웨어는 이 차이라고 보시면 됩니다.
그리고 어셈블리에서는 배열이란 개념은 생각 안 하는게 좋습니다. 특히 2, 3차원 배열까지
변수나 특정 변수 뭉텅이(C언어라면 구조체가 되겠죠)를 메모리상에 일률적으로
나열하면 그게 배열입니다.
타 언어에서는 배열에 속한 요소를 인덱스번호로 접근하면 되지만(C조차도)
어셈블리에서는 배열에 속한 요소의 주소를 알아낸 뒤 그 주소에 접근합니다.
배열에 속한 요소의 주소를 알아내서 접근하는거는 뭐 어렵지 않습니다. 메모리상에 알률적으로
나열했기 때문에 배열 요소에 배열크기*인덱스를 더하면 금방 나오니까요.
Written By the Black Knight of Destruction
Written By the Black Knight of Destruction
답변 정말정말 감사드립니다..^^
답변 정말정말 감사드립니다..^^
어렵네요..ㅜㅠ 열심히 공부 해야겠습니다 ㅋ
아.글구 namhw 님... 블로그 방명록에 글 남겨 놓았습니다..^^살짝 한번 읽어보세요~ 스팸 아니니깐요 ㅋ
댓글 달기