Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Программируемые логические схемы и их применение»

Наберусь наглости и спрошу ещё раз. Про работу с памятью альтера флекс 10к.

Отправлено ex51 30 октября 2007 г. 18:02


Я всё со своим сумматором 8-)

Есть такой код:

module adder
(input clk, shEn, Marker, input [15:0] din, input [3:0] addrExt,
output addrClk, weS, weR, start, cpStart, output [3:0] addrIn, output [24:0] dout, output [15:0] result);
reg [5:0] counter;
//wire [3:0] addrIn;
wire [3:0] addr;
wire signed [24:0] sumn, sum;
//wire weS, weR;
//wire addrClk;
//wire start;
//wire cpStart;
wire cpRam;
wire [24:0] sIn;
wire aclk;
wire readRes;

initial counter = 6'd0;

dff tr1(!addrClk, aclk, start, , addrClk);
assign aclk = clk & !counter[5];

dff tr2(1'b1, !shEn, !counter[5], , start);

assign addrIn[3:0] = counter[3:0];

assign sum = sumn + {{9{din[15]}},din};
assign dout = sumn; // только для отладки!
assign cpStart = counter[4];
assign weS = addrClk & !clk;
assign weR = cpStart & weS;
mux2to1 #(25) muxd(cpStart, sum, 25'd0, sIn);
mux2to1 #(4) muxa(cpStart, addrExt, addrIn, addr);

sumRam rams(addrIn, sIn, weS, addrClk, weS, sumn);
assign readRes = !clk & !cpStart;
ramBuff ramr(addr, sumn[23:8], addrClk, readRes, weR, result);

always @(negedge addrClk, negedge start) begin
if(!start) counter <= 6'd0;
else counter <= counter + 1'b1;
end

endmodule

module mux2to1
#(parameter width = 2)
(input sel, input [width-1:0] in1, in2, output [width-1:0] out);

assign out = (sel) ? in2: in1;

endmodule

Вроде работает! Но когда я читаю результат из ramr то он почему-то расположен не с нулевого, а с первого адреса! Может подскажите где у меня ошибка? Что-то никак не могу понять в чём причина?
Если что, задал этот же вопрос на электрониксе, там приципил проектик с временной диаграммой для проверки, но там что-то молчат все. Может тут кто подскажет где копать?



Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 97:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru