搜索
bottom↓
回复: 5

FPGA设计的SPI模块,有问题吗

[复制链接]

出0入0汤圆

发表于 2013-10-9 15:18:00 | 显示全部楼层 |阅读模式
在网上看到这样的一个VHDL的SPI从机,大概能看懂。现在刚学VHDL,有很多不懂的,程序如下:
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;

ENTITY spi IS
    GENERIC ( N:INTEGER := 8 );
    PORT( sclk    :IN STD_LOGIC;
          cs      :IN STD_LOGIC;
          miso    :OUT STD_LOGIC;
          mosi    :IN STD_LOGIC;
          data_tx :IN STD_LOGIC_VECTOR(N-1 DOWNTO 0);     --这里为什么要用在端口PORT里呢?SPI只需四根线,配置引脚时,这8个线要怎么处理?能不能用寄存器代替?
          data_rx :OUT STD_LOGIC_VECTOR(N-1 DOWNTO 0);  --同上
          reset   :IN STD_LOGIC;
          state   :OUT STD_LOGIC );
END ENTITY spi;

ARCHITECTURE one OF spi IS
    SIGNAL i:INTEGER RANGE 0 TO N-1;
    SIGNAL j:STD_LOGIC;
BEGIN
    PROCESS(sclk)
    BEGIN
        IF reset = '0' THEN data_rx <= (OTHERS => '0');j <= '1';
        ELSIF cs = '1' THEN i <= N-1;miso <= 'Z';
        ELSIF (rising_edge(sclk)) THEN
            data_rx(i) <= mosi;
            miso <= data_tx(i);
            IF i=0 THEN i <= N-1;j <= '1';
            ELSE i <= i-1;j <= '0';
            END IF;
        END IF;
    END PROCESS;
    state <= cs AND j;
END one;

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2013-10-9 15:45:58 | 显示全部楼层
mosi的数据给data_rx
data_rx的数据给miso

出0入0汤圆

 楼主| 发表于 2013-10-9 16:57:37 | 显示全部楼层
usingavr 发表于 2013-10-9 15:45
mosi的数据给data_rx
data_rx的数据给miso

那在配置引脚时,是不是不用管data_rx,data_tx,就是这16个引脚不用配置?其他的如reset,mosi,miso等就按实际引脚选择。

出0入0汤圆

发表于 2013-10-10 16:09:03 | 显示全部楼层
CLK、CS、MOSI、MISO引脚配置到连接的SPI通信接口上,其余的都是模块解析SPI协议产生的接收数据或需发送的数据,最近正好要做这一块,大家一起研究啊

出0入0汤圆

 楼主| 发表于 2013-10-11 01:20:40 | 显示全部楼层
本帖最后由 kandy286 于 2013-10-11 01:24 编辑
幸福的鱼 发表于 2013-10-10 16:09
CLK、CS、MOSI、MISO引脚配置到连接的SPI通信接口上,其余的都是模块解析SPI协议产生的接收数据或需发送的 ...



我知道四根线要配置到FPGA的引脚,还有reset,state也要,但是data_tx以及data_rx就不知道怎么处理了。能不能具体点呢?刚学VHDL,有很多不懂的, ;你研究的怎么样,有没有例子呢?包括例化元件的程序,参考一下。

出0入0汤圆

发表于 2013-10-12 11:49:22 | 显示全部楼层
kandy286 发表于 2013-10-11 01:20
我知道四根线要配置到FPGA的引脚,还有reset,state也要,但是data_tx以及data_rx就不知道怎么处理了。能 ...

你的这个模块程序只是把MOSI串行发送过来的数据转换成了并行数据data_rx,至于data_rx怎么处理,要看你的通信协议了
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 07:18

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表