티스토리 뷰
Inside CRT: Debug Heap Management
참고 : http://www.codeguru.com/cpp/w-p/win32/tutorials/article.php/c9535
디버깅을 하다가 0xBAADF00D를 보게되었는데,
악성코드 제작자가 나름 의미를 부여해서 이용하는 값으로 생각했다.
그런데, 구글님께 물어보니 이런 정보가 나오네.
RtlHeapAllocate() 함수와 관련된 것으로 보인다.
0xBAADF00D는 아래에 나와있는 것처럼 Alloc 함수(LMEM_FIXED)를 통해 Heap을 생성한 경우에 기본적으로 메모리에 Assign 되어있는 값이다.
아래는 RtlAllocateHeap 을 통해 생성된 메모리 공간이다.
00AB36BC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36CC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36DC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36EC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36FC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB370C 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >............ >
00AB36BC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36CC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36DC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36EC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB36FC 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >.............>
00AB370C 0D F0 AD BA 0D F0 AD BA 0D F0 AD BA >............ >
아래의 표처럼 어떤 방식으로 메모리가 생성되었는지에 따라 버퍼(Heap)의 기본 값이 정해진다. 스택에 대해서는 해당되지 않을 것으로 추정된다.
When you compile a debug build of your program with Visual Studio and run it in debugger, you can see that the memory allocated or deallocated has funny values, such as 0xCDCDCDCD or 0xDDDDDDDD. This is the result of the work Microsoft has put in to detect memory corruption and leaks in the Win32 platform. In this article, I will explain how memory allocation/deallocation is done via new/delete or malloc/free.
First, I will explain what all these values that you see, like CD, DD, and so forth, mean.
Value | Name | Description |
---|---|---|
0xCD | Clean Memory | Allocated memory via malloc or new but never written by the application. |
0xDD | Dead Memory | Memory that has been released with delete or free. It is used to detect writing through dangling pointers. |
0xFD | Fence Memory | Also known as "no mans land." This is used to wrap the allocated memory (like surrounding it with fences) and is used to detect indexing arrays out of bounds. |
0xAB | (Allocated Block?) | Memory allocated by LocalAlloc(). |
0xBAADF00D | Bad Food | Memory allocated by LocalAlloc() with LMEM_FIXED, but not yet written to. |
0xCC | When the code is compiled with the /GZ option, uninitialized variables are automatically assigned to this value (at byte level). |
If you take a look at DBGHEAP.C, you can see how some of these values are defined:
static unsigned char _bNoMansLandFill = 0xFD; /* fill no-man's land with this */
static unsigned char _bDeadLandFill = 0xDD; /* fill free objects with this */
static unsigned char _bCleanLandFill = 0xCD; /* fill new objects with this */
'보안 > 분석' 카테고리의 다른 글
[노트] iexplore.exe 명령어 파라메터 (0) | 2011.01.10 |
---|---|
[노트] PE 리소스 - DVCLAL, PACKAGEINFO (3) | 2011.01.06 |
[노트] 포인터에 대한 암/복호화 (0) | 2010.11.14 |
[노트] SEH 관련 참조 (0) | 2010.11.14 |
[노트] 일부 정상 CLSID (0) | 2010.08.23 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
- 지루박멸연구센타
- 열정의 힘을 믿는다
- Le4rN TO Cr4cK
- 디버깅에관한모든것(DebugLab)
- sysinternals
- FoundStone
- hashtab
- 보안-coderant
- 디바이스드라이버 개발자 포럼
- dualpage.muz.ro
- osronline.com - 드라이버 관련 정보 사이트
- NtInternals - NativeAPI Refere…
- pcthreat - spyware 정보 제공
- rootkit.com - 루트킷 관련 정보
- www.ntinternals.net
- WINE CrossRef. - source.winehq…
- tuts4you
- hex-rays
- idapalace
- idefense
- immunityinc
- threatexpert
- hdp.null2root.org
- www.crackstore.com
- crackmes.de
- www.who.is
- www.cracklab.ru
- community.reverse-engineering.…
- video.reverse-engineering.net
- SnD
- 클레이 키위
- reversengineering.wordpress.co…
- www.openrce.org
- www.woodmann.com
- PEID.Plusins.BobSoft
- roxik.com/pictaps/
- regexlib.com
- spyware-browser.com
- www.usboffice.kr
- regulator
- www.txt2re.com
- ietab.mozdev.org
- zesrever.xstone.org
- www.heaventools.com/PE-file-he…
- www.heaventools.com
- www.innomp3.com
- 울지않는벌새
- exetools.com-forum
- exetools.com
- utf8 conv
- robtex - IP trace
- onsamehost - same IP sites
- JpopSuki
- jsunpack.jeek.org
- wepawet.iseclab.org
- www.jswiff.com
- www.hackeroo.com
- winesearcher.co.kr
- khpga.org
- malwareurl.com
- anubis.iseclab.org
- www.crummy.com-eautifulSoup
- malwarebytes.org/forums
- bbs.janmeng.com
- blackip.ustc.edu.cn
- eureka.cyber-ta.org
- exploit-db.com
TAG
- 군함도
- Pivot
- logrotate
- ROA
- 주택구매력지수
- systemd
- 맥쿼리인프라
- 피봇
- PIR
- 전세매매지수
- 레고랜드
- 미국주식
- 다올저축은행
- 주식
- 공공인프라
- 매매가격지수
- SBI저축은행
- O365
- 사회간접자본
- ElasticSearch
- CriticalSection
- ubuntu
- hai
- ChatGPT
- INVOICE
- 신한저축은행
- 시스템트래이딩
- 자동트래이딩
- 주식트래이딩
- 실시간트래이딩
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
글 보관함