motofan logo
6 страниц V  1 2 3 > »         
> 

Учимся Патчить Прошивку., Дисассемблируем ARM.

Arkasha18
сообщение 24.11.2005, 21:32 Закрепленное сообщение!



****

Группа: Администраторы
Сообщений: 242
Регистрация: 27.4.2004
Из: Санкт-Петербург
Пользователь №: 2

Рейтинг: 249.5



Всем привет.
И так будем учиться дисассемблировать прошивку. Тут все просто не чего сложного.

Я не буду объяснять как SHX разобрать, надеюсь все знают. Единственное условие… CG0(MemoryMap) должна быть слита с прошивкой, а то не чего не выйдет, т.е. один файл д.б.
--------------------------
ссылка на программу IDA Pro Advanced https://motofan.ru/soft/?action=view&id=246&parent=5
Запускаем IDA , выбираем файл прошивки (CG1), потом выбираем Processor type – ARMB, жмем ок.
Тут ставим галки на Create RAM section и Create ROM section.
Выставляем адреса:
RAM start address - 0x03FC0000
RAM size - 0x40000
ROM start address - 0x10080000
ROM size - 0x1F80000
Loading address - 0x10080000
Остальное оставьте так как есть.
Жмем Ок, и ждем.


По хорошему теперь еще оперативку будет правильно сделать, идем в меню:
Edit>segments>create>segment
Пишем:
Segment name – любое придумайте;
Start address - 0x12000000
End address - 0x12800000
Base – 0

Теперь переходи на сегмент ROM (жмем на Клаве ”g” пишем 10080000, должны перескочить на 10080000 адрес ).
Объявляем dword (жмем Alt-D, потом на кнопку Double word).
у меня это вылезло это
Код

ROM:10080000                 DCD 0x10BCD3D0

Появилось (оранжевым цветом).
Теперь жмем "O" (Буква латинская О ), должен появиться указатель на точку входа
у меня это вылезло это
Код

ROM:10080000                 DCD byte_10BCD3D0

Встаем на этот (byte_10BCD3D0) адрес курсором и жмем на Enter или просто двойной щелчок мышкой по этому адресу, вы перепрыгнете на адрес (10BCD3D0).

И так мы сейчас на 10BCD3D0.
Теперь сморим. ARM умеет работать в 2х режимах:
ARM - режим 32хразрядных опкодов и
THUMB - режим 16тиразрядных опкодов.
Для самой иды режим задается младшим битом адреса опкода.
т.е. если адрес например был бы 10A01D18 - то это был бы опкод в режиме ARM по адресу 10A01D18
а если адрес 10A01D19 то это опкод по адресу 10A01D18 в режиме THUMB
в ARM режиме набор команд более гибкий, но в THUMB за 1 цикл выполняется 2 команды - он быстрее.

Это мне так Vilko объяснял…я конечно же не Х.. не понял, так что буду говорить своими словами.
Нам сейчас надо задать ИДЕ режим в котором мы будем работать.
Мы стоим на адресе 10BCD3D0, если мы посмотрим на этот адрес в двоичной системе исчисления, то будет видно что это 000100000101111001101001111010000, так вот если последний байт – 0, то значит режим ARM, а если 1 – THUMB.
Теперь говорим идее в каком мы режиме будем работать:
Если THUMB то надо встать на один адрес выше, т.е если стояли например на 10BCD3CF этот адрес говорит что режим THUMB, значит встаем на один адрес выше (10BCD3CE) и
жмем (Alt+G) , выбираем ”T”,а в поле Value ставим 1 (режим THUMB).

А если мы бы определили что режим ARM, то на один адрес выше вставать не надо! Просто на этом же адресе жмем (Alt+G) , выбираем ”T”,а в поле Value ставим 0 (режим ARM).

