기본 콘텐츠로 건너뛰기

Dalvik VM: Precise GC or Conservative GC ?

Dalvik VM이 garbage collection을 하는 과정 중 모든 thread의 stack frame을 뒤져서 레지스터가 가리키는 객체들을 marking한다. (marking한다는 것은 이 객체가 살아있으므로 GC하지 않겠다라고 표시하는 것이라고 알아두자. 더 자세한 내용은 추후 다른 글에서 다루어보도록 하자)

위 그림을 보면서 이해해보도록 하자. Thread는 curFrame에 현재 stack frame 주소를 가지고 있다. stack frame은 register 값들을 저장하고 있는데 위 그림에서는 rvalue라고 표현하고 있다. 레지스터는 object에 대한 reference를 가지고 있을 수 있다. 이 경우 해당 object는 현재 사용되고 있는 것이므로 GC 과정에 없어지지 않도록 살아있음을 표시하는 marking을 한다. 이 그림에서는 object에 직접 marking하는 것으로 표현하고 있지만 실제로는 HeapBitmap이라고 하는 bit vector에 marking한다.

Register에 저장된 값이 object에 대한 reference인지 아니면 다른 값 (예를 들면, 상수 값) 인지 어떻게 판단할 수 있을까? 이 판단 방법에 따라 Precise GC 혹은 Conservative GC의 구분이 이루어진다.

Precise GC란 어떤 방법에 의해서든 object에 대한 reference 값을 정확하게 파악하여 잘못된 marking이 이루어지지 않게 하는 방법이다. 이와 달리 Conservative GC는 레지스터의 값의 패턴을 대충 파악하여 이 값이 object reference로 판단할만하면 marking하는 방식이다. 그러므로, 레지스터 값이 object에 대한 reference가 아닌데도 잘못 marking하는 경우가 생길 수 있다.


Dalvik VM은 위 코드와 같이 register의 값(rval)이 0이 아니고 하위 2 bits의 값이 0이면 이를 object에 대한 reference로 가정하고 marking을 시도한다. 이런 방식으로 동작해도 실제 GC 과정에는 별로 문제가 없다고 한다. 물론, 잘못된 영역을 marking해서 쓰레기로 처리되어야 할 object가 살아남는 경우도 발생할 수 있지만 별로 문제시 삼지않는다. (Android Platform Group에서 논의된 내용을 참고하시길)

현재 최신 버전의 Dalvik VM은 precise GC도 지원하는 것으로 보인다. 이를 위해 code verification 과정 중에 RegisterMap이라는 정보를 만들어낸다. RegisterMap은 method가 실행 시 특정 시점에 레지스터가 가진 값이 object에 대한 reference인지 나타내는 비트 값을 가진다. (Java의 StackMap과 유사한 개념이다.) 간단한 예를 들어보자.

int i = 10;
int a = i + 10; // (1) 0 0 0 0 0 0 0 0

SomeObject p = new SomeObject ();
callSomeMethod(p); // (2) 1 0 0 0 0 0 0 0

위와 같은 코드가 현재 callSomeMethod(p)까지 실행 중이다. 레지스터는 8개가 있다고 가정하자. (1)번 주석은 해당 라인의 코드가 실행될 때의 RegisterMap 값이다. 모든 비트가 0으로 이 stack frame의 레지스터 값은 object에 대한 reference가 하나도 없음을 알 수 있다. (2)번 주석의 경우는 1개의 비트가 1로 첫 번째 레지스터의 값이 object에 대한 reference임을 알 수 있다.

이처럼 precise GC를 처리하면 실행 성능에는 큰 차이가 없으나 엉뚱한 object를 marking하는 문제를 없앨 수 있다. 또한, compaction과 같은 발전된 GC 기능을 구현하기 위해서는 꼭 구현되어야 할 기능이다. 하지만, RegisterMap 정보를 추가적으로 만들어내므로 DEX 파일의 크기가 약 9% 정도 커지므로 주의하도록 한다.

Dalvik VM을 실행 시 -Xgenregmap 옵션을 지정해주면 code verification 과정 중에 dvmGenerateRegisterMapV 함수를 호출하여 RegisterMap을 생성한다.

참고자료:

댓글

이 블로그의 인기 게시물

Wireless: HotSpot 2.0 이란?

스마트폰 사용자가 HotSpot 2.0을 지원하는 Wi-Fi 망을 사용하는 경우라면 기존 Wi-Fi 망과 달리 이동통신 망에서 Wi-Fi 망으로의 네트워크 연결 전환이 자연스럽게 이루어진다. 예를 들면, 3G 네트워크를 이용하여 영화를 보고 있다가 HotSpot 2.0 네트워크에 연결이 가능하게 되면 영화 시청 중단 없이 Wi-Fi 망으로 자연스럽게 네트워크 연결이 이동하여 3G 망의 부하도 줄이고 사용자의 네트워크 비용도 절약할 수 있다. 시스코에서 제공한 White Paper 를 참고.

