An issue was discovered in GPAC version 0.8.0 and 0.9.0-development-20191109. There is a memory leak in dinf_New() in isomedia/box_code_base.c.
Weakness
The product does not sufficiently track and release allocated memory after it has been used, making the memory unavailable for reallocation and reuse.
Affected Software
| Name |
Vendor |
Start Version |
End Version |
| Gpac |
Gpac |
0.8.0 (including) |
0.8.0 (including) |
| Gpac |
Gpac |
0.9.0 (including) |
0.9.0 (including) |
| Gpac |
Ubuntu |
bionic |
* |
| Gpac |
Ubuntu |
disco |
* |
| Gpac |
Ubuntu |
eoan |
* |
| Gpac |
Ubuntu |
focal |
* |
| Gpac |
Ubuntu |
groovy |
* |
| Gpac |
Ubuntu |
hirsute |
* |
| Gpac |
Ubuntu |
impish |
* |
| Gpac |
Ubuntu |
kinetic |
* |
| Gpac |
Ubuntu |
lunar |
* |
| Gpac |
Ubuntu |
trusty |
* |
| Gpac |
Ubuntu |
trusty/esm |
* |
| Gpac |
Ubuntu |
xenial |
* |
Potential Mitigations
- Choose a language or tool that provides automatic memory management, or makes manual memory management less error-prone.
- For example, glibc in Linux provides protection against free of invalid pointers.
- When using Xcode to target OS X or iOS, enable automatic reference counting (ARC) [REF-391].
- To help correctly and consistently manage memory when programming in C++, consider using a smart pointer class such as std::auto_ptr (defined by ISO/IEC ISO/IEC 14882:2003), std::shared_ptr and std::unique_ptr (specified by an upcoming revision of the C++ standard, informally referred to as C++ 1x), or equivalent solutions such as Boost.
References