Vulnerability Spotlight: Type confusion

What is type confusion exactly? And how can it be used to exploit programs? According to the CWE (Common Weakness Enumeration) "Type confusion is when: the program allocates or initializes a resource such as a pointer, object, or variable using one type, but it later accesses that resource using a type that is incompatible with the original type. When the program accesses the resource using an incompatible type, this could trigger logical errors because the resource does not have expected properties. In languages without memory safety, such as C and C++, type confusion can lead to out-of-bounds memory access."

C and C++ are common examples used because these languages do not have type checking. This allows attackers to potentially exploit type confusion within C/C++ programs, which can lead to code execution. Of course C and C++ are not the only examples, languages with dynamic typing generally (like Perl) have this issue.

C++ has 3 main Casting Operations:

1. Static Casting -> static_cast<ToClass>(object)
    - Class Hierarchy checked at compile time
    - Unsafe
2. Dynamic Casting -> dynamic_cast<ToClass>(Object)
    -Run-time check based on allocated type(vtable pointer)
    -Not used in performance critical code
    -Safe, but not used by everyone since it lowers performance
3. C-Styel Casting->(ToClass)(Object)
    -C-Style cast, no check for the object type a tall
    -Unsafe

The take away from these casting operations is that there is a safe way to implement casting within C++, but because it's at the cost of performance many people choose not to do so. 

A type confusion bug arises from illegal down-casts. Basically within object-orientated programing you can have what you would call a "Parent" class and subclasses for example "Child 1, and Child 2". Both Child 1 and Child 2 are a subclass of Parent, but they are not equal to each other. For example: Child 1 is not a Child 2. However, in the case of C++ this can actually be an issue since there is no checking. 

The biggest concern with this is that it can lead to remote code/arbitrary code execution. Quite a few of these have been demonstrated through Chrome/Chromium. See here for one of them: https://github.blog/2022-06-29-the-chromium-super-inline-cache-type-confusion/ 

That's all for now! 

Thanks for taking the time to read this. I hope you have a great day. :) 
If you would like to read a more in depth post about type confusion this paper is a good one: https://nebelwelt.net/files/18SyScan360-presentation.pdf and the youtube video as well. https://www.youtube.com/watch?v=jbglFfkRYQs&t=138s  

Have a great week! <3 Blackcatt

Comments

Popular posts from this blog

DEFCON 32: My review as a first time attendee.

Steghide: An introduction