Не удается установить настраиваемость в счетчике Verilog
Я написал счетчик вверх / вниз и создал код для настраиваемой начальной точки. Пока все хорошо, но я не могу придумать, как добавить его в счетчик. Я должен подчеркнуть, что я совершенно новичок в Verilog и подобных языках.
//UTILS
reg [2:0] delay;
wire clock;
reg[3:0] tens;
reg[3:0] units;
wire[5:0] number;
reg[13:0] shift;
integer i;
//ASSIGNS
assign number[5:0] = SW[5:0];
assign up = SW[7];
assign start = SW[6];
//PRESCALER
always@ (posedge MCLK)
begin
delay <= delay + 1;
end
assign clock = &delay;
//MAIN COUNTER
always@ (posedge clock)
begin
if (start)
begin
if (up) //going up
begin
if (units == 4'd3 && tens == 4'd6)
begin //63 reached
units <= 0;
tens <=0;
end
if (units==4'd9)
begin //x9 reached
units <= 0;
tens <= tens + 1;
end
else
units <= units + 1; //typical case
end
else //goin down
begin
if (units == 4'd0)
if ( tens ==4'd0) //00 reached back to 63
begin
units <= 4'd3;
tens <= 4'd6;
end
else
begin //x0 reached
tens <= tens-1;
units <= 4'd9;
end
else
begin //typical case
units <= units -1;
end
end
end
end //MAIN COUNTER END
Здесь я не знаю, как объединить эти две части, я хотел бы, чтобы это было так, если start всегда @ posedge clock /counting/ else / * меняет число почти функционально (сразу, когда происходит изменение)*/
Добавление его в if(start), похоже, выполняет свою работу, но только на положительном фронте тактовой частоты с достаточно низкой частотой. Насколько я знаю, я не могу использовать один регистр в двух разных ВСЕГДА @.
/* // Clear previous number and store new number in shift register
shift[13:6] = 0;
shift[5:0] = number;
//BINARY TO BCD
for (i=0; i<6; i=i+1)
begin
if (shift[9:6] >= 5)
shift[9:6] = shift[9:6] + 3;
if (shift[13:10] >= 5)
shift[13:10] = shift[13:10] + 3;
shift = shift << 1;
end
units <= shift[9:6];
tens <= shift[13:10];
*/
dek7seg - это 7-сегментный дисплей, который на 100% в порядке (код профессора).
dek7seg ss1(
.bits(units[3:0]),
.seg(DISP1[6:0])
);
dek7seg ss10(
.bits(tens[3:0]),
.seg(DISP2[6:0])
);
endmodule
1 ответ
Вы используете производные часы для управления своим главным счетчиком. Вместо этого используйте основные часы MCLK
и использовать логику для delay
как условное утверждение.
Так как вы хотите сохранить новые значения при изменении number
, то вам нужно будет сохранить предыдущий number
цени и сравни.
Исходя из вашего описания, ваш код должен выглядеть примерно так:
//MAIN COUNTER
always@ (posedge MCLK)
begin
if (start && &delay)
begin
/* your up/down logic here */
end
else if (number != prev_number)
begin // Clear previous number and store new number
prev_number <= number;
units <= new_units;
tens <= new_tens;
end
end
// Calculate new units and tens from number
always @* begin
shift[13:6] = 0;
shift[5:0] = number;
//BINARY TO BCD
for (i=0; i<6; i=i+1) begin
if (shift[9:6] >= 5)
shift[9:6] = shift[9:6] + 3;
if (shift[13:10] >= 5)
shift[13:10] = shift[13:10] + 3;
shift = shift << 1;
end
new_units = shift[9:6];
new_tens = shift[13:10];
end