| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 嵌入式 -> STM32CubeMX SDRAM的使用(一) -> 正文阅读 |
|
[嵌入式]STM32CubeMX SDRAM的使用(一) |
一、目的? ? ? ? 大部分情况下芯片自带的SRAM足够我们使用,但是当我们实现复杂GUI特效显示的时候,一般都会配备SDRAM芯片用作图像显存;那什么是SDRAM,SDRAM如何初始化,如何进行SDRAM读写就是必须要解决的问题,本篇给大家介绍SDRAM的工作原理以及如何通过STM32CubeMX进行配置。 ? ? ? ? 本篇使用的开发板是ArtPi开发板(RT-Thread出品),板载W9825G6KH-6,其基本信息:4M words x 4banks x 16bit,内部有4个bank,每个bank的大小为13行9列个存储单元,每个存储单元16bit,也就是位宽为2字节,总容量为? ? ? ? ?? ? ? ? ? 注意下最高时钟166MHz,并且CL需要设置为3;如果时钟为133MHz可以设置CL为2;至于CL是什么,我们下文会介绍。 ???????? 二、介绍? ? ? ? 按照惯例,我们先上参考资料 三、实战????????1、SDRAM是什么?????????????????synchronous dynamic random access memory,同步动态随机访问存储器,区别于SRAM(静态随机访问存储器) ? ? ? ? ? ? ? ? 动态是指其需要不断被刷新才能保持内部的数据(电荷)不丢失(相当于需要定时给内部电容充电) ? ? ? ? ? ? ? ? 同步即命令的发送与数据的传输都需要外部时钟并以此为基准 ? ? ? ? ? ? ? ? 随机即可以指定某个地址直接访问 ? ? ? ? 2、SDRAM的一些基本概念? ? ? ? ? ? ? ? 由于工艺的限制、避免地址冲突等等问题,SDRAM一般都设置为多个Bank(我用的这颗是4Bank),每个Bank通过行地址和列地址进行寻址访问。 ????????????????芯片框图????????????????????????? ? ? ? ? ? ? ? ? 从上图我们可以看到4个Bank,每个Bank都有一个行地址和列地址解码; ????????????????MODE REGISTER(模式寄存器)用于设置一些关键参数控制SDRAM的运行?; ????????????????COMMAND DECODER(命令解码器)用于判断当前的外部输入的命令码; ? ? ? ? ? ? ? ? REFRESH COUNTER(刷新计数器)用于记录当前刷新的行数; ????????????????????????芯片引脚说明????????????????????????
? ? ? ? ? ? ? ? ? ? ? ? 与STM32H750XBH6芯片的接线
? ? ? ? ? ? ? ? ? ? ? ? 寻址方式(图片出自电脑高手关于SDRAM的讲解)???????????????????????? ? ? ? ? ? ? ? ? 通过选择Bank、Row、Column这三个参数唯一确定一个存储单元。? ? ? ? ? 3、SDRAM的关键参数? ? ? ? ? ? ? ? 命令列表????????????????
? ? ? ? ? ? ? ? 注意:CKEn代表当前时钟上升沿时刻的值;CKEn-1是上一个时钟上升延时刻的值 ? ? ? ? ? ? ? ? 上电初始化? ? ? ? ?? ? ? ? ? ? ? ? 上电后模式寄存器的状态是不确定的,所以必须对它进行初始化; ? ? ? ? ? ? ? ? 为了描述方便,这边使用的示例图是另外一款的SDRAM(基本过程都差不多) ???????????????? ? ? ? ? ? ? ? ? 上电后(VDD/VDDQ要同时上电,其他输入信号保持在NOP状态),等待200us(这期间DQM和CKE引脚要保持高电平),然后对所有Bank进行预充电,然后等待tRP时间后?,发送八个自动刷新命令(周期为tRC),在此之后发送模式寄存器设置命令,并等待tMRD时间。 ? ? ? ? ? ? ? ? 模式寄存器设置命令? ? ? ? ? ? ? ? 在时钟上升沿时刻,CS/RAS/CAS/WE都为低电平,BS1/BS0/A12-A0引脚电平为设置值 ????????????????
|
|
嵌入式 最新文章 |
基于高精度单片机开发红外测温仪方案 |
89C51单片机与DAC0832 |
基于51单片机宠物自动投料喂食器控制系统仿 |
《痞子衡嵌入式半月刊》 第 68 期 |
多思计组实验实验七 简单模型机实验 |
CSC7720 |
启明智显分享| ESP32学习笔记参考--PWM(脉冲 |
STM32初探 |
STM32 总结 |
【STM32】CubeMX例程四---定时器中断(附工 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年3日历 | -2025/3/4 12:01:30- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |