Compatibility mode
Содержание
Режим совместимости
Application Compatibility Framework (фреймворк совместимости приложений) - механизм, предназначенный для работы с ошибками в приложениях. После обновления операционной системы некоторые приложения внезапно перестают работать. Общей причиной этого является то, что приложение используют в своей работе исправленную ошибку в операционной системе. И после исправления данной ошибки приложение, без вмешательства автора, больше не будет работать. Поскольку автор может быть недоступен для создания обновления (или может даже не знать о проблеме), в приложении Application Compatiblity Framework есть средства для устранения распространенных ошибок.
Наиболее известной для пользователя является вкладка «Совместимость», находящаяся в диалоговом окне свойств.
В ReactOS аналог данной функции разрабатывает Mark Jansen.
Поддержка API NT 6.0
- CORE-11288 - В настоящее время ReactOS нацелен на совместимость с Windows Server 2003. Разработчик планирует реализовать механизм для использования API-интерфейсов Windows NT 6.0 и более поздних, при этом чтобы в ReactOS оставалась среда Windows Server 2003.
- CORE-11289 - Исследование и документирование параметров совместимости Windows
- CORE-11290 - Убедиться в том, что загрузчик соблюдает совместимость
- CORE-11291 - Создание спек-файлов для основных библиотек Windows 7
- CORE-11292 - Реорганизация ядра Win32 API
- CORE-11293 - Исследование требований ядра для NT 6+ API пользовательского режима
CORE-11292 - Реорганизация ядра Win32 API - PR-397 Timo Kreuzer реализует поддержку экспорта версий.
Реорганизации API со следующими целями:
- Использование статических библиотек / API-наборов MinWin в качестве основы
- Комбинирование (объединение общеиспользуемых API наподобие kernel32/advapi32/... в единую DLL, типа MinWin API используемую в качестве основы)
- Возможность тестирования DLL в Windows (добавление пользовательских целей для автономных полных DLL на поддерживаемую целевую версию: kernel32_0x502 для 2k3)
- Управление конкретными версиями API
- DLL Naming (пользовательские имена DLL для основных DLL)
"Идея состоит в создании наборов «оберточных DLL», по одному для каждой версии ОС. Каждая из них обращается к "базовой версии" (например, «roskernelbase.dll»), за исключением тех, которые требуют специальной обработки. Все это можно сделать, не создавая полдюжины копий спек-файлов." - Timo Kreuzer, PR-397
Дистрибутив NT 6
Участник сообщества The_DarkFire делает проект по созданию ReactOS с функциями NT 6.1 - ReactOS Longhorn.
Наработки проекта по состоянию на 18.04.23 можно скачать по ссылке: https://disk.yandex.ru/d/4OJEHFtqnHG0mw
Реализация режима совместимости
NtApphelpCacheControl
Функция ядра NtApphelpCacheControl используемая AppHelp, чтобы сохранить список (200) недавно запущенных приложений в оперативной памяти для более быстрого поиска. При выходе список приложений сохраняется в реестре, а при загрузке подгружается обратно.
Реализация apphelp sdb
Реализация большинства SDB * API-интерфейсов, связанных с чтением и записью файлов SDB.
SDB файлы - базы данных совместимости приложений, содержащие информацию об известных "плохих приложениях", а также список «слоев», которые должны применяться к этим приложениям.
В качестве основы используется: http://github.com/krofna/wine/tree/master/dlls/apphelp
CORE-10367- в настоящий момент ведется работа над данным компонентом
Вкладка в explorer
В более новых версиях Windows реализована в виде расширения оболочки (acppage.dll). Использует функции SetPermLayerState, SdbGetPermLayerKeys.
На данный момент вкладка реализована вместе с функциональностью позволяющей применить необходимые «слои».
Интеграция apphelp
Интеграция apphelp в создание процесса, COM, MSI и загрузку драйверов.
- CORE-10368
- 3 июня 2017 года была начата интеграция apphelp в создание процесса
- 27 июня был опубликован первый патч
- 29 июня года была реализована функция SdbpMatchExe
- 1 июля произведена интеграция apphelp в создание процесса
- 3 июня 2017 года была начата интеграция apphelp в создание процесса
Инфраструктура Shim
Реализует базовую инфраструктуру для работы со слоями совместимости.
Создание стандартных значений Shim
Предоставляет:
- список "эмулируемых" версий API (VersionLie) (
CORE-11299) - настройку разрешения экрана/глубины цвета/отключение тем (
CORE-11927) - игнорировать песочницу Chrome CORE-13409
- обработчик исключений WindowProc CORE-12244
ShimLib
Выполняет вспомогательные функции для регистрации регулировочных слоев и для обработки общих задач.
Первый коммит - r73461.
Данные Shim в ярлыках
Применение окружения совместимости не для *.exe-файла, а для ярлыка.
Статус реализации
- 5 сентября 2015 года в ядре был реализован компонент NtApphelpCacheControl (
CORE-9914) - 31 марта 2016 года была добавлена библиотека apphelp.dll (
CORE-10367) - 28 мая 2016 года был добавлен список "эмулируемых" версий API (
CORE-11299) - 16 декабря 2016 года была добавлена настройка разрешения экрана/глубины цвета/отключения тем (
CORE-11927) - 22 апреля 2017 года - реализация пользовательского выбора режима совместимости в виде расширения оболочки acppage
- 19 мая 2017 года была добавлена начальная реализация интеграции apphelp в создание процесса, COM, MSI и загрузку драйверов (CORE-10368)
- 29 июня 2017 года была реализована функция SdbpMatchExe, позволяющая сопоставить файлы/приложения в соответствии с параметрами (CORE-13284)
- 1 июля 2017 года:
- была полностью реализована вкладка для проводника
- было реализовано большинство необходимых функций apphelp sdb. Остальные будут реализованы когда понадобятся
- произведена интеграция apphelp в создание процесса
- 30 июля 2017 года была завершена разработка ShimLib
- 17 августа 2017 года режим совместимости был включен по-умолчанию (при этом он не может применяться на системные файлы - в system32 и WinSxS)
- 10 января 2018 был реализован запуск NT6-приложений (информация в списке рассылки) (Colin Finck)
- 24 февраля 2018:
- 2019
- начата работа по поддержке пользовательских установщиков shim
- приложения могут получить версии Windows 7 SP1, 8 или 8.1
- исправлены некоторые сбои движка shim[4]
- 23 августа 2019 - PR-1872 - Система управления версиями для DLL
- 28 мая 2020 - PR-2872 - Начальная реализация движка Kernel Shim Engine
База совместимости
Приложения работающие через режим совместимости:
- VMware Horizon Client for 32-bit Windows[5][6]
- Windows Media Player 6.4[7]
- Windows Media Player 7[8]
- Krita 3.2.1.0[9]
- QuickTime Player 7.7.9[10]
- Sound Forge Pro 11.0 build 299[11]
*_vista-библиотеки
В исходном коде ReactOS есть библиотеки advapi32_vista, kernel32_vista, ntoskrnl_vista и ntdll_vista. Может показаться, что они существуют для реализации vista-API в ReactOS, однако, это не так. Они предназначены для предоставления необходимых функций для линкинга [i] используемых Wine-библиотек.
Ссылки
- Обсуждение на форуме: [12], [13];
- Управление версиями в списке рассылки
- One-Core-Api - слой совместимости NT6 для Windows XP/2003 на базе Wine и ReactOS
- Wined3D, [14] - обертка основанная на Wine, транслирующая вызовы DirectX 1-11 в OpenGL, являющаяся полной реализацией DirectX для старых версий Windows.
- О режиме совместимости на сайте Microsoft (англ.)
- Режим совместимости на официальной вики