MC_knlAlloc 또는 MC_knlCalloc 으로 할당된 메모리를 MC_knlFree 로 해제 했다고 해서 완전히 해제되는 것이 아니며 MC_knlGetFreeMemory 를 호출하여 컴팩션을 해주어야 한다. 이 때 동적 할당된 메모리의 포인터가 바뀔 수 있으므로 할당된 메모리 포인터 이용시 MC_GETPTR 을 이용하여 다시 포인터를 얻어야 한다.

* 도움될만한 퍼온글 (www.mobilejava.com WIPI-C 게시판)

Q1. WIPI에서 Memory Compaction을 지원합니다. 이 COMPACTION이 Fragmentation을 줄이기 위한 일반 정렬 수준인지 아니면 정말 메모리를 절약할 수 있는 압축기술을 쓰는 것인지 궁 금합니다. 메모리가 정말 압축 될 것이라고 생각하기는 힘든데 혹시나 해서 여쭤봅니다.

A1. 제가 보기에는 WIPI에서 지원하는 Compaction은 Fragmentation을 줄이기 위한것 같네요. 여지껏 메모리를 압축하는것은 엄청난 기술이며... 여지껏 경험을 못해봤기 때문입니다. 그리고 압축하는거라면 거기에 따른 프로세싱 타임이 있어서 약간의 작업시간이 걸릴듯 하구요. 어쨌든 압축을 하기 위해 작업중에는 또 다른 공간이 필요함으로서 메모리를 더 쓰면 썼지... 절약은 되지 않는다고 봅니다... 다만 작업완료후에는 엄청나게 줄어들겠죠... 이래저래 디코딩이나 인코딩 하기 위해서는 추가 메모리 영역 사용 및 작업시간으로 손해를 보게 되는군요. 답변은 No입니다.

Q2. 수시로 Memory Compaction이 일어난다면 메모리 번지를 리턴받은 후 재사용할 때는 문제가 생길 수 있는건가요? 예를 들면 어플 초기화 단계에서 gLCDFrameBuffer = (WORD*)MC_GRP_GET_FRAME_BUFFER_POINTER(g_GrpFrameBuffer); 와 같이 gLCDFrameBuffer에 포인터를 리턴 받았다고 했을 때 일정 루틴을 실행 한 다음 gLCDFrameBuffer 값을 그대로 사용하면 Compaction으로 인한 메모리 주소가 변경이 생겨 심각한 문제가 생길 수 있는가 하는 것이지요. 만약 그렇다면 항상 MC_GRP_GET_FRAME_BUFFER_POINTER(g_GrpFrameBuffer); 이렇게 포인터를 받아 와야 하는 것인가요? 물론 Memory Compaction 기능이 지원되지만 수시로 이루어 지는 것이 아니라 개발자가 직접 명령을 내리는 것이라면 다르겠지만요.

A2. 사용자가 원하는 메모리 영역이 확보되어있다고 하지만 메모리가 Fragmentation 되어있다면... 메모리 할당은 이루어지지 않습니다. 이러한 상황을 해결하기 위한것이 Compaction 입니다. 이미 할당해 놓은 메모리 영역이 있음에도 불구하고 Compaction이 발생되게 되면 일단 미리 지정해놓은 메모리 포인터는 변경이 됩니다. 그리고 Compaction은 수시로 발생이 되나 발생되는 시점이 한정되어져 있습니다. 메모리 할당이라든지 메모리 재할당 등등... 대체적으로 메모리 사용 관련과 연관이 있죠. 그러기에 이부분에서만 실수를 안하시면 그렇게 문제는 안될것 같네요. 그리고 MC_knlCalloc 같은 메모리 할당을 했을시 넘어오는 ID값을 잘 생각하셔야 합니다. WIPI에서는 메모리 할당을 했을시 넘어오는 값이 포인터가 아닌 ID값이죠. 내부적으로 메모리 관리자가 있는듯 하구요. 거기에서 ID값에 맞는 포인터 값을 관리합니다. 그리고 메모리 할당을 한 포인터로 접근할시에 MC_GETDPTR 를 사용하여 ID값 전달후 넘어오는 포인터로 접근해서 사용하시면 될듯합니다. 그냥 메모리 포인터만으로 사용하시면 Compaction 이 발생한후에는 보관중이 포인터가 변경이 되기전 포인터이기에 다른 메모리영역 violation이 일어나게 됩니다. 그리고 내부적으로 Compaction은 자주 발생이 되며, 사용자가 MC_knlCalloc 하기전 메모리 영역이 확보가 되기 위한 작업으로 직접 Compaction을 내릴수 있습니다. MC_knlGetFreeMemory를 사용하여 메모리 할당전에 미리 Compaction을 발생시키는 거죠. 그러므로 사용자가 항상 Compaction이 일어났는지는 알길이 없다는겁니다. 그러기에 항상 포인터에 접근하실려면 Helper 함수를 통해 포인터를 매번 구해오셔야 합니다. 답변은 Yes입니다.

Posted by 창신다이
BLOG main image
오랫동안 꿈을 그리는 사람은 마침내 그 꿈을 닮아 간다. -앙드레 말로- by 창신다이

공지사항

카테고리

분류 전체보기 (248)
공장이야기 (115)
Education (30)
회사이야기 (19)
일상 (73)

최근에 올라온 글

최근에 달린 댓글

최근에 받은 트랙백

Total :
Today : Yesterday :