И так…фух…устал уже (
У меня получилась такая картина:
Код

ROM:10BCD3CC                 DCB 0xE7; ч
ROM:10BCD3CD                 DCB 0xF9; •
ROM:10BCD3CE                 DCB    0;  
ROM:10BCD3CF                 DCB    0;  
ROM:10BCD3D0                 CODE32
ROM:10BCD3D0 byte_10BCD3D0   DCB 0xE3        ; DATA XREF: ROM:10080000 o
ROM:10BCD3D1                 DCB 0x21; !
ROM:10BCD3D2                 DCB 0xF0; Ё
ROM:10BCD3D3                 DCB 0xD1; T

У меня режим ARM !
Теперь встаем курсором на ROM:10BCD3D0 и жмем на Клаве ”c” (объявляем код). (кнопку С надо давить на адресе, около которого появилсяь надпись CODE16 или CODE32 в зависимости от режима )
Должен появиться АСМ примерно такого плана.
Код

M:10A01DA4; ---------------------------------------------------------------------------
ROM:10A01DA4                 CODE16
ROM:10A01DA4                 LDR     R1, =0x28880020; DATA XREF: ROM:10BCD424o
ROM:10A01DA6                 LDR     R0, =0x2201
ROM:10A01DA8                 PUSH    {R4,R5,R7,LR}
ROM:10A01DAA                 STMIA   R1!, {R0}
ROM:10A01DAC                 LDR     R0, =0x3011
ROM:10A01DAE                 MOV     R5, #0
ROM:10A01DB0                 STR     R0, [R1]
ROM:10A01DB2                 MOV     R0, #3
ROM:10A01DB4                 ADD     R1, #4
ROM:10A01DB6                 LSL     R0, R0, #0x11
ROM:10A01DB8                 STMIA   R1!, {R0,R5}
ROM:10A01DBA                 MOV     R0, #0

Собственно и все…дальше только остается объявлять код (вызов unk_address)…..и менять режим….режим меняется только после оператора BX.

Ссылка на литературу по ARM.
Краткий справочний по командам ARM. (Это от ARM9 в нашем ARM7 многих команд нет, учтите это)

P.S.
Задавайте вопросы, я понимаю что не чего не понятно, так что не стесняйтесь.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
hobbit19
сообщение 24.11.2005, 21:38


квант истории
******

Группа: Пользователи
Сообщений: 1 043
Регистрация: 1.4.2005
Из: Рязань
Пользователь №: 39 980
Модель телефона: (M)oTorola
Прошивка: testing/unstable
Победитель конкурса 2008

Рейтинг: 739.5



Arkasha18
Выставляем адреса:
RAM start address - 0x03FC0000
RAM size - 0x40000
ROM start address - 0x10080000
ROM size - 0x1F80000
Loading address - 0x10080000

это для всех прошивок?
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Arkasha18
сообщение 24.11.2005, 21:41



****

Группа: Администраторы
Сообщений: 242
Регистрация: 27.4.2004
Из: Санкт-Петербург
Пользователь №: 2

Рейтинг: 249.5



hobbit19,
Да. т.к. начало у всех одинаковое (ROM start address - 0x10080000)
а RAM тоже
RAM start address - 0x03FC0000
RAM size - 0x40000
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Inlined
сообщение 25.11.2005, 12:30


Интересующийся
**

Группа: Пользователи
Сообщений: 91
Регистрация: 5.9.2005
Из: Санкт-Петербург
Пользователь №: 50 635
Модель телефона: E398, DEFY

Рейтинг: 73.5



Самое плохое это то, что IDA в общем-то плохо умеет сам понимать, где код, а где данные.
Даже если запускать его анализ с EntryPoint, то он подумает-подумает, и определит от силы 1-2% процента кода.

Можно схитрить, выделить часть кода через скроллинг, и нажать C (предварительно выбрав нужный режим).
Тогда он лучше автоматически анализирует, но все. Большие блоки кода он считает данными, и их приходится обрабатывать руками :-(

Второе что плохо - так это сам код прошивки. Из-за особенностей адресации ARM архитектуры, данные и код находится рядом. А иногда таблицы по вызовам процедур прямо в самом коде.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 25.11.2005, 13:59


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



Inlined,
никто и не обещал, что будет легко и что ида сама все сделает :)
руками придется работать ОЧЕНЬ много. и твой метод - выделить все и пометить кодом - далеко не самый лучший и правильный.
правильнее будет идти по ходу выполнения кода и там где у иды цепочка прерывается - подсказывать ей - как найти код дальше...
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Arkasha18
сообщение 25.11.2005, 14:11



****

Группа: Администраторы
Сообщений: 242
Регистрация: 27.4.2004
Из: Санкт-Петербург
Пользователь №: 2

Рейтинг: 249.5



Добавляю:
Можно так же ориентироваться на примеры по сименам, вот например
http://forum.allsiemens.com/viewtopic.php?...der=asc&start=0
или вот
http://forum.siemens-club.org/viewtopic.php?TopicID=55280
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Inlined
сообщение 25.11.2005, 16:03


Интересующийся
**

Группа: Пользователи
Сообщений: 91
Регистрация: 5.9.2005
Из: Санкт-Петербург
Пользователь №: 50 635
Модель телефона: E398, DEFY

Рейтинг: 73.5



Vilko,
Цитата
никто и не обещал, что будет легко и что ида сама все сделает
руками придется работать ОЧЕНЬ много. и твой метод - выделить все и пометить кодом - далеко не самый лучший и правильный.


это и ежу понятно, что легко не будет.
этот метод лишь грубая обработка, после которой следует метод ручной обработки. согласись, что он лучше, чем ничего. хоть какую-то часть работы он может сделать - особенно, если если выделять непомногу.

очень хочется еще реализовать такой метод - из прошивки CG0 вытащить все 32-битные значения, находящиеся в ее диапазоне адресов и имеющие значения первых 4 бит - 01,05,09,13 (32bit-align +1)
таких чисел должно быть много, и все они `defacto' - на 95% = указатели на куски THUMB-кода (понятно, почему)
запихать их в IDA - и пусть он их анализует себе часа 2-3. тогда может что путное и выйдет

найти такие куски можно, но вот как их засунуть в IDA я пока не знаю, с его скрипт-языков пока не разбирался.

кроме того, я бы порекомендовал подгружать в IDA не только остальные CG-куски, а еще и обе области RAM.
в процессорную часть RAM копируется определенный код - причем для каждый прошивки разный, по разным адресам и т.п. да и в области основной RAM тоже много важных данных. эти дампы нужно предварительно снять - обязательно на той же версии прошивки.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 25.11.2005, 16:25


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



Цитата(Inlined @ Пятница, 25 Ноября 2005, 19:03)
это и ежу понятно, что легко не будет.
этот метод лишь грубая обработка, после которой следует метод ручной обработки. согласись, что он лучше, чем ничего. хоть какую-то часть работы он может сделать - особенно, если если выделять непомногу.

нет, этот метод скорее все-таки больше навредит, ибо таблица, обозначенная кодом или код не в том режиме только запутает.
Цитата
очень хочется еще реализовать такой метод - из прошивки CG0 вытащить все 32-битные значения, находящиеся в ее диапазоне адресов и имеющие значения первых 4 бит - 01,05,09,13  (32bit-align +1)
таких чисел должно быть много, и все они `defacto' - на 95% = указатели на куски THUMB-кода (понятно, почему)
запихать их в IDA - и пусть он их анализует себе часа 2-3. тогда может что путное и выйдет
найти такие куски можно, но вот как их засунуть в IDA я пока не знаю, с его скрипт-языков пока не разбирался.

ну тогда уж все указатели в пределах прошивки ис младшим битом=1, ибо thumb инструкции выровнены на 16 а не на 32.
но зато сами указатели(эти самые 32-битные значения) как раз будут выровненными на 32.
на самом деле подобное достаточно легко реализуется idc скриптом, но метод надо еще немного оптимизировать, например проверять наличие push в начале кода, на который идет указатель. скоро выложу подобный скрипт...

Цитата
кроме того, я бы порекомендовал подгружать в IDA не только остальные CG-куски, а еще и обе области RAM.
в процессорную часть RAM копируется определенный код - причем для каждый прошивки разный, по разным адресам и т.п. да и в области основной RAM тоже много важных данных. эти дампы нужно предварительно снять - обязательно на той же версии прошивки.
*


не, дампы снимать не самый правильный метод. точнее снять дамп "верхней RAM" - 12000000.. можно, а вот нижней - 03FC.... - большая часть затирается загрузчиком при переходе во флеш. НО! в самом начале кода легко находится процедура , всегда одинаковая, и ее таблица, которая перемещает код и данные из флешки в обе RAM, что легко повторяется скриптом IDA memcpy.idc
опять-же на днях будет скрипт, находящий процедуру и таблицы и проводящий все перемещения сам.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
hobbit19
сообщение 25.11.2005, 20:42


квант истории
******

Группа: Пользователи
Сообщений: 1 043
Регистрация: 1.4.2005
Из: Рязань
Пользователь №: 39 980
Модель телефона: (M)oTorola
Прошивка: testing/unstable
Победитель конкурса 2008

Рейтинг: 739.5



Vilko
а вобще какая достоверность кода будет после
дисассемблировании прошивки?
как ее можно повысить ( что бы потом меньше править)?
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 26.11.2005, 8:28


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



как и обещал - скриптик, ищущий все потенциальные указатели на thumb код и помещающий их как указатели и код, на который они указывают - как код :)
//

