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

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

вопрос про ресурсы(+)

Отправлено beginer 13 августа 2007 г. 12:14
В ответ на: Не совсем так. Так было раньше. Сейчас вовсю пошли FPGA со встроенной памятью-загрузчиком. Как пример - MAX-II или LatticeXP. Реальное отличие в структуре. У CPLD это матрица вида ([НЕ]-И-ИЛИ) с небольшими "туда-сюда", а у FPGA это LUT-ы, мелкие блочки загружаемого ОЗУ. отправлено SM 13 августа 2007 г. 00:14

набросал небольшой проект (4 сенсора + различные режимы мигания светодиодов) в качестве девайса выбрал EPM7160slc84, компиляция показывает total macrocells 113/160(70%), может я чего не так сваял, только уж больно быстро 70 % израсходовались, боюсь если чего еще придеться добавить - ресурсов не хватит, вот проект на верилоге, посмотрите если не сложно:
module blink_leds
(
// {{ALTERA_ARGS_BEGIN}} DO NOT REMOVE THIS LINE!
sensor, sensor1, sensor2, sensor3, leds,clk
// {{ALTERA_ARGS_END}} DO NOT REMOVE THIS LINE!
);
// Port Declaration

// {{ALTERA_IO_BEGIN}} DO NOT REMOVE THIS LINE!
input clk;
input sensor;
input sensor1;
input sensor2;
input sensor3;
output [23:0] leds;

reg [31:0] timer;

reg [10:0] leds;
reg [24:0] leds_tmp1;
reg [24:0] leds_tmp2;
reg [3:0] mode;
// {{ALTERA_IO_END}} DO NOT REMOVE THIS LINE!
always @(posedge clk)
begin
//timer <= timer + 1;
if(sensor) mode <= 0;
else if(sensor1) mode <= 1;
else if(sensor2) mode <= 2;
else if(sensor3) mode <= 3;
else
begin
timer <= 0;
mode <= 4;
leds_tmp1 <= 1;
leds_tmp2 <= 25'b0001001001001001001001001;
end
case(mode)
4'b0000:
begin
leds <= leds_tmp1;
timer <= timer + 1;
if(timer < 2000000)
begin
end
else
begin
leds_tmp1 <= leds_tmp1 << 1;
leds_tmp1[0] <= leds_tmp1[24];
timer <= 0;
end
end

4'b0001:
begin
leds <= leds_tmp1[24:1];
timer <= timer + 1;
if(timer < 2000000)
begin
end
else
begin
leds_tmp1 <= leds_tmp1 >> 1;
leds_tmp1[24] <= leds_tmp1[0];
timer <= 0;
end
end

4'b0010:
begin
timer <= timer + 1;
if(timer < 2000000)
begin
end
else
begin
leds_tmp2 <= leds_tmp2 << 1;
leds_tmp2[0] <= leds_tmp2[2];
leds <= leds_tmp2;
timer <= 0;
end
end

4'b0011:
begin
timer <= timer + 1;
if(timer < 2000000)
begin
end
else
begin
leds_tmp2 <= leds_tmp2 >> 1;
leds_tmp2[23] <= leds_tmp2[20];
leds <= leds_tmp2;
timer <= 0;
end
end
default:
begin
timer <= 0;
end
endcase
end
endmodule



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

Ответы


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

Сообщение:

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

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

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

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