PDA

Просмотр полной версии : Как снять защиту CD Star Force


superboy4
26.10.2007, 19:52
Меня БЕСИТ эта защита! Например, если ты поцарапал диск, то игра не запустится. Знаете же игру Пираты Карибского моря и файл в ней 'engine.dll'? Всё из-за него, я даже уверен,что это файл защиты, посмотря на свойства. Надо его заменить на такой же точно файл, не выполняющий защиту, а лишь запускающий саму игру 'engine.exe'. Защиту Star Force ещё никто не поломал, так что лучше подменить её. Я не знаю, насколько я прав.

FeraS
26.10.2007, 20:01
сделай образ алкоголем

sys(64)
26.10.2007, 20:04
torrents.ru/forum/viewtopic.php?t=101258

superboy4
26.10.2007, 20:04
Ну сделал, ну и что, всё равно, зараза, не видит копию-диск, а с оригинала пашет!!!

Onix
26.10.2007, 20:48
http://gamecopyworld.com

superboy4
12.11.2007, 20:54
Оригинал-то у меня в беспонтовом состоянии из-за того, что постоянно пихаю в CD-rom!!!!как отучить Pirates of Caribbean от диска??? Подкиньте мне хакнутую DLL-ку(engine.dll)!!!!

BlackCats
12.11.2007, 20:57
сам хотел создать тему, кароче такая байда: диск друга - сильно исцарапал, у меня работает, но у друга сидиром просто не пррочтёт, копии - последним неро(8) делал, всёравно нехочет работать, устанавливается норм, а при проверке диска говорит"вставте лецензию" мне неохота ему новый диск покупать... он 300р стоит..

[dword]
12.11.2007, 21:02
Alcohol и подобные ему программы, эмуляторы в т.ч давненько уже не берут ее. Тут индивидуальный подход к каждой игре нужен, отладчик\дизасм. в зубы и вперед. Проверка на физическом уровне проходит, никакие образы и топологии не помогут (за исключ. старых версий). Это больше вопрос к реверсерам наверное.
Вывод:
Искать NoCD сделанный уже за вас
Делать его самому.

superboy4
12.11.2007, 21:04
Да, ты прав, даже старрффак не помогает, вылезает ета хррень

Фещ
12.11.2007, 21:06
Как скопировать диск защищенный StarForce 3

Ваш CD-привод не работает со StarForce?
Вы не хотите каждый раз вставлять диск с игрой в привод, боясь поцарапать его?
Тогда эти советы для Вас. (проверено на самой «неломаемой» игре «В Тылу Вага»)
Что понадобиться:
1. Alcohol 120% - желательно последней версии (испытано на 1.9.2.1705)
2. UltraISO - желательно последней версии (испытано на 7.21 SR2)
3. Лицензионный диск с игрой

Что делать:
1. В папке куда установлен Alcohol 120% находим файл AxType.ini, и в конец файла добавляем следующие строчки:
----------линия отреза----------
[StarForce 3.x сonfig]
MAX Read Speed=65535
Skip Read Error=0
Fast Skip Read Error=0
Read SubChannel Data=0
Read PreGap Area=0
DPM=1
DPM Precision=1
MAX Write Speed=65535
Fix EFM Error=0
Burn RMPS on Disc=0
RecordMethodCount=4
RecordMethod_00=0x01
RecordMethod_01=0x02
RecordMethod_02=0x03
RecordMethod_03=0x04
----------линия отреза----------
Либо создаем подобный профиль вручную:


Некоторые люди рекомендуют устанавливать чекбокс «Чтение субканальных данных…». У меня при данной настройке пустой .mdf не монтировался. Появлялось сообщение «неверный файл-образ».
Запускаем копирование диска с данным профилем.
Скорость измерения DPM лучше установить равной 1

