upx 패킹한 파일을 분석해보자.

   

패킹된 파일의 EP 포인트 지점에서는 ESI 레지수터에 두번째 섹션 시작 주소를, 그리고 EDI레지스터에는 첫번째 섹션 시작 주소를 세팅한다.

   

   

Source(ESI)로부터 데이터를 읽어 압축 해제 Destination(EDI) 저장시킬 것이다. 그러므로 UPX EP 코드를 전부 트레이싱하면 OEP 찾을 있다.

   

중요한 루프 #1

   

EDX에서 바이트를 읽어 EDI 쓰는 것이다. EDI레지스터가 가리키는 주소는 번째 섹션의 시작 주소이며, 메모리에서만 존재하는 섹션이다(내용은 전부 NULL).

   

   

중요한 루프 #2

   

본격적인 디코딩 루프로, ESI가 가리키는 두 번째 섹션의 주소에서 차례대로 값을 읽어서 적절한 연산을 거쳐 압축을 해제하여 EDI 가리키는 번째 섹션의 주소에 값을 써준다.

   

   

중요한 루프 #3

   

원본 코드의 CALL/JMP명령어의 destination 주소를 복원시켜주는 코드이다.

   

   

중요한 루프 #4

   

IAT 세팅하는 루프이다. EDI 두번째 섹션 영역으로 세팅된다. 이곳에는 원본 notepad.exe에서 사용되는 API 이름 문자열이 저장되어 있다. 과정을 이름 문자열이 끝날 때까지 반복하면 원본 notepad.exe IAT 복원 과정이 마무리된다.

   

   

upx패커의 특징 하나는 EP코드가 PUSHAD/POPAD명령어로 둘러싸여 있다는 것이다. OEP코드로 가는 JMP명령어가 POPAD명령어 바로 이후에 나타나므로 JMP명령어에 BP 설치하고 실행하면 바로 OEP 있다.

   

   

'리버싱' 카테고리의 다른 글

개요  (0) 2016.09.20
어셈블리 정리  (1) 2016.09.20

리버스 엔지니어링이란 물건이나 기계장치 혹은 시스템 등의 구조, 기능, 동작 등을 분석하여

원리를 이해하며 단점을 보완하고 새로운 아이디어를 추가하는 작업.

   

리버싱 방법

   

1.정적 분석

파일의 겉모습을 관찰하여 분석하는 방법. 정적 분석의 단계에서는 파일을 실행하지 않고 종류, 크기, 헤더정보, Import/Export API, 내부 문자열, 실행 압축 여부, 등록 정보, 디버깅 정보, 디지털 인증서 등의 다양한 내용을 확인하는 것. 그리고 디스어셈블러를 이용하여 내부 코드와 그 구조를 확인하는 것.

2.동적 분석

파일을 직접 실행시켜 행위를 분석하고, 디버깅을 통하여 코드 흐름과 메모리 상태 등을 자세히 살펴보는 방법. 파일, 레지스트리, 네트워크 등을 관찰하면서 프로그램의 행위를 분석. 또한 디버거를 이용하여 프로그램 내부 구조와 동작 원리를 분석.

   

가지 방법을 활용하면 프로그램을 리버싱할 시간을 많이 단축시킬 있고, 효과적인 분석이 가능.

   

 

함수 호출 규약

   

caller - 함수를 호출하는

callee - 호출 받는쪽

   

1.cdecl

함수를 호출한 쪽이 stack 정리

2.stdcall

호출을 당한 쪽이 stack 정리

3.fastcall

   

 

   

참고 - http://www.slideshare.net/H4C/ss-59722847

   

 

   

 

   

   

'리버싱' 카테고리의 다른 글

패킹  (0) 2016.09.23
어셈블리 정리  (1) 2016.09.20

CMP TEST 다른

   

CMP 첫번째 operand에서 번째 Operand 뺀다. 연산의 결과는 operand 값이 변경되지 않고 EFLAGS 레지스터만 변경된다. ( operand 값이 동일하다면 SUB 결과는 0이고 ZF=1. SUB 명령과 동일하나 SUB operand 값이 변경됨.)

   

TEST 번째 operand 번째 operand AND연산 시킨다. 연산의 결과는 ZF에만 영향을 미치고 operand에는 영향을 미치지 않는다.

   

개의 다른 점은 operand 비교하는 방식이다. CMP 숫자를 빼서 비교하고, TEST AND연산을 시켜서 비교한다. 이로 인해 CMP operand 완전히 같은지 비교할 있고 TEST operand 모두 0인지 아닌지 판단할 있다. TEST 경우 operand 0 아닌 경우를 제외하고 서로 다른 값일지라도 연산 결과가 0 나올 있으므로 TEST eax,eax 같이 대상의 값이 0 아닌지 확인하는 용도로 사용된다.

   

   

mov lea 다른

   

mov 좌변에 우변의 값을 대입한다.

   

lea 좌변(레지스터만 가능) 우변의 주소값을 대입한다.

   

   

조건 점프문

   

   

   

PUSHAD - 8개의 범용 레지스터의 값을 스택에 저장하는 명령

   

POPAD - PUSHAD 명령에 의해서 스택에 저장된 값을 다시 레지스터들에게 입력하는 명령

'리버싱' 카테고리의 다른 글

패킹  (0) 2016.09.23
개요  (0) 2016.09.20

+ Recent posts