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

 
 
 
Reply to this topicStart new topic
> SPI и ATMega .. FTDI
onizuka
сообщение Mar 24 2008, 20:03
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 30
Регистрация: 12-01-08
Из: Санкт-Петербург
Пользователь №: 34 012



может у кого нибудь есть приемо-передатчик для ftdi fifo (245R например).
Go to the top of the page
 
+Quote Post
onizuka
сообщение Mar 24 2008, 20:06
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 30
Регистрация: 12-01-08
Из: Санкт-Петербург
Пользователь №: 34 012



неоходимо соеденить ПЛИС и атмегу. коннект по spi.
вот такая реализация spi подойдет?

Код
/*

SPI_master.v - Verilog source for SPI module

Features:
- 25 MHz max operating frequency (on Xport 2.0)
- 8-bit Clock divider to obtain slower speeds
- Synthesizable and tested on Xport 2.0

Limitations:
- Only supports master mode
- Only supports MSB first data read/write
- Only supports sampling on rising edge and setup on falling edge
- Only 8-bit data transfers
- no IRQ support but has a busy bit that can be polled to assure module is not busy
- !SS pin has to be controlled by GPIO

Copyright © 2007  Steven Yu

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.

*/


module spi_master(addr, in_data, out_data, rd, wr, cs, clk, miso, mosi, sclk);
input wire [1:0] addr;
input wire [7:0] in_data;
output reg [7:0] out_data;
input wire rd;
input wire wr;
input wire cs;
input wire clk;
inout miso;
inout mosi;
inout sclk;

reg sclk_buffer = 0;
reg mosi_buffer = 0;
reg busy = 0;

reg [7:0] in_buffer = 0;
reg [7:0] out_buffer = 0;
reg [7:0] clkcount = 0;
reg [7:0] clkdiv = 0;
reg [4:0] count = 0;

always@(cs or rd or addr or out_buffer or busy or clkdiv)
begin
    out_data = 8'bx;
    if(cs && rd)
    begin
        case(addr)
        2'b00:   begin out_data = out_buffer; end
        2'b01:   begin out_data = {7'b0, busy}; end
        2'b10:   begin out_data = clkdiv; end
        endcase
    end
end

always@(posedge clk)
begin
    if(!busy)
    begin
        if(cs && wr)
        begin
            case(addr)
            2'b00: begin in_buffer = in_data; busy = 1'b1; end
            2'b10: begin clkdiv = in_data; end
            endcase
        end
    end
    else
    begin
        clkcount = clkcount + 1;

        if(clkcount >= clkdiv)
        begin
            clkcount = 0;

            if((count % 2) == 0)
            begin
                mosi_buffer = in_buffer[7];
                in_buffer = in_buffer << 1;
            end

            if(count > 0 && count < 17)
            begin
                sclk_buffer = ~sclk_buffer;
            end

            count = count + 1;
      
            if(count > 17)
            begin
                count = 0;
                busy = 1'b0;
            end
        end
    end
end

always@(posedge sclk_buffer)
begin
    out_buffer = out_buffer << 1;
    out_buffer[0] = miso;
end

assign sclk = sclk_buffer;
assign mosi = mosi_buffer;

endmodule


Сообщение отредактировал onizuka - Mar 24 2008, 20:52
Go to the top of the page
 
+Quote Post
zltigo
сообщение Mar 24 2008, 20:18
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(onizuka @ Mar 24 2008, 23:06) *
вот такая реализация подойдет?

Moderator:
И все с увлечением бросились читать слепой не фоматированный текст. По ходу дела устраивая телепатические сеансы....
Старая истина - вопрос должен содержать не менее половины ответа.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
onizuka
сообщение Mar 24 2008, 20:48
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 30
Регистрация: 12-01-08
Из: Санкт-Петербург
Пользователь №: 34 012



прошу прощения за неправильный формат текста
Go to the top of the page
 
+Quote Post
AlexKLm
сообщение Mar 24 2008, 21:02
Сообщение #5


Частый гость
**

Группа: Свой
Сообщений: 160
Регистрация: 17-03-08
Из: Мурманская
Пользователь №: 35 989



Висит, платка с 245-ой, уже с годик. А что такое 'verilog'? Просьба - не выражаться.


--------------------
Демократия - это когда считается, что два дурака лучше одного умного
Суверенная демократия - это когда считается, что один дурак лучше двух дураков
Go to the top of the page
 
+Quote Post
onizuka
сообщение Mar 24 2008, 21:08
Сообщение #6


Участник
*

Группа: Участник
Сообщений: 30
Регистрация: 12-01-08
Из: Санкт-Петербург
Пользователь №: 34 012



Цитата(AlexKLm @ Mar 25 2008, 00:02) *
Висит, платка с 245-ой, уже с годик. А что такое 'verilog'? Просьба - не выражаться.


я имею в виду модуль для ПЛИСа для общения с 245R написанный на verilog'е. verilog - это язык описания аппаратуры, используемый для описания и моделирования электронных систем
Go to the top of the page
 
+Quote Post
zltigo
сообщение Mar 24 2008, 21:41
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(onizuka @ Mar 24 2008, 23:03) *
может..

Если у Вы не можете описать что-то типа банального параллельного регистра, то что будете делать дальше?


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
onizuka
сообщение Mar 25 2008, 19:34
Сообщение #8


Участник
*

Группа: Участник
Сообщений: 30
Регистрация: 12-01-08
Из: Санкт-Петербург
Пользователь №: 34 012



Цитата(zltigo @ Mar 25 2008, 00:41) *
Если у Вы не можете описать что-то типа банального параллельного регистра, то что будете делать дальше?


банальный параллельный не проблема. проблема с тем чтобы сделать slave модуль для wishbone например.
Go to the top of the page
 
+Quote Post
des00
сообщение Mar 26 2008, 03:57
Сообщение #9


Вечный ламер
******

Группа: Модераторы
Сообщений: 7 248
Регистрация: 18-03-05
Из: Томск
Пользователь №: 3 453



Цитата(onizuka @ Mar 25 2008, 14:34) *
банальный параллельный не проблема. проблема с тем чтобы сделать slave модуль для wishbone например.


Цитата
Are you using Wishbone, do you need some simple 'slaves' to test your bus with ?


http://www.opencores.org/projects.cgi/web/...t_port/overview


--------------------
Go to the top of the page
 
+Quote Post
onizuka
сообщение Mar 26 2008, 20:38
Сообщение #10


Участник
*

Группа: Участник
Сообщений: 30
Регистрация: 12-01-08
Из: Санкт-Петербург
Пользователь №: 34 012



Цитата(des00 @ Mar 26 2008, 06:57) *


спасиба. немного помогло
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st June 2025 - 16:15
Рейтинг@Mail.ru


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