После того как DPM измерен и началось копирование диска, процесс можно прервать. На вопрос «сохранить ли файлы» ответить утвердительно.
2. В UltraISO открываем файл *.mdf и удаляем из него все файлы и папки.
Сохраняем в виде BIN. Полученный *.bin переименовываем в *.mdf, а *.cue просто удаляем. (Вместо *, естественно имя игры.) В итоге остаются два файла *.mdf и *.mds
3. Выключаем компьютер, открываем корпус и отключаем все CD-приводы.
Другой вариант – в BIOS отключаем IDE канал на котором стоят привод(ы) CD. Именно IDE канал, иначе, по крайней мере у меня, драйвер StarForce все равно определяет наличие CD-привода.
4. Включаем компьютер, монтируем образ, и запускаем игру.

===============================================

С третьим старфорсом это прокатывало, с 4-ым - вряд ли.


или

Вот еще статейка, как отучить игры от проверки CD-ROM (на примере Hellfire):

Использованные программы: Hellfire v2.0, W32Dasm v8.9, Dos Navigator v1.5
В статье рассматриваются следующие вопросы:

Заменяем в программе HellFire v2.0 проверку с диска CD-ROM на сетевой диск
Пишем Fake-CD для OS Windows 95
Заменяем в программе HellFire v2.0 проверку с диска CD-ROM на сетевой диск

Суть проблемы состоит в том, чтобы доказать программе, что винчестер на самом деле совсем не винчестер, а CD-ROM. Или скажем - как в данном случае - в выдаче за локальный CD сетевого, ну один CD на работе, а играть-то всем охота!
Приступим. Цель - Функция GetDriveType(). Она возвращает тип диска, имя которого ей передали. Вот ее прототип:


UINT GetDriveType(LPCTSTR lpRootPathName);
Функция возвращает следующие значения:

Числовое
значение Идентификатор Описание диска
0 - Невозможно определить тип
1 - Диск не найден
2 DRIVE_REMOVABLE Гибкий (возможна замена)
3 DRIVE_FIXED Жесткий (замена невозможна)
4 DRIVE_REMOTE Сетевой диск
5 DRIVE_CDROM CD-ROM
6 DRIVE_RAMDISK RAM - Диск

Стандартно программа получает список всех дисков, проверяет их на "CDромность" и по нахождению проверяет наличие нужных файлов. Для проверки, необходимо, очевидно, сравнить возвращаемое значение с 5. Найдем этот момент программы, вот как он выглядит после дизассемблирования HellFire с помощью W32Dasm :


Reference To: KERNEL32.GetDriveTypeA, Ord:00DFh |
:0041D976 FF151CA56F00 Call dword ptr [006FA51C]
:0041D97C 83F805 cmp eax, 00000005
:0041D97F 752A jne 0041D9AB

В принципе можно использовать любой другой дизассемблер, или SoftICE, в последнем случае для нахождения нужного куска необходимо написать:

bpx GetDriveType
bpx GetDriveTypeA
В самом же W32Dasm можно воспользоваться списком использованных функций. Ищем KERNEL32.GetDriveTypeA и два раза щелкаем по функции мышью. В IDA такой список есть в конце отдизассемблированного файла. Листинг полученный Sourcer'ом придется исследовать обычным текстовым поиcком.
Запишем HEX-DUMP этого куска и найдем его в шеснадцатеричном редакторе. Например в DN: откроем файл hellfire.exe по F3, далее F4 (переход в HEX режим), F7 (поиск), в строке ввода HEX строки введем записанное ранне и вперед (т.е. ENTER).

Вместо 83F805 введем 83F804 и любой из подключенных сетевых дисков теперь будет восприпринят прораммой за CD, иначе введем 83F803 - тогда жесткие диски будут приниматься за CD. Фантазия может развиваться по-любому, можно изменить условие перехода после сравнения, тогда не придется заботится о типе диска.

Вот и все на сегодня, в следующий раз можно будет поговорить о минимизации количества данных, копируемых с диска. Эта проблема отнюдь не тривиальна, так как файлы обычно храняться в виде типа PAK как, например в QUAKE. Для простых же программ можно посоветовать обнулить все WAV, AVI файлы. Для этого есть специальные утилиты, но, конечно, проще создать файл нулевой длинны с таким же именем, например по Shift-F4 в любом дисковом коммандере (DN,NC,etc.).

Пишем Fake-CD для OS Windows 95

Для DOS существовала прекрасная утилита - FakeCD, которая подменяла MSСDEX и эмулировала таким образом CD-диск который, на самом деле, был каталогом на винчестере. Для Win95 такую программу найти не просто, поэтому необходимо ее сделать самим. Этим мы и займемся, тем более, что это будет прекрасная практика по копанию в недрах 95'ого.

Посмотрим на проблему, обсуждавшуюся раннее, с другой стороны. Заменим не использование функции, а саму функцию. Если в DOS для замены функций необходимо только было изменить обработчик прерываний, то в Windows такой финт уже не поможет. Выясним, где "живет" GetDriveType(). И - о ужас - это главная библиотека Win95 KERNEL32.DLL. Что делать? Как всегда, запастись кофе и напуcтить на KERNEL32.DLL дизассемблер. OK, ждем окончания процесса и смотрим список экспортируемых функций. Вот нужная нам:

Exported fn(): GetDriveTypeA - Ord:013Fh
:BFF777C4 57 push edi
:BFF777C5 6A21 push 00000021
...
...
...
:BFF777E1 F2 repnz
:BFF777E2 AE scasb

* Referenced by a (U)nconditional or ©onditional Jump at Address:
|:BFF777DA©
|
:BFF777E3 648F02 pop dword ptr fs:[edx]
:BFF777E6 83C408 add esp, 00000008
:BFF777E9 5F pop edi
:BFF777EA E9E5D4FFFF jmp BFF74CD4
Делаем переход в конце(кнопка Jump to на панели W32Dasm) и видим продолжение. Функция, оказывается-то, длинная! Не будем в ней разбираться, а лучше вспомним как происходит возврат значения из функции. Т.о. ищем строку типа

mov eax,03000000
Нашли? Далее, как и при любом взломе, запомним последовательность HEX кодов нужной команды (а лучше нескольких следующих, так как загрузка в аккумулятор числа 3 не самая редкая операция) и найдем этот блок в копии библиотеки (в копии - потому что файл используется системой и не может быть изменен). Все, осталось лишь в режиме DOS подменить KERNEL32.DLL. Перезагрузимся и в Проводнике насладимся результатом - все ваши жесткие диски представленны в виде кругленьких пластинок ранее обозначавших CD.
А теперь - для ленивых - кусок кода, который возвращает 3:

* Possible Reference to String Resource ID=00003: "....."

| :BFF74E0F B803000000 mov eax, 00000003 //Возвращаемое значение
:BFF74E14 EB05 jmp BFF74E1B //Переход на возврат

* Referenced by a (U)nconditional or ©onditional Jump at Addresses:
|:BFF74DEB©, :BFF74DFC©, :BFF74E0D©
|

* Possible Reference to String Resource ID=00006: "..."
Да - лучше сохранить старый KERNEL32, так как некоторые программы могут не оценить ваш юмор, и решить, что несколько CD и ни одного винчестера - это слишком. А вообще идеально было бы изменить функцию коренным образом. Скажем сделать CD дисками все, начиная с T. Тогда можно было бы подключать subst'ом каталоги, которые были бы CD, а винчестеры остануться винчестерами. Но это уже задание на дом. Удачи!


честно стырено с 0day.kiev.ua :)

superboy4
12.11.2007, 21:09
дА ты прав, [dword], нужно дизассемблировать и декомпилировать экзешник, чтобы в нём не было процедуры вызова библиотечки защиты. её несложно определить,хоть и строк десятки тысяч с подключаемыми модулями, вероятно...

Дрэгги
12.11.2007, 23:38
http://forum.antichat.ru/threadnav51591-1-10-%E7%E0%F9%E8%F2%E0.html вот еще почитай там ниже есть пост.

superboy4
28.11.2007, 16:21
Понимаете, я НЕ собираюсь зарабатывать на защите StarForce деньги, я лишь хочу без диска играть!!!!