реклама на сайте
подробности

 
 
> Сделать сдвигающий регистр, С парал. загрузкой -"потенциалом"
muravei
сообщение Sep 5 2006, 06:22
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 538
Регистрация: 13-08-05
Пользователь №: 7 591



Естественно. сигналы загрузки и сдвига разные.(при активном загрузки-сдвиг запрещен)
Может есть что-то готовое, я не очень копенгаген, пока.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Alex_xxx
сообщение Sep 6 2006, 13:16
Сообщение #2





Группа: Новичок
Сообщений: 10
Регистрация: 24-11-05
Пользователь №: 11 333



Цитата(muravei @ Sep 5 2006, 09:22) *
Естественно. сигналы загрузки и сдвига разные.(при активном загрузки-сдвиг запрещен)
Может есть что-то готовое, я не очень копенгаген, пока.



Как пример могу предложить вариант модуля описаного на Verilog с паралельной загрузкой:



module shifter (clk, rst, data_in, serial_out, load);

input clk; wire clk;
input rst; wire rst;

input [7:0] data_in; wire [7:0] data_in;
input load; wire load;

output serial_out; wire serial_out;

reg [7:0] shift_reg;

assign serial_out = shift_reg[7];

always @(posedge clk)
if (!rst) begin shift_reg <= 8'b00000000; end
else if (load) begin shift_reg <= data_in; end
else
begin shift_reg[0] <= shift_reg[7]; // <= 1'b0; // dlya zapolneniya 0
shift_reg[1] <= shift_reg[0];
shift_reg[2] <= shift_reg[1];
shift_reg[3] <= shift_reg[2];
shift_reg[4] <= shift_reg[3];
shift_reg[5] <= shift_reg[4];
shift_reg[6] <= shift_reg[5];
shift_reg[7] <= shift_reg[6];
end

endmodule
Go to the top of the page
 
+Quote Post
PetrK
сообщение Aug 19 2007, 11:59
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 40
Регистрация: 19-12-05
Из: SPb
Пользователь №: 12 417



Цитата(Alex_xxx @ Sep 6 2006, 17:16) *
Как пример могу предложить вариант модуля описаного на Verilog с паралельной загрузкой:
module shifter (clk, rst, data_in, serial_out, load);

input clk; wire clk;
input rst; wire rst;

input [7:0] data_in; wire [7:0] data_in;
input load; wire load;

output serial_out; wire serial_out;

reg [7:0] shift_reg;

assign serial_out = shift_reg[7];

always @(posedge clk)
if (!rst) begin shift_reg <= 8'b00000000; end
else if (load) begin shift_reg <= data_in; end
else
begin shift_reg[0] <= shift_reg[7]; // <= 1'b0; // dlya zapolneniya 0
shift_reg[1] <= shift_reg[0];
shift_reg[2] <= shift_reg[1];
shift_reg[3] <= shift_reg[2];
shift_reg[4] <= shift_reg[3];
shift_reg[5] <= shift_reg[4];
shift_reg[6] <= shift_reg[5];
shift_reg[7] <= shift_reg[6];
end

endmodule


что-то у меня на выходе данные отсутствуют.

дело в коде, приведенном выше или я что-то делаю неправильно?
скриншот прилагается

спасибо
Эскизы прикрепленных изображений
Прикрепленное изображение
 
Go to the top of the page
 
+Quote Post
-=Vitaly=-
сообщение Aug 20 2007, 12:37
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 468
Регистрация: 31-08-06
Из: Киев
Пользователь №: 19 991



Цитата(PetrK @ Aug 19 2007, 14:59) *
что-то у меня на выходе данные отсутствуют.

дело в коде, приведенном выше или я что-то делаю неправильно?
скриншот прилагается

спасибо

У вас синхронная загрузка, можно увеличенный фрагмент симуляции, чтобы было видно сигнал LOAD??

Сообщение отредактировал -=Vitaly=- - Aug 20 2007, 12:37
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 11:20
Рейтинг@Mail.ru


Страница сгенерированна за 0.01378 секунд с 7
ELECTRONIX ©2004-2016