Apple M1 Mac Mini에서 이더리움 (Ethereum) 채굴하기

 돈을 벌 목적은 아니고 이더리움 기술에 대한 호기심에 직접 채굴(마이닝)에 나서 보기로 했다. 머신은 Apple M1 Mac Mini. 스팩을 살펴보니 8 Core GPU에 16GB 메모리를 공유하고 있어 가능은 해보인다. 큰 흐름은 다음과 같다. 채굴한 이더리움을 저장할 지갑을 만든다 만든 지갑의 정보를 잘 보관해둔다 (Secret Recovery Phrase, 지갑의 주소 값) Apple M1용 채굴 프로그램 설치 내 지갑 정보를 이용해서 채굴 프로그램 실행 일단, 채굴한 이더리움을 저장할 지갑(wallet)을 만들어야 한다.  크롬 브라우저 익스텐션 설치로 비교적 간단하게 지갑을 만들 수 있는  https://metamask.io/ 를 이용하기로 했다. 크롬 익스텐션을 설치 후 기존에 만든 지갑이 없으므로 "Create a Wallet"을 선택한다. 패스워드 입력하고 등등의 절차를 거치면 아래와 같은 Secret Recovery Phrase가 나온다. 이 값을 잘 보관해두기 바란다. 나중에 지갑을 복구할 때 필요한 값이다. 이 값이 유출되면 지갑에 모아둔 이더리움을 다 털릴 수 있으므로 안전한 곳에 보관한다. Confirm Your Secret Phrase에서 확인 과정을 거친다. 직접 입력하는 것이 아니라 단어 별 버튼을 일일이 클릭해서 확인해주어야 한다. (좀 번거롭지만 그만큼 Secret Recovery Phrase가 중요함을 인지시키기 위한 과정이다.) 이제 지갑은 준비 완료. 생성된 Account 화면에서 지갑의 주소갑을 얻을 수 있다.  Apple M1용 채굴 프로그램을 설치해보자. Ethminer M1 Github 프로젝트 에서 미리 컴파일된 바이너리를 다운로드 받는다. (Assets를 펼치고 ethminer-m1을 클릭해서 다운 받으면 된다) 원하는 폴더에 파일을 옮겨 놓고 Terminal에서 chmod +x로 실행가능하게 만든다. % mv ~/Downloads/ethminer-m1 .             %   % c

Java: Java for Game? Java가 Game 개발에 어울릴까?

Java가 기업용 서버 소프트웨어 개발에 활발하게 쓰이는 것과 달리 일반 응용프로그램 분야에서는 별로 대접을 받지 못하는 현실을 개선하려면 어떤 분야부터 손보면 좋을까? 로딩타임, 성능, 사용자 인터페이스 등 Java를 이용한 클라이언트 프로그램을 개발하지 않는 이유들은 개발자 별로 서로 다를 것이다. 하지만, 이런 단점에도 불구하고 점점 복잡해지는 소프트웨어를 더 쉽게 다양한 환경에서 동작하도록 만들기 위해서는 Java만큼 이미 성숙한 해결책도 없지 않은가? 클라이언트 개발을 활성화하기 위해 Java를 게임 개발에 활용할 수 있도록 지원하면 어떨까? 역시, 사용자가 직접 쓰는 응용프로그램 중에는 게임이 가장 시장이 큰 분야이니 말이다. 그렇다면, 현재 게임 개발에 Java가 어느 정도 사용되고 있고 미래에 더 활성화 될 가능성은 있을 것인가? 이런 의문점을 가지고 "Java + Game"에 대해 조사해보기로 했다. 1. Java로 개발한 게임들 우선, Java로 개발한 게임들에 대해 살펴보자. Oracle의  Java in Action 웹페이지 를 보면 Java를 이용한 3D MMORPG RuneScape 에 대한 설명이 있다. 가입자가 1억 3000만명이 넘는다고 하다. 실제 게임을 설치해서 실행해보니 WOW같은 화려한 그래픽에는 못미치치만 잘만든 Role Playing 게임이다 Puppy Games 에서 개발한  Revenge of the Titans 게임도 눈여겨 볼 만하다. 이 회사는 작고 손쉽게 즐길 수 있는 게임을 개발하는데 모든 게임을 Java로 만든다. Revenge of the Titans는 Starcraft와 같은 전략 게임으로 너무 머리쓰지 않고 즐길 수 있는 게임이며 그래픽도 신선하다. 개발이 진행 중인 것으로 보이는 Urban Galaxy 라는 게임도 재미있을 것 같다. SF 영화를 보면 자주 등장하는 미래의 빌딩 숲을 날아다니는 자동차로 전투도 치르고 무역도 하며 캐릭터를 키우는 게임으로