Wasmtime — это среда выполнения WebAssembly. Начиная с версий 25.0.0 и до версий 36.0.7, 42.0.2 и 43.0.1, компилятор Winch компании Wasmtime содержит уязвимость, из-за которой компиляция инструкции table.fill может привести к панике хоста. Это означает, что действительный гость может быть скомпилирован с помощью Winch на любой архитектуре и вызвать панику хоста.
Это представляет собой уязвимость типа «отказ в обслуживании» в Wasmtime, поскольку гости могут вызвать панику. Конкретная проблема заключается в том, что исторический рефакторинг изменил то, как скомпилированный код ссылается на таблицы в инструкциях table.*. В ходе этого рефакторинга также не были обновлены связанные пути кода Winch, а это означает, что Winch использовал неправильную схему индексации.
Из-за поддержки функций Winch единственной проблемой, которая может возникнуть, является путаница таблиц или использование несуществующих таблиц, а это означает, что гость ограничивается паникой хоста (использованием несуществующей таблицы) или выполнением неправильного по спецификации поведения и изменением неправильной таблицы. Эта уязвимость исправлена в версиях 36.0.7, 42.0.2 и 43.0.1.
Показать оригинальное описание (EN)
Wasmtime is a runtime for WebAssembly. From 25.0.0 to before 36.0.7, 42.0.2, and 43.0.1, Wasmtime's Winch compiler contains a vulnerability where the compilation of the table.fill instruction can result in a host panic. This means that a valid guest can be compiled with Winch, on any architecture, and cause the host to panic. This represents a denial-of-service vulnerability in Wasmtime due to guests being able to trigger a panic. The specific issue is that a historical refactoring changed how compiled code referenced tables within the table.* instructions. This refactoring forgot to update the Winch code paths associated as well, meaning that Winch was using the wrong indexing scheme. Due to the feature support of Winch the only problem that can result is tables being mixed up or nonexistent tables being used, meaning that the guest is limited to panicking the host (using a nonexistent table), or executing spec-incorrect behavior and modifying the wrong table. This vulnerability is fixed in 36.0.7, 42.0.2, and 43.0.1.
Характеристики атаки
Последствия
Строка CVSS v4.0