реклама на сайте
подробности

 
 
> ARMv6 iOS уходит в перезагрузку при делении на 0.0f c dze = 1, Floating point exception trapping
ShiftZ
сообщение Apr 7 2011, 10:34
Сообщение #1





Группа: Новичок
Сообщений: 7
Регистрация: 7-04-11
Пользователь №: 64 183



Всем привет, товарищ посоветовал данный форум в качестве последней надежды.
Есть iPhone с iOS 4.2. Нужно отловить деление на 0.0f в произвольном месте. В исходном состоянии iOS выставляет RunFast mode в регистре fpscr и сбрасывает все флаги floating point exception trapping. Что я делаю -

Код
uint fpscr = 0;
asm volatile("fmrx %0, fpscr" : "=r" (fpscr));  // читаю значение регистра fpscr
fpscr &= ~(3 << 24);   // сбрасываю флаги deafault NaN mode и flush to zero mode (disable RunFust)
fpscr |= (1<<8) | (1<<9) | (1<<10) | (1<<11) | (1<<12) | (1<<15);  // Выставляю fpe trapping на div by zero, invalid op и т.д.
asm volatile("fmxr fpscr, %0" : : "r" (fpscr)); // Записываю значение обратно в регистр


Далее такая строчка.
float a = 0;
float b = 1 / a;

После деления iOS уходит в перезагрузку. Почему??? И как это пофиксить?

Сообщение отредактировал ShiftZ - Apr 7 2011, 10:36
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
ShiftZ
сообщение Apr 7 2011, 14:26
Сообщение #2





Группа: Новичок
Сообщений: 7
Регистрация: 7-04-11
Пользователь №: 64 183



Вообще задача стоит отловить деление на 0.0f и просто невалидные операции с плавающей точкой в большой программе.

На другом форуме подсказали что дело может быть в iOS. Так как приложения запускаются по дефолту в RunFast mode, то обратотчики исключений не выставляются (адреса хандлеров). Есть ли в ARM11 такие регистры хранящие адреса переходов в случае исключения?

Сообщение отредактировал ShiftZ - Apr 7 2011, 14:26
Go to the top of the page
 
+Quote Post
AlexandrY
сообщение Apr 8 2011, 09:41
Сообщение #3


Ally
******

Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050



Цитата(ShiftZ @ Apr 7 2011, 17:26) *
Вообще задача стоит отловить деление на 0.0f и просто невалидные операции с плавающей точкой в большой программе.

На другом форуме подсказали что дело может быть в iOS. Так как приложения запускаются по дефолту в RunFast mode, то обратотчики исключений не выставляются (адреса хандлеров). Есть ли в ARM11 такие регистры хранящие адреса переходов в случае исключения?


Адрес перехода Undefined instruction trap у всех 11-х ARM-ов в одном и том же месте.
Это адрес 0x00000004 или 0xFFFF0004 (зависит от установки флага в контрольном регистре MMU).
Я бы подключил JTAG и поставил там брекпойнт. Надежней всего.

Кстати, только JTAG может показать, было ли вообще чтение-запись в этот вектор и если было то откуда оно производилось.
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 17:03
Рейтинг@Mail.ru


Страница сгенерированна за 0.02631 секунд с 7
ELECTRONIX ©2004-2016