S3C2440扩展SDRAM

 本文主要目的是记录一下S3C2440扩展SDRAM的一些知识,方便以后查阅。

通过查阅手册我们知道,2440有8个可以用来扩展内存的BANK,其中第6和第7还可用来扩展SDRAM

下面我们来看一下2440扩展SDRAM需要设置哪些寄存器。

一、BWSCON寄存器

该寄存器我们只需要设置和SDRAM有关的bank7和bank6,我的开发板的SDRAM是连接到bank6的,我们需要配置bank6相关位,不过一般我们bank6和bank7都设置为一样(我记得两者好像是有共用什么来着,不记得了,需要查手册再去看才能想起),ST6位里的UB/LB一般是用于SRAM的,我用的是SDRAM,配置为0;WS6配置为disable,因为我的开发板扩展了两片16位的SDRAM,相当于一片32位的SDRAM,DW6选择32bit。bank7配置和bank6一样,所以我们配置BWSCON = 0X22000000;

 

二、BANKCON6、BANKCON7

对于MT,因为我们用的是SDRAM,所以配置为11;配置为SDRAM模式后,还需要配置Trcd和SCAN,Trcd是RAS(行地址发出时间)到CAS(列地址发出时间)的时间间隔,我们可以直接在我们的SDRAM芯片手册里查找一下Trcd,结果如下图

 

因为我的板子上的SDRAM是-6G的,所以最小为18ns,因为2440内存控制器的时钟为HCLK,我配置为100M,所以Trcd配置为00(2 clocks),至于列地址数,我们可以查看我们的SDRAM芯片的手册得到以下结果,所以SCAN配置为9个列地址,即把BANKCON6、BANKCON7配置为0X00018001。

 

三、REFRESH寄存器

因为SDRAM需要不断地刷新才能保存住里面的数据,所以REFEN必须使能;TREFMD配置为自动模式;Trp直接在我们的SDRAM芯片手册里查找得知-6型号的芯片为18,所以配置为2个clocks,Tsrc在芯片手册里找不到,但我们可以查找Trc,-6型号的Trc为60ns,所以Tsrc等于60-18等于42,我们配置为5个clocks;配置Refresh Counter需要在SDRAM手册里查找Refresh period,我的芯片是64ms/8k,根据公式算出Refresh count等于1269,所以REFRESH配置为0X8404F5。

 

四、BANKSIZE寄存器

我们使能突发访问(可一次连续访问多个字节)和休眠模式,所以bit5和7都配置为1,bit4采用推荐值1,因为我们相当于扩展了一片64M的SDRAM,所以BK76MAP配置为64MB,所以BANKSIZE配置为0XB1。

 

五、MRSRB6、MRSRB7

这个寄存器只有CL是可设置的,其他都为Fixed,因为SDRAM这种内存芯片其实性能不是很好,我们在发送完地址后,一般需要等待2或3个时钟周期才有数据返回,CL正是设置这一点的,我们的SDRAM芯片可配置为2或者3,我们配置为2,所以MRSRB6和MRSRB7配置为0X20。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384548.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

汇编语言的相对跳转和绝对跳转以及反汇编代码解析

上图第一行的b1 main为相对跳转,即跳转到pcoffset,其中pc为当前pc值,offset可以理解为偏移地址,也就是根据当前所在地址加上偏移地址实现跳转,为相对跳转。 我们来看看它的反汇编代码 上图清除完bss区后使用b1指令跳转到30000668…

韦东山嵌入式第一期14课第004节_und异常模示程序示例_P笔记

本节课的第一个程序韦老师是想让大家见识一下未定义异常,而第二个程序是对第一个程序进行改进,防止在某些条件下执行不了,下面就来讲一下第2个程序改进了哪些地方并且有什么用。 程序在此路径中:源码文档图片\源码\源码_20180321…

关于NOR FLASH地址左右移的问题

问题引入:不知道你会不会有这样的疑问:为什么在发送解锁命令时,我们不用右移一位,而发送扇区地址时却要右移一位(nor_cmd函数内部已经左移一位),这里先补充说明一下说明是cpu角度和nor角度&…

在linux下利用ls命令进行模糊查找

如上图,我们当前路径下有三个文件,分别为helloworld.c以及helloworld和1.c,直接输入命令ls则显示所有文件,我们可以利用ls 加*的方向进行模糊查找。 输入ls 目录名 形式的命令行,则是对该目录名下的文件全部进行显示&a…

Linux下没有包含头文件(不知是哪个)导致编译无法通过的解决心得

最近写程序的时候编译出错了,提示信息为:invalid use of undefined type fb_var_screeninfo。显示根据英文知道是没有定义 fb_var_screeninfo这个类型,明显是缺少了某个头文件,但是缺少哪个头文件以及有什么又快又好的解决方法呢&…

Linux编译程序时加-I指定头文件位置

Linux下编译出现以下错误,错误的原因是在/usr/local/arm/arm-2009q3/bin/../arm-none-linux-gnueabi/libc/usr/include/freetype/config/下找不到ftheader.h,而我到该目录下看,发现路径是这样的rootubuntu:/usr/local/arm/arm-2009q3/arm-non…

关于源文件用不同的编码方式编写,会导致执行结果不一样的现象及解决方法

