Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: C5510 обнаружение насыщения
Форум разработчиков электроники ELECTRONIX.ru > Цифровая обработка сигналов - ЦОС (DSP) > Алгоритмы ЦОС (DSP)
Warlord
Задача: узнать было ли насыщение при операции (например сложение).
Решение:
сбрасываю все 4 бита ACOVx в регистре CT0_55 (адрес 0x0002)
Код
*(int *0x0002)=*(int *0x0002)&39FF;

вычисляю
Код
long a,b,c;
int d;
a= 0x70000000;
b= 0x70000000;
c = _lsadd(a,b); // (сложение с насыщением)

проверяю
Код
d=*(int *0x0002)|0xC600;

Оптимизация -o3. Компилер оптимизирует так что второго чтения регистра нет (выдержки кода):
Код
   MOV *AR3, AR1; считал
   AND #0x39ff, AR1, AR1; изменил
   MOV AR1, *AR3;  записал
   ADD dbl(*SP(#0)), AC0, AC0; выполнил сложение с насыщением
   MOV #-14848, AR2; есть 0xC600
   AND AR1, AR2; - вот тут оптимизатор решил сэкономить на обращении к памяти, взял                        ;припасенный результат
   MOV AR2, *SP(#6); спокойно положил в переменную d ложный результат

Как написать верный С-код в этом случае?
Edmundo
Цитата(Warlord @ Nov 8 2006, 16:24) *
Как написать верный С-код в этом случае?

Может, так?

Код
*(volatile int *0x0002)=*(volatile int *0x0002)&39FF;
d=*(volatile int *0x0002)|0xC600;

А еше лучше:

Код
#define CT0_55       (*((volatile int *)0x0002))

CT0_55 &= 39FF;
d = CT0_55 | 0xC600;
Warlord
Спасибо, помогло. Еще вопрос: почему компилер сделал 3 команды
Код
        MOV *AR3, AR1
        AND #0x39ff, AR1, AR1
        MOV AR1, *AR3

(дальше регистр AR1 нигде не используется)
на которые уйдет 3 цикла, хотя можно обойтись одной:
Код
  AND #0x39ff, *AR3
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.