Код

//

#include <idc.idc>

//------------------------------------------------------------------------
static main(void) {
 auto bx_pc, ptr,from,to,size;

 from = AskAddr(here, "Please enter the start address");
 if ( from == BADADDR ) return;
 to = AskAddr(here, "Please enter the end address");
 if ( to == BADADDR ) return;

 ptr = from;
 while(ptr < to){
   bx_pc = Dword(ptr);
   if ((bx_pc > from)&&(bx_pc < to)&&((bx_pc & 1) == 1)){
     Message("Found %x\n", ptr);
     MakeDword(ptr);
     OpOff(ptr,0,0);
     SetReg(bx_pc-1,"T",1);
     MakeCode(bx_pc-1);
   }
   ptr = ptr + 4;
 }
 Message("Done\n");
}

начальный адрес задавать выровненным на 32бита!
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Arkasha18
сообщение 26.11.2005, 13:24



****

Группа: Администраторы
Сообщений: 242
Регистрация: 27.4.2004
Из: Санкт-Петербург
Пользователь №: 2

Рейтинг: 249.5



Vilko,
Круто :) Ща испробую.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Trog
сообщение 29.11.2005, 9:31


Мастер
****

Группа: Пользователи
Сообщений: 291
Регистрация: 7.4.2005
Из: Москва
Пользователь №: 40 276
Модель телефона: Motorola V620
Прошивка: R376_G_0E.66.0BR

Рейтинг: 60



Цитата(Arkasha18 @ Пятница, 25 Ноября 2005, 0:32)
Появилось (оранжевым цветом).
Теперь жмем "O" (Буква латинская О ), должен появиться указатель на точку входа
у меня это вылезло это
*



у меня вылезло вот такое
ROM:10080000 DCD unk_1022564F

переходим
ROM:1022564F unk_1022564F DCB 0x70 ; p ; DATA XREF: ROM:10080000o

судя по адресу - режим ARM

встаю на адрес ROM, нажимаю С и получаю...

Command "MakeCode" failed
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 29.11.2005, 9:47


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



Цитата
переходим
ROM:1022564F unk_1022564F DCB 0x70 ; p ; DATA XREF: ROM:10080000o

судя по адресу - режим ARM

встаю на адрес ROM, нажимаю С и получаю...

Command "MakeCode" failed

не. не совсем правильно.
ты видишь адрес 1022564F:
это режим thumb а не arm(адрес нечетный!)
и вставать ты должен на адрес 1022564E, его обозначить как thumb и его пометить как код.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Trog
сообщение 29.11.2005, 10:18


Мастер
****

Группа: Пользователи
Сообщений: 291
Регистрация: 7.4.2005
Из: Москва
Пользователь №: 40 276
Модель телефона: Motorola V620
Прошивка: R376_G_0E.66.0BR

Рейтинг: 60



разобрался..
есть неточность в инструкции..

кнопку С надо давить на адресе, около которого появилсяь надпись CODE16 или CODE32 в зависимости от режима
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 29.11.2005, 10:29


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



Trog,
дык ты ж координатор :) поправь :))
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Trog
сообщение 29.11.2005, 16:59


Мастер
****

Группа: Пользователи
Сообщений: 291
Регистрация: 7.4.2005
Из: Москва
Пользователь №: 40 276
Модель телефона: Motorola V620
Прошивка: R376_G_0E.66.0BR

Рейтинг: 60



а как дадбше анализировать и править код??
например для

отключение проверки залоченности ОТП:
10A6325E:
MOV R0,0
BX LR
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 30.11.2005, 7:21


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



Trog,
а дальше - анализировать код, пытатся понять(часто с помощью эмулятора) что делает та или иная процедура, искать нужные тебе и думать, что в них ихменить для достижения желаемого результата.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Trog
сообщение 30.11.2005, 7:33


Мастер
****

Группа: Пользователи
Сообщений: 291
Регистрация: 7.4.2005
Из: Москва
Пользователь №: 40 276
Модель телефона: Motorola V620
Прошивка: R376_G_0E.66.0BR

