VDB
EN
MEDIUM 5.3

GHSA-p27m-hp98-6637

ImageMagick's failure to limit the depth of SVG file reads caused a DoS attack

상세

### Summary

Using Magick to read a malicious SVG file resulted in a DoS attack.

### Details

bt obtained using gdb:

``` #4 0x0000555555794c9c in ResizeMagickMemory (memory=0x7fffee203800, size=391344) at MagickCore/memory.c:1443 #5 0x0000555555794e5a in ResizeQuantumMemory (memory=0x7fffee203800, count=48918, quantum=8) at MagickCore/memory.c:1508 #6 0x0000555555acc8ed in SVGStartElement (context=0x517000000080, name=0x5190000055e3 "g", attributes=0x0) at coders/svg.c:1254 #7 0x00007ffff6799b1c in xmlParseStartTag () at /lib/x86_64-linux-gnu/libxml2.so.2 #8 0x00007ffff68c7bb8 in () at /lib/x86_64-linux-gnu/libxml2.so.2 #9 0x00007ffff67a03f1 in xmlParseChunk () at /lib/x86_64-linux-gnu/libxml2.so.2 ```

This is related to the SVGStartElement and ResizeQuantumMemory functions.

### PoC

1. Generate an SVG file

2. Read this file using Magick:

``` ./magick /data/ylwang/Tools/LargeScan/targets/ImageMagick/test++/1.svg null ```

3. Causes a DoS Attack

My server has a large amount of memory, causing a stack overflow to take a long time. I'll use the Windows release version as an example:

``` PS C:\Program Files\ImageMagick-7.1.2-Q8> .\magick.exe -ping 1.svg null: PS C:\Program Files\ImageMagick-7.1.2-Q8> echo $LASTEXITCODE -1073741571 ```

The error code -1073741571 indicates a crash due to a stack overflow.

### Impact

This is a DoS vulnerability and all applications using Magick to parse SVG files are affected.

이 버전이 영향받나요?

사용 중인 패키지 버전을 입력하면 즉시 평가합니다.

영향 패키지

NuGet / Magick.NET-Q16-AnyCPU
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-AnyCPU --version 14.10.1
NuGet / Magick.NET-Q16-HDRI-AnyCPU
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-HDRI-AnyCPU --version 14.10.1
NuGet / Magick.NET-Q16-HDRI-x86
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-HDRI-x86 --version 14.10.1
NuGet / Magick.NET-Q16-x86
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-x86 --version 14.10.1
NuGet / Magick.NET-Q8-AnyCPU
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q8-AnyCPU --version 14.10.1
NuGet / Magick.NET-Q8-x86
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q8-x86 --version 14.10.1
NuGet / Magick.NET-Q8-arm64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q8-arm64 --version 14.10.1
NuGet / Magick.NET-Q8-OpenMP-x64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q8-OpenMP-x64 --version 14.10.1
NuGet / Magick.NET-Q8-OpenMP-arm64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q8-OpenMP-arm64 --version 14.10.1
NuGet / Magick.NET-Q16-x64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-x64 --version 14.10.1
NuGet / Magick.NET-Q16-arm64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-arm64 --version 14.10.1
NuGet / Magick.NET-Q16-OpenMP-x64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-OpenMP-x64 --version 14.10.1
NuGet / Magick.NET-Q16-OpenMP-arm64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-OpenMP-arm64 --version 14.10.1
NuGet / Magick.NET-Q16-HDRI-x64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-HDRI-x64 --version 14.10.1
NuGet / Magick.NET-Q16-HDRI-arm64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-HDRI-arm64 --version 14.10.1
NuGet / Magick.NET-Q16-HDRI-OpenMP-x64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-HDRI-OpenMP-x64 --version 14.10.1
NuGet / Magick.NET-Q16-HDRI-OpenMP-arm64
최초 영향 버전: 0 수정 버전: 14.10.1
수정 dotnet add package Magick.NET-Q16-HDRI-OpenMP-arm64 --version 14.10.1

참고