[an error occurred while processing this directive]
Не-а, попробовал, до лампочки, как и добавить-убрать 16000. Ещё раз - если нет условного оператора, просто (+)
(«Телесистемы»: Конференция «Языки описания аппаратуры (VHDL и др.))

миниатюрный аудио-видеорекордер mAVR

Отправлено ReAl 17 марта 2006 г. 16:47
В ответ на: Попробуй написать localparameter signed (-) отправлено <font color=gray>Tiro</font> 17 марта 2006 г. 15:19

`line_wrap( 7 - shift) - то всё пучком.
Поигрался ещё, в том числе


localparam signed low = 1, len = 60, base = 16384;
`define line_wrap1(val) ((base + val + len - base ) % len)

и вот что выяснилось. Если val вида ((low ? 7 : 12) - shift), то!!!

`define line_wrap1(val) ((base + val + len - base ) % len)
возвращает результат, соответствующий
`define line_wrap1(val) ((base + val) % len)

а

`define line_wrap1(val) ((val + len) % len)
возвращает результат, соответствующий
`define line_wrap1(val) ((val) % len)
т.е. - само то отрицательное число, разогнанное не имеющееся количество бит

Т.е. с первым положительным числом отрицательное складывается правильно, а всё, что после отрицательного - игнорируется. Но только если было (?:). Если этого не было, то всё нормально независимо от порядка.

Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 
NoIX ключ Запомнить

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Rambler's Top100 Рейтинг@Mail.ru
Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание

E-mail: info@telesys.ru