如果我们编写以下程序,并分别另存为ANSI和UTF-8两种不同的编码方式保存,放到Linux下编译并运行如下图,两端相同的程序以不同的编码方式保存编译后的运行结果不一样,./ansi采用ANSI编码方式,会自动采用GBK方式来保存中文…

arm-linux-gcc静态编译和动态编译的区别

很多教程会提到加上-static是静态编译,但对于新手来说没有用例子来说明可能不太好理解,今天我就介绍一下关于这方面知识的一个例子: 最近在做一个关于freetype字体的东西,需要依赖freetype官方提供的库,我已经把电脑这…

从0到1写RT-Thread内核——线程定义及切换的实现

从0写RT-Thread内核之线程定义及切换的实现具体可以分为以下六步来实现 一:分别定义线程栈、线程函数、线程控制块; ALIGN(RT_ALIGN_SIZE)//设置4字节对齐 /* 定义线程栈 */ rt_uint8_t rt_flag1_thread_stack[512]; rt_uint8_t rt_flag2_thread_stack…

从0到1写RT-Thread内核——临界段的保护

临界段就是一段在执行的时候不能被中断的代码段,在RT-Thread里,临界段最常出现的就是对全局变量的操作(类似Linux下的锁)。RT-Thread对临界段的保护是直接把中断全部关了,NMI FAULT和硬FAULT除外。下图是3个关于中断屏…

从0到1写RT-Thread内核——空闲线程与阻塞延时的实现

在之前写的另外一篇文章——<从0到1写RT-Thread内核——线程定义及切换的实现>中线程体内的延时使用的是软件延时&#xff0c;即还是让CPU空等来达到延时的效果。RTOS中的延时叫阻塞延时&#xff0c;即线程需要延时的时候&#xff0c;线程会放弃CPU的使用权&#xff0c;C…

从0到1写RT-Thread内核——支持多优先级

在本章之前&#xff0c;RT-Thread还没有支持多优先级&#xff0c;我们手动指定了第一个运行的线程&#xff0c;并在此之后三个线程&#xff08;包括空闲线程&#xff09;互相切换&#xff0c;在本章中我们加入优先级的功能&#xff0c;第一个运行的程序是就绪列表里优先级最高的…

AD软件之模块化原理图

首先我们创建两个原理图文件 然后我们在Sheet2.SchDoc里放置一个页面符并双击绿色的方框 选择目标文件 我们选择我们刚才创建的Sheet4.SchDoc 然后在 视图——>面板——>Navigator选项 里点一下交互式导航 就可以看到Sheet4.SchDoc被添加到Sheet2.SchDoc下面了 通过上面…

AD软件操作技巧

本文介绍一些关于AD软件的实用小操作&#xff0c;这些小技巧可以大大的减少我们的工作量 一.批量操作丝印&#xff08;或者操作别的东西也可以&#xff0c;主要是凸显批量操作的思想&#xff09; 如下图假设我们工程里有很多丝印和焊盘等等&#xff0c;现在我想改批量地修改丝…

V4L2框架分析

V4L2是Video for linux2的简称,为linux中关于视频设备的内核驱动。v4L2是针对uvc&#xff08;USB Video Class&#xff09;免驱usb设备的编程框架&#xff0c;主要用于采集usb摄像头等。 下图是V4L2的框架&#xff0c;首先系统核心层分配设置注册一个名为cdev结构体变量&#x…

mjpg-streamer框架分析

mjpg-streamer程框架图如下所示&#xff1a; 程序运行起来后&#xff0c;主进程根据传入的参数设置的输入输出通道打开对应的输入输出动态链接库&#xff0c;并依次调用以下函数 1、输入---仓库-----输出&#xff08;mjpg-streamer.h&#xff09; &#xff08;1&#xff09;gl…

linux字符驱动之概念介绍

一、字符驱动框架 问&#xff1a;应用程序open、read、write如何找到驱动程序的open、read、write函数&#xff1f; 答:应用程序的open、read、write是在C库里面实现的&#xff0c;它里面通过swi val指令去触发一个异常&#xff0c;这个异常就会进入到内核空间&#xff0c;在内…

USB摄像头视频监控项目学习笔记

一个摄像头监控应用程序的系统调用如下所示&#xff1a; /* open * VIDIOC_QUERYCAP 确定它是否视频捕捉设备,支持哪种接口(streaming/read,write) * VIDIOC_ENUM_FMT 查询支持哪种格式 * VIDIOC_S_FMT 设置摄像头使用哪种格式 * VIDIOC_REQBUFS 申请buffer 对于 str…

图片缩放算法

项目背景&#xff1a;博主之前做过一个摄像头采集数据&#xff0c;然后在LCD上显示视频数据的项目&#xff0c;假如我们摄像头采集的一帧数据的分辨率比我们的LCD的分辨率要大&#xff0c;那么LCD则无法显示整个图像&#xff0c;这时候我们就要把这么一帧图片进行缩放&#xff…

数码相框项目之显示一张可放大、缩小、拖拽的图片

之前我做过一个电子相框的项目&#xff0c;涉及到的重难点主要为&#xff1a;在LCD上放大、缩小、移动图片。 首先我们得明白的一点是&#xff1a;无论是放大或缩小&#xff0c;实际上都是对原图进行等比例的缩小&#xff0c;然后在LCD上面显示&#xff0c;只不过缩小的程度不…