Compatibility mode

Материал из Русский WINE
Перейти к: навигация, поиск
Режим совместимости в Wine

Режим совместимости

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

Реализация режима совместимости

CORE-10366

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 в создание процесса

Инфраструктура 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 года:
  • 30 июля 2017 года была завершена разработка ShimLib
  • 17 августа 2017 года режим совместимости был включен по-умолчанию (при этом он не может применяться на системные файлы - в system32 и WinSxS)
  • 10 января 2018 был реализован запуск NT6-приложений (информация в списке рассылки) (Colin Finck)
  • 24 февраля 2018:
    • были реализованы VersionLie для WIN8 и WIN81[1][2]
    • в acppage добавлены системы NT6+[3]
  • 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-библиотек.

Ссылки

ReactOS
Search.png
Доклады
О ReactOSARWINSSЧеЗа
Информация Новости Выпуски новостейПереводы блоговНовости проектаВидеоReactOS на ХабреUSB от Вадима Галянта
Разработка Руководство по программированиюОтсутствующая функциональностьВетви разработкиКомпоненты системыReactOS и WineПлан работRoadmap ядра by VgalРазработчикиСовместимость с dll WindowsНаиболее значимые изменения за годИспользуемые проектыGoogle Summer of CodeИзвестные проблемы
Порты AMD64ARMXboxPowerPC
Компоненты Файловые системыРежим совместимостиОтчеты об ошибкахПечатьUSBЯдро
Загрузчик Восстановление MBRЗагрузка из GRUBПараметры загрузки
Прочее ARWINSSПриложения в ReactOSОформление ReactOSКоординаторы"Пасхальные яйца"Монетизация
Другое Типы ядерFreeWin95
Помощь
RAM-диск ReactOS по PXEс жесткого диска
Разработка Стиль написания кодаСтандарты RC-файловРабота с документациейВенгерская нотацияGNU Indent • [ Subversion : ветвислияниеиспользование TortoiseSVN ] • Основы переводаОтправка патчей
Репорты Отладка в VirtualBoxОтладка на экранДобавление программы в менеджер приложенийОтправка отчетов
Отладка Com0comGDBKdbgRossym.gdbRoswin.gdbWinDBGРуководство по WinDBGВключение трассировки ядраКоды DPRINTУдалённый отладчик ReactOS
Сборка CMakeRBuildФайлы RBuildАвтоматическое копирование файловСборка MINGW-w64Сборка модулейСреда сборки
Тестирование VirtualBoxVMwareQEMUHyper-VНеобходимый объём дискаПеренос файлов на виртуальный дискУстановка ReactOSУстановка драйверов
Сеть Общие папкиSambaNFS
Игры Установка DirectPlay
Обновление ReactOSЗагрузочная флешкаЧем можно помочь проектуСоздание нового пользователяЗвук и сеть в VirtualBoxСъемка и публикация видеоIRC-каналСторонние компонентыFAQReactOS как рабочая станцияReactOS и UEFI
Обзоры ОболочкаNTVDMWOWCommunity EditionИстория сайтаReactOS ServerКриптографияПО времен XP