基于DUAL-PORT RAM的双CPU快速通讯

2024-02-20 00:18
文章标签 快速 cpu 通讯 ram port dual

本文主要是介绍基于DUAL-PORT RAM的双CPU快速通讯,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

相信大家对以下几种双CPU之间通讯的方法可能有所耳闻:

        1.使用双口RAM。

        2.利用I/O口进行并行通信。
        3.利用串口进行通信。

        4.共享内存。

 

    几种方法的优缺点,这里就不再具体说明了,不清楚的朋友呢,可以Google、百度一下“双CPU通讯”,应该会有不少的文章来说明!

    这里,我主要想说一下双口RAM的通讯,具体以IDT71V321S为例:

    芯片原理图如下:

   

    从原理图我们可以清楚看到,其实通讯的原理很简单,就是通过双CPU以中断的方式进行内存读写控制来完成的,/BUSY引脚起写保护的作用。

    硬件设计比较简单,只需参考芯片引脚定义连接到不同CPU即可,在此就不列图说明了!

    软件设计,我们可以可以参考Datasheet P12 Table2:

    

    (下面我们用L-CPU表示连接到Left Port的CPU,R-CPU表示连接到Right Port的CPU)
    从表中中可以看出,当
        R-CPU写数据到0x7FE地址时,会引发L-CPU的中断
        L-CPU写数据到0x7FF地址时,会引发R-CPU的中断

    因此,我们可以以命令的方式来实现L-CPU与R-CPU之间的通讯,具体实现如下:

        1. 利用0x7FE、0x7FF两个地址分别存储通讯的命令类型及响应

        2. 根据需要,在双口RAM中定义一段内存作为命令Buffer,以存储参数或作为其它用途

        3. 通讯时,先写入参数或其它数据到命令Buffer,然后再写入命令类型到0x7FE/0x7FF

        4. 当对方CPU收到中断响应时,读取0x7FE/0x7FF命令类型,然后进行处理

        5. 数据处理完成后,写入响应到0x7FE/0x7FF地址,至此,一次通讯就完成了

    下面给出发送命令及中断处理的简单原型:

SendCommandToXCPU(unsigned char cmdType, unsigned char*cmdBuf, int cmdLen)
{
    写入数据(cmdBuf)到用户定义Buffer
    // 发送命令
    根据不同CPU向0x7FE/0x7FF写入cmdType
}
void InterruptSupport()
{
    //读取命令
    从地址0x7FE/0x7FF读取命令类型
    switch(cmdType)
    {
        case xxx:
            //通知OS或者根据需要处理命令Buffer等
    }
}

这篇关于基于DUAL-PORT RAM的双CPU快速通讯的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/726456

相关文章

乐鑫 Matter 技术体验日|快速落地 Matter 产品,引领智能家居生态新发展

随着 Matter 协议的推广和普及,智能家居行业正迎来新的发展机遇,众多厂商纷纷投身于 Matter 产品的研发与验证。然而,开发者普遍面临技术门槛高、认证流程繁琐、生产管理复杂等诸多挑战。  乐鑫信息科技 (688018.SH) 凭借深厚的研发实力与行业洞察力,推出了全面的 Matter 解决方案,包含基于乐鑫 SoC 的 Matter 硬件平台、基于开源 ESP-Matter SDK 的一

java中查看函数运行时间和cpu运行时间

android开发调查性能问题中有一个现象,函数的运行时间远低于cpu执行时间,因为函数运行期间线程可能包含等待操作。native层可以查看实际的cpu执行时间和函数执行时间。在java中如何实现? 借助AI得到了答案 import java.lang.management.ManagementFactory;import java.lang.management.Threa

LVGL快速入门笔记

目录 一、基础知识 1. 基础对象(lv_obj) 2. 基础对象的大小(size) 3. 基础对象的位置(position) 3.1 直接设置方式 3.2 参照父对象对齐 3.3 获取位置 4. 基础对象的盒子模型(border-box) 5. 基础对象的样式(styles) 5.1 样式的状态和部分 5.1.1 对象可以处于以下状态States的组合: 5.1.2 对象

段,页,段页,三种内存(RAM)管理机制分析

段,页,段页         是为实现虚拟内存而产生的技术。直接使用物理内存弊端:地址空间不隔离,内存使用效率低。 段 段:就是按照二进制文件的格式,在内存给进程分段(包括堆栈、数据段、代码段)。通过段寄存器中的段表来进行虚拟地址和物理地址的转换。 段实现的虚拟地址 = 段号+offset 物理地址:被分为很多个有编号的段,每个进程的虚拟地址都有段号,这样可以实现虚实地址之间的转换。其实所谓的地

【Spring】Spring Boot 快速入门

📚博客主页:爱敲代码的小杨. ✨专栏:《Java SE语法》 | 《数据结构与算法》 | 《C生万物》 |《MySQL探索之旅》 |《Web世界探险家》 ❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️ 🙏小杨水平有限,欢迎各位大佬指点,相互学习进步! 小杨近些在学习人工智能方面的知识,发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一

关于CPU的一点知识

首先说一下,CPU是干啥的: CPU所负责的就是解释和运行最终转换成机器语言的程序内容 我们需要知道的CPU结构:重点需要关注寄存器 运算器 简单说就是负责运算从内存读取到寄存器中的数据,可以看作一个数据加工厂,就是对寄存器中的数据做运算,这些运算包含基本的算术和逻辑运算。 算术逻辑单元(ALU) 这个是运算器中重要的一个组成,主要负责的就是对数据的处理,从而实现对数据的算术和

Sublime Text 快速折叠CSS代码到一行

快速折叠CSS代码到一行 1.使用HTML/CSS/JS Prettify或者CSScomb美化代码 2.使用Alt+F3特征选取,删除下图中所有的特征空格 3.使用Ctrl+Shift+M选取括号里的内容,再使用一次Ctrl+Shift+M将大括号也一起选中。 4.使用Ctr+J折叠代码 5.Home键 6.Backspace键

一篇文章带你快速入门java

文章目录 一、一个简单的java代码1.1 Java程序的结构由三个不成组成:1.2 运行java程序1.3 JDK,JRE,JVM之间的关系?(面试题)1.4 标识符1.5 注释1.6 关键字 一、一个简单的java代码 public class HelloJava {public static void main(String[] args) {System.out.

汇编快速入门

一.基础知识 1.数据类型 DB(Define Byte,字节类型    占位8位bit == 1字节) 范围:DB可以用来定义(无符号、有符号)整数(包含二、十、十六进制)和字符 语法:a DB  数据个数  数据值 用法:a DB  -1 , 1 , 1000H , 'A' , "ABC" , ?(?是不知道的数值,一般机器自动使用0填充) DW(Define Word,字类型

C++系统相关操作4 - 获取CPU(指令集)架构类型

1. 关键词2. sysutil.h3. sysutil.cpp4. 测试代码5. 运行结果6. 源码地址 1. 关键词 关键词: C++ 系统调用 CPU架构 指令集 跨平台 实现原理: Unix-like 系统: 可以通过 uname -m 命令获取 CPU 架构类型。Windows 系统: 可以通过环境变量 PROCESSOR_ARCHITECTURE 获取 CPU 架构类型。