[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Full-disclosure] CORE-2010-0514: XnView MBM Processing Heap Overflow



-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

      Core Security Technologies - CoreLabs Advisory
           http://corelabs.coresecurity.com/

          XnView MBM Processing Heap Overflow



1. *Advisory Information*

Title: XnView MBM Processing Heap Overflow
Advisory Id: CORE-2010-0514
Advisory URL:
[http://www.coresecurity.com/content/xnview-mbm-heap-overflow]
Date published: 2010-06-14
Date of last update: 2010-06-14
Vendors contacted: XnView
Release mode: Coordinated release



2. *Vulnerability Information*

Class: Buffer overflow [CWE-119]
Impact: Code execution
Remotely Exploitable: Yes (client-side)
Locally Exploitable: No
CVE Name: CVE-2010-1932
Bugtraq ID: N/A



3. *Vulnerability Description*

XnView [1] is prone to a security vulnerability when processing MBM
files. This vulnerability could be exploited by a remote attacker to
execute arbitrary code on the target machine, by enticing the user of
XnView to open a specially crafted file.


4. *Vulnerable packages*

   . XnView 1.97.4
   . Older versions are probably affected too, but they were not checked.


5. *Non-vulnerable packages*

   . XnView 1.97.5


6. *Vendor Information, Solutions and Workarounds*

Update to the latest version of XnView, available on the website
[http://www.xnview.com/]


7. *Credits*

This vulnerability was discovered by Mauro Olea and researched by Mauro
Olea and Nahuel Riva from Core Security Technologies. Publication of
this advisory was coordinated by Carlos Sarraute from Core Security
Advisories team.


8. *Technical Description / Proof of Concept Code*

XnView is prone to a security vulnerability when processing MBM files.
The version used in our tests in XnView 1.97.4 running on Windows 2000
SP4. By enticing the user of XnView to open a specially crafted file, a
remote attacker may exploit this vulnerability to gain arbitrary code
execution.

The MBM file format (shortened from MultiBitMap) is a container for a
set of bitmap images. MBM files are used by most Symbian applications to
store their graphical content. MBM files can be created with the BMCONV
tool which is supplied with any Symbian (and EPOC) SDK.


8.1. *First Proof-of-Concept*

An MBM file that triggers this vulnerability is available at [2]. The
following is an excerpt of the vulnerable code, and the value of the
registers when the vulnerability is triggered (the values of EAX and ECX
are controlled by the attacker).

/-----
77FCC453   . 8901           MOV DWORD PTR DS:[ECX],EAX
77FCC455   . 8948 04        MOV DWORD PTR DS:[EAX+4],ECX
77FCC458   . 3BC1           CMP EAX,ECX
77FCC45A   . 75 25          JNZ SHORT ntdll.77FCC481



EAX 7A7A7A7A
ECX 7A7A7A7A
EDX 00000000
EBX 00000003
ESP 0171ED64
EBP 0171EEFC
ESI 013579F0 ASCII
"zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz"
EDI 00C60000
EIP 77FCC453 ntdll.77FCC453
C 0  ES 0023 32bit 0(FFFFFFFF)
P 1  CS 001B 32bit 0(FFFFFFFF)
A 0  SS 0023 32bit 0(FFFFFFFF)
Z 0  DS 0023 32bit 0(FFFFFFFF)
S 0  FS 0038 32bit 7FFDA000(FFF)
T 0  GS 0000 NULL
D 0
O 0  LastErr ERROR_SUCCESS (00000000)
EFL 00000206 (NO,NB,NE,A,NS,PE,GE,G)
ST0 empty -UNORM BC50 00000200 0014BC50
ST1 empty +UNORM 0014 000800EC 0049ECC0
ST2 empty +UNORM 4720 0012EF38 00000000
ST3 empty +UNORM 4730 01010052 00000014
ST4 empty 0.0000000000000000040e-4933
ST5 empty +UNORM 0018 0012EF48 77FA15EF
ST6 empty -UNORM EFB0 01010052 00000014
ST7 empty 1.0000000000000000000
               3 2 1 0      E S P U O Z D I
FST 0100  Cond 0 0 0 1  Err 0 0 0 0 0 0 0 0  (LT)
FCW 027F  Prec NEAR,53  Mask    1 1 1 1 1 1

- -----/



8.2. *Second Proof-of-Concept*

By generating a second malformed .MBM file (available at [2]), we can
trigger a heap overflow that may lead to arbitrary code execution. In
this case, the crash occurs in the following code:

/-----
77F937A5    8901            MOV DWORD PTR DS:[ECX],EAX
77F937A7    8948 04         MOV DWORD PTR DS:[EAX+4],ECX
77F937AA    3BC1            CMP EAX,ECX
77F937AC    75 2E           JNZ SHORT ntdll.77F937DC

EAX 41414141
ECX 41414141
EDX 0131DA98 ASCII
41,"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
EBX 00000005
ESP 0012DE68
EBP 0012E024
ESI 00C60000
EDI 0131DA98 ASCII
41,"AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"
EIP 77F937A5 ntdll.77F937A5

- -----/


The vulnerability is triggered in ntdll.dll. The code corresponds to the
function RtlAllocateHeap when a new node is added to the double-linked
list of heap chunks. As can be seen, both EAX and ECX contain arbitrary
values controlled by the attacker (0x41414141). This is the Call Stack
when the crash occurs:

/-----
Call stack of main thread
Address    Stack      Procedure / arguments          Called from
           Frame
0012E028   77FB55EB   ntdll.77F93633                 ntdll.77FB55E6
           0012E024
0012E0AC   77FA7C5E   ntdll.77FB5507                 ntdll.77FA7C59
           0012E0A8
0012E27C   77FCB167   ntdll.77F93633                 ntdll.77FCB162
           0012E278
0012E428   005AD1C6   ntdll.RtlAllocateHeap          xnview.005AD1C0
           0012E424
0012E42C   00C60000     hHeap = 00C60000
0012E430   40000060     Flags =
HEAP_TAIL_CHECKING_ENABLED|HEAP_FREE_CHECKING_ENABLED|40000000
0012E434   00000010     HeapSize = 10 (16.)
0012E464   005AD0BD   xnview.005AD0D9                xnview.005AD0B8
           0012E460
0012E46C   005AD0AA   xnview.005AD0AD                xnview.005AD0A5
0012E478   0049E8D4   xnview.005AD09B                xnview.0049E8CF
0012E748   004A00F5   ? xnview.0049E6C0              xnview.004A00F0
0012EAD4   00495075   xnview.0049FD40                xnview.00495070
0012EAE8   004C8525   Includes xnview.00495075       xnview.004C8523
0012EB24   77E12CA8   Includes xnview.004C8525       USER32.77E12CA5
0012EB44   77E14398   ? USER32.77E12C90              USER32.77E14393
0012EB48   004C8230     Arg1 = 004C8230
0012EB4C   00040124     Arg2 = 00040124
0012EB50   0000004E     Arg3 = 0000004E
0012EB54   000007D0     Arg4 = 000007D0
0012EB58   0012EC40     Arg5 = 0012EC40
0012EB74   77E14925   USER32.77E142DB                USER32.77E14920
           0012EB70
0012EB94   71715C13   USER32.SendMessageW            COMCTL32.71715C0D
           0012EB90
0012EB98   00040124     hWnd = 40124
0012EB9C   0000004E     Message = WM_NOTIFY
0012EBA0   000007D0     wParam = 7D0
0012EBA4   0012EC40     lParam = 12EC40
0012EC24   71752933   COMCTL32.717154AD              COMCTL32.7175292E
           0012EC20
0012ECB4   7175342C   COMCTL32.717528AB              COMCTL32.71753427
           0012ECB0
0012ED08   71755756   COMCTL32.7175339F              COMCTL32.71755751
           0012ED04
0012ED5C   77E12CA8   Includes COMCTL32.71755756     USER32.77E12CA5
           0012ED58
0012ED7C   77E152E6   ? USER32.77E12C90              USER32.77E152E1
           0012ED78
0012ED80   71755025     Arg1 = 71755025
0012ED84   0006012E     Arg2 = 0006012E
0012ED88   00001102     Arg3 = 00001102
0012ED8C   00000002     Arg4 = 00000002
0012ED90   00155FA8     Arg5 = 00155FA8
0012EDA0   77E15362   ? USER32.77E152A9              USER32.77E1535D
           0012ED9C
0012EDC0   0049EDED   ? USER32.CallWindowProcA       xnview.0049EDE7
           0012EDBC
0012EDC4   FFFF0201     PrevProc = FFFF0201
0012EDC8   0006012E     hWnd = 0006012E ('Tree
View',class='SysTreeView32',parent=00040124)
0012EDCC   00001102     Message = MSG(1102)
0012EDD0   00000002     wParam = 2
0012EDD4   00155FA8     lParam = 155FA8
0012EED8   77A530AA   ntdll.RtlFreeHeap              ole32.77A530A4
0012EEDC   00130000     hHeap = 00130000
0012EEE0   00000000     Flags = 0
0012EEE4   0016D990     pMemory = 0016D990
0012EEEC   77E12CA8   Includes ole32.77A530AA        USER32.77E12CA5
           0012EEF8
0012EF0C   77E14398   ? USER32.77E12C90              USER32.77E14393
           0012EEF8
0012EF10   0049ECC0     Arg1 = 0049ECC0
0012EF14   0006012E     Arg2 = 0006012E
0012EF18   00001102     Arg3 = 00001102
0012EF1C   00000002     Arg4 = 00000002
0012EF20   00155FA8     Arg5 = 00155FA8
0012EF3C   77E153A1   USER32.77E142DB                USER32.77E1539C
           0012EF38
0012EF5C   0049F0F9   Includes USER32.77E153A1       xnview.0049F0F7
           0012EF58
0012F284   004A7B45   ? xnview.0049EEC0              xnview.004A7B40
0012F294   005317E9   xnview.004A7B10                xnview.005317E4
0012FA44   00531276   xnview.005312C0                xnview.00531271
0012FA80   004C95B8   Includes xnview.00531276       xnview.004C95B4
0012FAA0   005382FE   xnview.004C9560                xnview.005382F9
0012FAB8   77E12CA8   Includes xnview.005382FE       USER32.77E12CA5
0012FAD8   77E14398   ? USER32.77E12C90              USER32.77E14393
0012FADC   005382E0     Arg1 = 005382E0
0012FAE0   00090130     Arg2 = 00090130
0012FAE4   00000401     Arg3 = 00000401
0012FAE8   00000000     Arg4 = 00000000
0012FAEC   0012FB58     Arg5 = 0012FB58
0012FB08   77E153A1   USER32.77E142DB                USER32.77E1539C
           0012FB04
0012FB28   005336BA   USER32.SendMessageA            xnview.005336B4
           0012FB24
0012FB2C   00090130     hWnd = 90130
0012FB30   00000401     Message = WM_USER+1
0012FB34   00000000     wParam = 0
0012FB38   0012FB58     lParam = 12FB58
0012FC68   005338A2   xnview.00533590                xnview.0053389D
0012FC80   004C96C7   Includes xnview.005338A2       xnview.004C96C3
0012FCA4   005369E3   xnview.004C9660                xnview.005369DE
0012FCC4   004C95B8   Includes xnview.005369E3       xnview.004C95B4
0012FCE4   005382FE   xnview.004C9560                xnview.005382F9
           0012FD18
0012FCFC   77E12CA8   Includes xnview.005382FE       USER32.77E12CA5
           0012FD18
0012FD1C   77E12DC5   ? USER32.77E12C90              USER32.77E12DC0
           0012FD18
0012FD20   005382E0     Arg1 = 005382E0
0012FD24   00090130     Arg2 = 00090130
0012FD28   00000111     Arg3 = 00000111
0012FD2C   0000000B     Arg4 = 0000000B
0012FD30   00000000     Arg5 = 00000000
0012FDA8   77E1577D   USER32.77E12CBD                USER32.77E15778
           0012FDA4
0012FDB4   0053802B   USER32.DispatchMessageA        xnview.00538025
0012FDB8   0012FDD8     pMsg = WM_COMMAND hw = 90130 ("XnView - [Browser
- - C:\Docu...") Notify =
0012FF38   005B21E2   ? xnview.005377E0
xnview.<ModuleEntryPoint>
  +0D
  0012FF3C   00400000     Arg1 = 00400000
  0012FF40   00000000     Arg2 = 00000000
  0012FF44   0013326B     Arg3 = 0013326B
  0012FF48   0000000A     Arg4 = 0000000A

- -----/


The problem is found in the function 0x65a310:

/-----
0065A310  /$  53            PUSH EBX
0065A311  |.  55            PUSH EBP
0065A312  |.  8B6C24 14     MOV EBP,DWORD PTR SS:[ESP+14]
0065A316  |.  33C0          XOR EAX,EAX
0065A318  |.  56            PUSH ESI
0065A319  |.  57            PUSH EDI
0065A31A  |.  85ED          TEST EBP,EBP
0065A31C  |.  0F8E AB000000 JLE xnview.0065A3CD
0065A322  |.  8B5C24 14     MOV EBX,DWORD PTR SS:[ESP+14]
0065A326  |.  8B7C24 18     MOV EDI,DWORD PTR SS:[ESP+18]
0065A32A  |>  8B03          /MOV EAX,DWORD PTR DS:[EBX]
0065A32C  |.  8D4C24 1C     |LEA ECX,DWORD PTR SS:[ESP+1C]
0065A330  |.  50            |PUSH EAX                      ; /Arg4
0065A331  |.  6A 01         |PUSH 1                        ; |Arg3 =
00000001
0065A333  |.  6A 01         |PUSH 1                        ; |Arg2 =
00000001
0065A335  |.  51            |PUSH ECX                      ; |Arg1
0065A336  |.  E8 284BF5FF   |CALL xnview.005AEE63          ;
\xnview.005AEE63
0065A33B  |.  83C4 10       |ADD ESP,10
0065A33E  |.  83F8 01       |CMP EAX,1
0065A341  |.  0F85 81000000 |JNZ xnview.0065A3C8
0065A347  |.  8A4424 1C     |MOV AL,BYTE PTR SS:[ESP+1C]
0065A34B  |.  84C0          |TEST AL,AL
0065A34D  |.  66:0FBEC0     |MOVSX AX,AL
0065A351  |.  7D 22         |JGE SHORT xnview.0065A375
0065A353  |.  8B13          |MOV EDX,DWORD PTR DS:[EBX]
0065A355  |.  F7D8          |NEG EAX
0065A357  |.  0FBFF0        |MOVSX ESI,AX
0065A35A  |.  52            |PUSH EDX                      ; /Arg4
0065A35B  |.  6A 01         |PUSH 1                        ; |Arg3 =
00000001
0065A35D  |.  56            |PUSH ESI                      ; |Arg2
0065A35E  |.  57            |PUSH EDI                      ; |Arg1
0065A35F  |.  2BEE          |SUB EBP,ESI                   ; |
0065A361  |.  E8 FD4AF5FF   |CALL xnview.005AEE63          ;
\xnview.005AEE63
0065A366  |.  83C4 10       |ADD ESP,10
0065A369  |.  85C0          |TEST EAX,EAX
0065A36B  |.  74 5B         |JE SHORT xnview.0065A3C8
0065A36D  |.  03FE          |ADD EDI,ESI
0065A36F  |.  897C24 18     |MOV DWORD PTR SS:[ESP+18],EDI
0065A373  |.  EB 44         |JMP SHORT xnview.0065A3B9
0065A375  |>  40            |INC EAX
0065A376  |.  0FBFF0        |MOVSX ESI,AX
0065A379  |.  8B03          |MOV EAX,DWORD PTR DS:[EBX]
0065A37B  |.  2BEE          |SUB EBP,ESI
0065A37D  |.  50            |PUSH EAX
0065A37E  |.  E8 AB4DF5FF   |CALL xnview.005AF12E
0065A383  |.  83C4 04       |ADD ESP,4
0065A386  |.  66:3D FFFF    |CMP AX,0FFFF
0065A38A  |.  74 3C         |JE SHORT xnview.0065A3C8
0065A38C  |.  0FBFC0        |MOVSX EAX,AX
0065A38F  |.  8AD8          |MOV BL,AL
0065A391  |.  8BCE          |MOV ECX,ESI
0065A393  |.  8AFB          |MOV BH,BL
0065A395  |.  8BD1          |MOV EDX,ECX
0065A397  |.  8BC3          |MOV EAX,EBX
0065A399  |.  C1E0 10       |SHL EAX,10
0065A39C  |.  66:8BC3       |MOV AX,BX
0065A39F  |.  8B5C24 14     |MOV EBX,DWORD PTR SS:[ESP+14]
0065A3A3  |.  C1E9 02       |SHR ECX,2
0065A3A6  |.  F3:AB         |REP STOS DWORD PTR ES:[EDI]
0065A3A8  |.  8BCA          |MOV ECX,EDX
0065A3AA  |.  83E1 03       |AND ECX,3
0065A3AD  |.  F3:AA         |REP STOS BYTE PTR ES:[EDI]
0065A3AF  |.  8B7C24 18     |MOV EDI,DWORD PTR SS:[ESP+18]
0065A3B3  |.  03FE          |ADD EDI,ESI
0065A3B5  |.  897C24 18     |MOV DWORD PTR SS:[ESP+18],EDI
0065A3B9  |>  85ED          |TEST EBP,EBP
0065A3BB  |.^ 0F8F 69FFFFFF \JG xnview.0065A32A
0065A3C1  |.  5F            POP EDI
0065A3C2  |.  5E            POP ESI
0065A3C3  |.  5D            POP EBP
0065A3C4  |.  33C0          XOR EAX,EAX
0065A3C6  |.  5B            POP EBX
0065A3C7  |.  C3            RETN
0065A3C8  |>  B8 04000000   MOV EAX,4
0065A3CD  |>  5F            POP EDI
0065A3CE  |.  5E            POP ESI
0065A3CF  |.  5D            POP EBP
0065A3D0  |.  5B            POP EBX
0065A3D1  \.  C3            RETN

- -----/


According to the .MBM format [3], the structure of an MBM is the
following (beginning with a Header Section):

/-----
Offset Size Data Description

0000 ID 37 00 00 10 UID1: Header Section layout

0004 ID 42 00 00 10 UID2: File kind

0008 ID 00 00 00 00 UID3: Application ID

000C L 39 64 39 47 UID4: Checksum of UID1, UID2 and UID3

0010 Offset MBM Jumptable

- -----/


The MBM Jumptable is an LListL of offsets in which each offset points to
a Paint Data Section. An LListL is basically a list where, as can be
deduced from [4], the first letter ("L") represents the encoding of the
list size indicator and the last letter ("L") represents the size of
each element of the list. In this case, we have a list of LONGs and the
size of this list is encoded as a LONG. So in our case, we have the
following:

/-----
37000010 // Header Section Layout
42000010 // File  Kind
00000000 // Application ID
39643947 // Checksum Header Section, File Kind and Application ID
14000000 // Offset to MBM Jumptable

- -----/


Our MBM Jumptable contains the following:

/-----
01000000 // List lenght
1C000000 // Offset to the list

- -----/


This is a list with one element (there is only one drawing in the file).
The structure of each Paint Data Section is described in [5]. Inside
this structure, there is a field called "Encoding", represented as Long
and which contains the following values:

/-----
00 00 00 00 Plain data
01 00 00 00 8-bit RLE encoding
02 00 00 00 12-bit RLE encoding
03 00 00 00 16-bit RLE encoding
04 00 00 00 24-bit RLE encoding

- -----/


The original value in our case was 0x00000000, that the encoding
indicates as plain data. When we change this value to 0x00007a7a, XnView
interprets the data as RLE encoding. According to the format
documentation [5]: "RLE encoding consists of sequences of marker bytes
with data bytes. A marker byte of 00 to 7F means that the next byte
should be repeated that many times and once more. A marker byte of 80 to
FF means that (100-marker) bytes of data follow."

The function 0x65A310 is responsible for handling this encoding and
copying the data indicated by the marker byte according to the encoding
indicated by the "Encoding" field. In our case, the encoding field
contains the following values:

/-----
0x00007a7a // Malformed encoding
0x7a41 // Data for this encoding

- -----/


We now look with more detail at that function, and how it handles data:

/-----
0065A347  |.  8A4424 1C     |MOV AL,BYTE PTR SS:[ESP+1C] // takes the
marker byte
0065A34B  |.  84C0          |TEST AL,AL
0065A34D  |.  66:0FBEC0     |MOVSX AX,AL                // moves it to AX
0065A351  |.  7D 22         |JGE SHORT xnview.0065A375  // checks if
it's greater than 0

- -----/


In this part, the program uses the third byte of the encoding, that is
0x7A, and since it is greater that 0, jumps to:

/-----
0065A375  |> \40            |INC EAX        // increments EAX
0065A376  |.  0FBFF0        |MOVSX ESI,AX   // copies the high part of
EAX to ESI
0065A379  |.  8B03          |MOV EAX,DWORD PTR DS:[EBX]
0065A37B  |.  2BEE          |SUB EBP,ESI
0065A37D  |.  50            |PUSH EAX
0065A37E  |.  E8 AB4DF5FF   |CALL xnview.005AF12E // obtains the byte
following 0x7A, that is the last byte of the encoding
0065A383  |.  83C4 04       |ADD ESP,4
0065A386  |.  66:3D FFFF    |CMP AX,0FFFF   // is this last byte 0xFFFF?
in fact it should be 0xFF, it's one byte
0065A38A  |.  74 3C         |JE SHORT xnview.0065A3C8 // if it is, then
good bye!
0065A38C  |.  0FBFC0        |MOVSX EAX,AX   // otherwise move AX to EAX
0065A38F  |.  8AD8          |MOV BL,AL      // AL = 0x41 goes to BL
0065A391  |.  8BCE          |MOV ECX,ESI    // ESI = 0x7B = 0x7A + 1 = ECX
0065A393  |.  8AFB          |MOV BH,BL      // BL a BH -> BH takes the
value 0x4141
0065A395  |.  8BD1          |MOV EDX,ECX    // EDX = 0x7B
0065A397  |.  8BC3          |MOV EAX,EBX    // EAX == EBX
0065A399  |.  C1E0 10       |SHL EAX,10     // here EAX == 0x41410000
0065A39C  |.  66:8BC3       |MOV AX,BX      // AX == 0x4141 -> EAX ==
0x41414141
0065A39F  |.  8B5C24 14     |MOV EBX,DWORD PTR SS:[ESP+14]
0065A3A3  |.  C1E9 02       |SHR ECX,2      // ECX / 4 = 0x1E, counter
0065A3A6  |.  F3:AB         |REP STOS DWORD PTR ES:[EDI] // EDI points
to a HEAP of 0x32 bytes.
0065A3A8  |.  8BCA          |MOV ECX,EDX
0065A3AA  |.  83E1 03       |AND ECX,3
0065A3AD  |.  F3:AA         |REP STOS BYTE PTR ES:[EDI] // copies
another DWORD

- -----/


As we can see, in this part it takes the marker byte (0x7A), increments
it by 1 (0x7B) and copies the following byte (0x41) the number of times
indicated by the marker byte, but the buffer has only 0x32 bytes
allocated. Below those 0x32 bytes we find the header of another chunk on
the heap:

/-----
01355570  00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  // beginning
of the 0x32 bytes heap
01355580  00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
01355590  AB AB AB AB AB AB AB AB 00 00 00 00 00 00 00 00
013555A0  20 00 07 00 01 04 EE FE 78 02 C6 00 78 02 C6 00
013555B0  EE FE EE FE EE FE EE FE EE FE EE FE EE FE EE FE
013555C0  EE FE EE FE EE FE EE FE EE FE EE FE EE FE EE FE

- -----/


0x31355A0 is the beginning of the header of the next chunk. After
executing REP STOS, the corruption of the header of that chunk occurs:

/-----
013555D8  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41
013555E8  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41
013555F8  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41
01355608  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41
01355618  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41
01355628  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41
01355638  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41
01355648  41 41 41 41 41 41 41 41 EE FE EE FE EE FE EE FE

- -----/


The error is the following: since it copies DWORDs, instead of copying
0x1E bytes, it should have copied 0x0F bytes (0x1E / 2). Finally, the
heap block is allocated in this part of the code:

/-----
005AC5F7    56              PUSH ESI          // Heap Size
005AC5F8    6A 08           PUSH 8            // HEAP_ZERO_MEMORY
005AC5FA    FF35 A4347900   PUSH DWORD PTR DS:[7934A4]  // Heap
005AC600    FF15 84726E00   CALL DWORD PTR DS:[<&KERNEL32.HeapAlloc>]  ;
ntdll.RtlAllocateHeap

- -----/



9. *Report Timeline*

. 2010-05-27:
Core Security Technologies notifies XnView of the vulnerability.

. 2010-05-27:
The XnView author acknowledges receipt of the notification.

. 2010-05-27:
Core sends a technical description of the vulnerability, and a
Proof-of-Concept file that triggers the bug.

. 2010-05-28:
The XnView author notifies Core that the vulnerability has been fixed,
and that a fixed version will be released.

. 2010-06-02:
Core asks XnView when the fixed version will be released, in order to
coordinate the publication of the advisory with the release of a fixed
version.

. 2010-06-03:
The XnView author responds that version 1.97.5 will be available in 2
weeks.

. 2010-06-03:
Core requests a more precise date for the release, and reschedules
publication of its advisory to June 14th, 2010.

. 2010-06-07:
The XnView author responds that the update will be available on June 14th.

. 2010-06-10:
Core sends a second Proof-of-Concept, and asks the XnView author if it
triggers a different vulnerability.

. 2010-06-11:
The XnView author responds that the second PoC triggers the same
vulnerability.

. 2010-06-14:
Advisory CORE-2010-0514 is published.



10. *References*

[1] XnView website
[http://www.xnview.com/]
[2] Proof of Concept files
[http://www.coresecurity.com/files/attachments/CORE-2010-0514-Xnview-PoCs.rar]
[3] MBM file format
[http://software.frodo.looijaard.name/psiconv/formats/MBM_File.html]
[4] Basic elements: LListL
[http://software.frodo.looijaard.name/psiconv/formats/Basic_Elements.html#LListL]
[5] Paint Data Section
[http://software.frodo.looijaard.name/psiconv/formats/Paint_Data_Section.html#Paint%20Data%20Section]


11. *About CoreLabs*

CoreLabs, the research center of Core Security Technologies, is charged
with anticipating the future needs and requirements for information
security technologies. We conduct our research in several important
areas of computer security including system vulnerabilities, cyber
attack planning and simulation, source code auditing, and cryptography.
Our results include problem formalization, identification of
vulnerabilities, novel solutions and prototypes for new technologies.
CoreLabs regularly publishes security advisories, technical papers,
project information and shared software tools for public use at:
[http://corelabs.coresecurity.com/].


12. *About Core Security Technologies*

Core Security Technologies develops strategic solutions that help
security-conscious organizations worldwide develop and maintain a
proactive process for securing their networks. The company's flagship
product, CORE IMPACT, is the most comprehensive product for performing
enterprise security assurance testing. CORE IMPACT evaluates network,
endpoint and end-user vulnerabilities and identifies what resources are
exposed. It enables organizations to determine if current security
investments are detecting and preventing attacks. Core Security
Technologies augments its leading technology solution with world-class
security consulting services, including penetration testing and software
security auditing. Based in Boston, MA and Buenos Aires, Argentina, Core
Security Technologies can be reached at 617-399-6980 or on the Web at
[http://www.coresecurity.com].


13. *Disclaimer*

The contents of this advisory are copyright (c) 2010 Core Security
Technologies and (c) 2010 CoreLabs, and may be distributed freely
provided that no fee is charged for this distribution and proper credit
is given.


14. *PGP/GPG Keys*

This advisory has been signed with the GPG key of Core Security
Technologies advisories team, which is available for download at
[http://www.coresecurity.com/files/attachments/core_security_advisories.asc].

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.14 (MingW32)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org/

iEYEARECAAYFAkwWj7IACgkQyNibggitWa1e5ACgo5+9x+0d52kMcG/W+SUMQBi2
654AoJ5SFLW+h9mSS84bHqpzqhxBwhB0
=HDp/
-----END PGP SIGNATURE-----

_______________________________________________
Full-Disclosure - We believe in it.
Charter: http://lists.grok.org.uk/full-disclosure-charter.html
Hosted and sponsored by Secunia - http://secunia.com/