набросал небольшой проект (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