Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

github логотип

GHSA-2gxj-qrp2-53jv

Опубликовано: 06 янв. 2022
Источник: github
Github: Прошло ревью
CVSS3: 9.8

Описание

Incorrect reliance on Trait memory layout in mopa

The mopa crate redefines the deprecated TraitObject struct from core::raw. This is done to then transmute a reference to a trait object (&dyn Trait for any trait Trait) into this struct and retrieve the data field for the purpose of downcasting. This is used to implement downcast_ref_unchecked(), in terms of which downcast_ref() is also implemented. Same goes for mutable reference downcasting and Box downcasting.

The Rust compiler explicitly reserves the right to change the memory layout of &dyn Trait for any trait Trait. The worst case scenario is that it swaps data and vtable, making an executable location breach and compromisation of ASLR possible, since reads from data would read vtable instead. Likewise, arbitrary code execution is also theoretically possible if reads of vtable generated by the compiler read data instead.

Пакеты

Наименование

mopa

rust
Затронутые версииВерсия исправления

<= 0.2.2

Отсутствует

EPSS

Процентиль: 76%
0.00931
Низкий

9.8 Critical

CVSS3

Связанные уязвимости

CVSS3: 9.8
nvd
около 4 лет назад

An issue was discovered in the mopa crate through 2021-06-01 for Rust. It incorrectly relies on Trait memory layout, possibly leading to future occurrences of arbitrary code execution or ASLR bypass.

EPSS

Процентиль: 76%
0.00931
Низкий

9.8 Critical

CVSS3