Lucene search

K
exploitpackGoogle Security ResearchEXPLOITPACK:AA22CB3910C06862D5D18E0073F7C60B
HistoryMay 23, 2017 - 12:00 a.m.

Apple macOSiOS - CAMediaTimingFunctionBuiltin NSKeyedArchiver Memory Corruption Due to Lack of Bounds Checking

2017-05-2300:00:00
Google Security Research
6

Apple macOSiOS - CAMediaTimingFunctionBuiltin NSKeyedArchiver Memory Corruption Due to Lack of Bounds Checking

Source: https://bugs.chromium.org/p/project-zero/issues/detail?id=1175

CAMediaTimingFunctionBuiltin is a class in QuartzCore. Its initWithCoder: method
reads an Int "index" then passes that to builtin_function

  mov     ebx, edi <-- controlled unsigned int
  mov     r14d, ebx
  lea     r15, __ZL9functions_0 ; functions
  mov     rax, [r15+r14*8]

if rax is non-null it's returned as an objective-c object pointer and the objective-c retain
selector is sent to it.

Serialized poc in attached file with an index of 12345678.

tested on MacOS 10.12.3 (16D32)


Proof of Concept:
https://github.com/offensive-security/exploitdb-bin-sploits/raw/master/bin-sploits/42052.zip