Рейтинг: 60



ну эт понятно..
ну вот ты написал в теме Ковырнём Прошивку ...

отмена проверки версии бута:
с 10A01CF6 по 10A01D35 заменяем код NOP'ами

или

отключение проверки залоченности ОТП:
10A6325E:
MOV R0,0
BX LR

вот как это сделать???
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
GregF
сообщение 8.12.2005, 6:57


Новичок
*

Группа: Пользователи
Сообщений: 26
Регистрация: 4.12.2005
Пользователь №: 60 690
Модель телефона: V551 Cingular
Прошивка: R47_G_08.17.0FR

Рейтинг: 0



Для знающих Инглыш пару ссылок: ;)

http://www.arm.com/miscPDFs/8031.pdf
http://www.heyrick.co.uk/assembler/qfinder.html
http://www.heyrick.co.uk/assembler/index.html
http://www.tek-tips.com/viewthread.cfm?qid=1101136&page=1

http://ipodlinux.org/ARMDev :
http://www.arm.com/pdfs/QRC0001H_rvct_v2.1_arm.pdf - была выше, но эта работает - ARM Instruction Set Quick Reference Card
http://www.arm.com/pdfs/QRC0001H_rvct_v2.1_thumb.pdf - Thumb Instruction Set Quick Reference Card
http://www.arm.com/pdfs/DVI0027B_7_R3.pdf - ARM7TDMI Product Overview
http://www.arm.com/pdfs/DDI0210C_7tdmi_r4p1_trm.pdf - ARM7TDMI Technical Reference Manual
http://www.arm.com/pdfs/DUI0056D_ADS1_2_Dev.pdf - ARM Developer Guide (http://www.arm.com/pdfs/DUI0056D_ADS1_2_Dev.pdf) (Runtime conventions)
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
KOPAY
сообщение 8.12.2005, 14:54


Новичок
*

Группа: Пользователи
Сообщений: 17
Регистрация: 11.4.2005
Пользователь №: 40 532
Модель телефона: E398

Рейтинг: 1



ребят, такой вопрос, открыл в иде файл прошивки, правдв ида 4.3, так вот всё расставил, ажреса, сегментацию сделал, но при переходе на 10080000 и про объявлении dword в том месте, где у вас DCD byte_10BCD3D0 у меня DCD 0x11FE0000 почему так? что я сделал не так?
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
GregF
сообщение 9.12.2005, 0:45


Новичок
*

Группа: Пользователи
Сообщений: 26
Регистрация: 4.12.2005
Пользователь №: 60 690
Модель телефона: V551 Cingular
Прошивка: R47_G_08.17.0FR

Рейтинг: 0



Небольшая добавка:

Архитектура процессора ARM (внизу страницы PDF)
The ARM Instruction Set Architecture - http://www.arm.com/products/CPUs/architecture.html
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
KOPAY
сообщение 9.12.2005, 14:43


Новичок
*

Группа: Пользователи
Сообщений: 17
Регистрация: 11.4.2005
Пользователь №: 40 532
Модель телефона: E398

Рейтинг: 1



при чём тут? ведь 10080000 - это начало уже? и у меня оно тоже, или начало это то, что появляется? :)
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
KOPAY
сообщение 9.12.2005, 15:20


Новичок
*

Группа: Пользователи
Сообщений: 17
Регистрация: 11.4.2005
Пользователь №: 40 532
Модель телефона: E398

Рейтинг: 1



объясните мне, что же я не так делаю? сначала открываю с помощью shx прошивку, убираю галочку с separate затем жму сплит и получаю файл CG1 беру, идой открываю его, выставляю там все адреса, делаю сегментацию. перехожу на начало, кстати, начало ли написано в параметрах файла в shx? так вот заием я перехожу на него, а там та картина, какая и была раньше, переход совершенно не на оот адрес, да и, смотря код весь, там очень много пустоты, какие-то неизвестные мне до этого команды. подскажите кто-нибудь, плиз
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Arkasha18
сообщение 9.12.2005, 16:02



****

Группа: Администраторы
Сообщений: 242
Регистрация: 27.4.2004
Из: Санкт-Петербург
Пользователь №: 2

Рейтинг: 249.5



KOPAY,
Возъми другую прошивку (не 42, 43 и не 44), другую
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
UNLM-Trojan
сообщение 10.12.2005, 13:20


МотоТроян
***

