Electron — это платформа для написания кроссплатформенных настольных приложений с использованием JavaScript, HTML и CSS. Начиная с версий 33.0.0-alpha.1 и до версий 39.8.5, 40.8.5, 41.1.0 и 42.0.0-alpha.5, приложения, использующие внеэкранный рендеринг с общими текстурами графического процессора, могут быть уязвимы для использования после освобождения. При определенных условиях обратный вызов Release(), предоставленный в текстуре события рисования, может пережить исходное состояние поддержки, и его вызов после этого момента разыменовывает освобожденную память в основном процессе, что может привести к сбою или повреждению памяти.
Приложения затронуты только в том случае, если они используют внеэкранный рендеринг с помощью webPreferences.offscreen: { useSharedTexture: true }. Приложения, которые не поддерживают закадровый рендеринг с общей текстурой, не затрагиваются. Чтобы устранить эту проблему, убедитесь, что метод текстуры.release() вызывается сразу после использования текстуры, прежде чем объект текстуры станет недоступным.
Эта уязвимость исправлена в версиях 39.8.5, 40.8.5, 41.1.0 и 42.0.0-alpha.5.
Показать оригинальное описание (EN)
Electron is a framework for writing cross-platform desktop applications using JavaScript, HTML and CSS. From 33.0.0-alpha.1 to before 39.8.5, 40.8.5, 41.1.0, and 42.0.0-alpha.5, apps that use offscreen rendering with GPU shared textures may be vulnerable to a use-after-free. Under certain conditions, the release() callback provided on a paint event texture can outlive its backing native state, and invoking it after that point dereferences freed memory in the main process, which may lead to a crash or memory corruption. Apps are only affected if they use offscreen rendering with webPreferences.offscreen: { useSharedTexture: true }. Apps that do not enable shared-texture offscreen rendering are not affected. To mitigate this issue, ensure texture.release() is called promptly after the texture has been consumed, before the texture object becomes unreachable. This vulnerability is fixed in 39.8.5, 40.8.5, 41.1.0, and 42.0.0-alpha.5.
Характеристики атаки
Последствия
Строка CVSS v3.1