【电路笔记 TMS320C6***DSP】外部存储器接口 A EMIFA向FPGA(作为异步存储器)写入数据的示例

目录

  • EMIFA(External Memory Interface A)的"异步存储器"(Asynchronous Memory)指的是那些不与系统时钟同步进行读写操作的外部存储设备。这类存储器使用特定的控制信号(如芯片选择、输出使能、写使能等)来管理数据传输,而不是依赖于一个全局时钟信号。这意味着数据传输的时机是由控制信号的变化触发的,而非由时钟边沿决定。

  • 以下是一个EMIFA向FPGA(作为异步存储器)写入数据的示例:

DSP和FPGA的连接

复制代码
        _____________________________________                                   __________________________
       |                                     |                                 |                          |
       |                                     |                                 |                          |
       |                                     |                                 |                          |
       |                                     |>=======EMIFA片选信号============>|                          |
       |                                     |>=======其他控制信号=============>|                          |
       |                   DSP               |                                 |           FPGA           |
       |                                     |                                 |                          |
       |                                     |>=========EMA_DATA[15:0]========>|                          |
       |                                     |>=========EMA_ADDR[15:0]========>|                          |
       |                                     |                                 |                          |
       |_____________________________________|                                 |__________________________|

DSP端:传输数据给FPGA

  • DSP向FPGA传输数据的过程涉及到EMIF(External Memory Interface)的初始化、通过特定地址写入数据到FPGA。
  1. EMIF初始化

    • EMIF_init(); 这个函数调用用于初始化外部存储器接口(EMIF),确保它可以正确地与外部设备(在此例中为FPGA)通信。这通常包括设置时序参数、配置总线宽度等。
  2. 定义宏

    c 复制代码
    #define CS4_DATA_ADD (*((volatile unsigned short*)(0x64000000)))

    定义一个地址,使用volatile关键字是为了告诉编译器不要优化对该地址的访问,因为它的值可能会在程序之外被改变(例如由硬件中断引起的变化)。

  3. 通过EMIF写入数据到FPGA

    c 复制代码
    *CS4_DATA_ADD = 0xFFFF; // 16位宽的数据
  • 注:代码中可能存在同一个代码块对CS4_DATA_ADD连续多次赋值,这是可行的,因为已经在初始化时配置了数据交互的时序,以确保FPGA能读取到所有的数据。

FPGA端:接收数据

verilog 复制代码
inout wire [15:0] EMA_D,    // 数据总线
inout wire [15:0] EMA_A,    // 地址总线
output reg [15:0] OUT_DATA, // 输出数据

always @(posedge clk) begin
    if(EMA_A[3:0] == 4'b0001) begin // https://blog.csdn.net/qq_24402247/article/details/125487700 & https://blog.csdn.net/ResumeProject/article/details/145931716
        OUT_DATA <= EMA_D[15:0]; // 当地址匹配时,更新OUT_DATA
    end
end
相关推荐
cmes_love1 天前
美股和港股的量化笔记-从下载逐笔tick到合成分钟
笔记·区块链
逻辑诗篇1 天前
FT-M6678+JFM7VX690T互联调试
fpga开发
A_humble_scholar1 天前
C++11 学习笔记:统一初始化、右值引用与完美转发
c++·笔记·学习
magic_now1 天前
Modbus RTU 与 TCP 学习笔记
笔记·学习·tcp/ip
轻闲一号机1 天前
【语音】笔记
前端·笔记·算法
szxinmai主板定制专家1 天前
基于 ARM+FPGA精密多轴实时运动控制卡设计方案,适用于半导体设备等高精度领域(一)
arm开发·人工智能·嵌入式硬件·fpga开发·架构·语音识别
小陈phd1 天前
多模态大模型学习笔记(四十六)——图像-文本生成(Image-Text Generation):跨模态创作与语义互通
笔记·学习·计算机视觉
噜噜噜阿鲁~1 天前
python学习笔记 | 11.4、面向对象高级编程-定制类
笔记·python·学习
CanCanCanedFish1 天前
Transformer论文阅读笔记:从注意力机制到革命性架构的启示
论文阅读·笔记·transformer
wangcheng3031 天前
LLMOps入门:高效管理大型语言模型
笔记