Группа: Пользователи
Сообщений: 143
Регистрация: 15.10.2005
Из: Украина, Ровно
Пользователь №: 54 658
Модель телефона: V3r
Прошивка: R4515..74R

Рейтинг: 42.5



Подскажите plz... Можно этими манипуляциями поправить прошивку так, что-бы LangPack она читала начиная из другого адреса... Дело в том, что Лэнг ОЧЕНЬ "жырно" розлегся в прошивке (~1.3 Mb)... Поставить полноэкранное меню в DRM не получится, потому-что мало пространства между ним и LangPack'ом(~786 Kb)... А вот если LangPack обрезать до одного языка и сдвинуть в прошивке, то появится не мало места которое можно забить DRM'ом...

P.S: Прошивка 365...32r
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
GregF
сообщение 10.12.2005, 23:09


Новичок
*

Группа: Пользователи
Сообщений: 26
Регистрация: 4.12.2005
Пользователь №: 60 690
Модель телефона: V551 Cingular
Прошивка: R47_G_08.17.0FR

Рейтинг: 0



Цитата(miha 666 @ Суббота, 10 Декабря 2005, 5:46)
ЛЮЮЮДИ У МУНЯ ИДА48 ПО ССЫЛКЕ НЕ КАЧАЕТСЯ ВЫКИНЬТЕ КТО-НИТЬ ГДЕ ЕЩЕ ВЗЯТЬ,
А ТО Я В НЕТЕ МАКСИМУМ НА МИНУТ 20!!!!
:o
*


http://samsfan.ru/soft/?action=list&parent=10
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
demanishe
сообщение 26.12.2005, 6:58


Новичок
*

Группа: Пользователи
Сообщений: 1
Регистрация: 24.12.2005
Пользователь №: 63 281
Модель телефона: e398
Прошивка: E1 Cristmas 6FR

Рейтинг: 0



а другой адрес IDA есть?
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
FatumNNM
сообщение 1.1.2006, 0:23


Интересующийся
**

Группа: Пользователи
Сообщений: 37
Регистрация: 6.5.2005
Пользователь №: 41 952
Модель телефона: Motorola L6 (Black)
Прошивка: R3443H1_G_0A.65.0BR

Рейтинг: 0



demanishe, я отсуда скачал: ftp://213.148.6.195/Software/Reversing/
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
HolodovAlexey
сообщение 2.1.2006, 17:45


Опытный
***

Группа: Пользователи
Сообщений: 149
Регистрация: 1.7.2005
Из: Москва
Пользователь №: 45 223
Модель телефона: Motorola Sholes

Рейтинг: 24.5



Извините за оффтоп... <_<
А что этим можно добиться в итоге? Это непосредственное редактирование исходного кода ОС телефона?
Ещё раз sorry. =)
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
aligatro
сообщение 3.1.2006, 2:38


Мотоблуджекер
******

Группа: Пользователи
Сообщений: 849
Регистрация: 14.4.2005
Пользователь №: 40 684
Модель телефона: Нокиа

Рейтинг: 155



Цитата(HolodovAlexey @ Понедельник, 2 Января 2006, 12:45)
Извините за оффтоп... 
А что этим можно добиться в итоге? Это непосредственное редактирование исходного кода ОС телефона?
Ещё раз sorry. =)
*


Будем патчить проши для поддержки разных форматов звуков(мелодий) к примеру.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Exebyte
сообщение 14.1.2006, 19:46


Интересующийся
**

Группа: Пользователи
Сообщений: 65
Регистрация: 11.6.2005
Пользователь №: 44 009
Модель телефона: Motorola E398=>E790
Прошивка: R373_G_0E.30.44R

Рейтинг: 34.5



Цитата(Arkasha18 @ Суббота, 14 Января 2006, 3:30)
Exebyte, Через IrDA 100% не получиться.


Когда ещё в придачу и прошу пропатчить для приёма загрузчика через IrDA, то получится...
Говорю прошу, потому как бутлоадер пока для правки недоступен... ;)


Цитата(palach @ Суббота, 14 Января 2006, 16:44)
Exebyte,
Возможно, как-то получится подключить интересующихся людей, например, отсюда http://forum.sources.ru/index.php?showforum=38


Спасибо.. загляну.. :)
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
forpost
сообщение 16.1.2006, 15:54


Интересующийся
**

