[an error occurred while processing this directive]
Знак в Verilog.
(«Телесистемы»: Конференция «Программируемые логические схемы и их применение»)

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

Отправлено cx 17 февраля 2006 г. 11:43

Код:

module test(
input clk,
input signed [3:0] in,
output signed [7:0] out);

parameter signed [3:0] coeff0 = 10'b1010; // -6 or 10

reg signed [3:0] temp;
assign out = temp * coeff0;

always @(posedge clk) temp <= in;

endmodule

работает верно. В симуляторе Quartus-а при in=-3 out=18, при in=5 out=-30.

Код:

module test(
input clk,
input signed [3:0] in,
output signed [7:0] out);

parameter signed [3:0] coeff0 = 10'b1010; // -6 or 10

reg signed [3:0] temp [1:0];
assign out = temp[0] * coeff0;

always @(posedge clk) temp[0] <= in;

endmodule

В симуляторе Quartus-а при in=-3 out=-126, при in=5 out=50. Т.е. умножитель стал беззнаковым.

Этой чей глюк. Помогите разобраться.

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

Ответы


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

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

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

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

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


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

E-mail: info@telesys.ru