Группа: Пользователи
Сообщений: 34
Регистрация: 14.7.2005
Пользователь №: 46 140
Модель телефона: milestone XT720
Прошивка: 2.1

Рейтинг: 8.5



нашел тут интересную статейку http://xtin.km.ru/view.shtml?id=154
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Sinensis
сообщение 16.1.2006, 19:33


Новичок
*

Группа: Пользователи
Сообщений: 4
Регистрация: 15.1.2005
Из: Волгоград
Пользователь №: 34 319
Модель телефона: C380
Прошивка: R365_G_0B.D3.06R

Рейтинг: 3



Вот нарыл еще док:
Описание ARM на русском: http://sub.chipdoc.ru/html.cgi/txt/doc/mic...ndex.htm?fid=12
Книга на английском: http://www.peter-cockerell.net/aalp/html/frames.html
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
0vZ
сообщение 17.1.2006, 7:08


Мото-юрист
*****

Группа: Почётные мотофаны
Сообщений: 371
Регистрация: 15.2.2004
Из: Ростов-на-Дону
Пользователь №: 1 173
Модель телефона: X100/C350/SP3i
Прошивка: G1/74R/WinMobile2005

Рейтинг: 278



Вот линки по реверсингу самсунгов на ARM7 (нам тоже многое подойдет)
http://sobakator.samsfan.ru/
Ещё можно поискать хорошую прогу BinEdit, имеет встроенный дизассемблер и ассемблер ARM7, и весит это чудо 0.5 Мб
вот линк, но качать могут только зарегистрированные на этом форуме: http://forum.samsung-mobile.ru/download.php?id=570
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
bad-rustamka
сообщение 20.1.2006, 18:42


Мастер
****

Группа: Пользователи
Сообщений: 225
Регистрация: 22.3.2005
Из: Самара
Пользователь №: 39 309
Модель телефона: photon
Прошивка: cm10

Рейтинг: 88



Подскажите плз адрес точки входа в прошу 6fr, а то ИДА выдаёт полнейшую бедиберду, если делать по мануалу, написанному выше
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
KOPAY
сообщение 21.1.2006, 9:49


Новичок
*

Группа: Пользователи
Сообщений: 17
Регистрация: 11.4.2005
Пользователь №: 40 532
Модель телефона: E398

Рейтинг: 1



да, скажите пожалуйста

2 Exebyte
писал патчи на сименс, хорошие патчи, могу дать их. возможно, по аналогии можно сделать подобие.
могу привести список патчей.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
KOPAY
сообщение 21.1.2006, 16:19


Новичок
*

Группа: Пользователи
Сообщений: 17
Регистрация: 11.4.2005
Пользователь №: 40 532
Модель телефона: E398

Рейтинг: 1



ребят, способен ли кто-нибудь из нас написать прогу, которая прозванивала бы конкретную процедуру во время работы телефона и выполняла её?
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 22.1.2006, 12:53


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



KOPAY,
выполняла - легко. а "прозванивала" это что?
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
KOPAY
сообщение 22.1.2006, 13:12


Новичок
*

Группа: Пользователи
Сообщений: 17
Регистрация: 11.4.2005
Пользователь №: 40 532
Модель телефона: E398

Рейтинг: 1



Цитата(Vilko @ Воскресенье, 22 Января 2006, 15:53)
KOPAY,
выполняла - легко. а "прозванивала" это что?
*


я это и имел ввиду. т.е. в процессе работы телефона выполнять конкретную процедуру по заданному нами адресу.
Уже есть такая? можешь поделиться, если есть.
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Vilko
сообщение 22.1.2006, 16:09


Мотокодер
******

Группа: Легенды MotoFan.Ru
Сообщений: 1 331
Регистрация: 23.6.2003
Из: Москва
Пользователь №: 71
Модель телефона: E398+, Е1000, ...

Рейтинг: 1116



KOPAY,
есть много разных способов запуска.
ты имеешь ввиду просто встройку своей процедуры в какой-либо процесс или принудительный запуск процедуры, инициированный "извне"?
Юзер вышелВ друзьяВизиткаП/Я
К началу страницы
+Ответить
Учимся Патчить Прошивку., Дисассемблируем ARM. · Патчи и всё для них · Forum
 

6 страниц V  1 2 3 > » 
Ответ в темуСоздание новой темы
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



Текстовая версия Сейчас: 8.7.2025, 13:08

Форум живёт: