Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
LPC2478外挂SDRAM还需要设置什么
发布于 2011-12-13 13:14:44 浏览:6841
订阅该版
我用的是LPC2478,外挂了个2MB的SDRAM,在options里设置RAM1的ADDRESS=0xA0000000,SIZE=0x200000,NOINIT,start_rvds.S文件打开EMC接口就可以了吗?还需要设置其他什么不?用内部RAM就正常,打开SDRAM就不对。
查看更多
11
个回答
默认排序
按发布时间排序
bernard
2011-12-13
这家伙很懒,什么也没写!
这个是SDRAM,你需要配置的。
bernard
2011-12-13
这家伙很懒,什么也没写!
NXP应该有相关的例程,不过2MB的估计比较少,你可以先试试8M、16MB的。
江南孤舟
2011-12-13
这家伙很懒,什么也没写!
在keil里新建个工程可以挂SDRAM啊,蜂鸣器能动作,说明程序能运行,但是在空的rt-thread工程里加上SDRAM,把同样的蜂鸣器动作加进去就不对,用内部RAM就可以。请问LS挂SDRAM时start_rvds.S文件要修改什么?
江南孤舟
2011-12-13
这家伙很懒,什么也没写!
EMC_SETUP EQU 1 EMC_DYNAMIC_SETUP EQU 1 EMC_DYNCS0_SETUP EQU 1 EMC_DYN_CFG0_Val EQU 0x00080280 就这几个定义打开就行了啊,启动代码应该不需要修改吧。不知道为什么不行,请教下。
江南孤舟
2011-12-13
这家伙很懒,什么也没写!
忘了说,我的配置时序等数据是我以前裸跑系统里设置好的。应该问题不大,仿真也不行, *** error 65: access violation at 0xA0033000 : no 'read' permission *** error 65: access violation at 0xA0000084 : no 'write' permission
aozima
2011-12-13
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
如何开启SDRAM与RT-Thread没什么关系。 可以先不要在MDK里面勾上SDRAM部分,也不要在RT-Thread把SDRAM把配置为Heap. 先独立对SDRAM做一下测试, 然后把SDRAM配置成heap做rt_malloc用。 mem_test可以使用: [https://rt-thread.googlecode.com/svn/trunk/examples/test/mem_test.c](https://rt-thread.googlecode.com/svn/tr ... mem_test.c)
江南孤舟
2011-12-13
这家伙很懒,什么也没写!
>如何开启SDRAM与RT-Thread没什么关系。 > >可以先不要在MDK里面勾上SDRAM部分,也不要在RT-Thread把SDRAM把配置为Heap. >先独立对SDRAM做一下测试, > >然后把SDRAM配置成heap做rt_malloc用。 > >mem_test可以使用: >[https://rt-thread.googlecode.com/svn/trunk/examples/test/mem_test.c](https://rt-thread.googlecode.com/svn/tr ... mem_test.c) --- 你说的“把SDRAM把配置为Heap”是怎么配置的,我没有这步操作啊?
bernard
2011-12-13
这家伙很懒,什么也没写!
你直接把SDRAM作为RW、ZI、Heap了?这样你需要在RTT跑起来之前就把SDRAM配置好。 你还是先用内部的,然后把SDRAM配置成Heap,这样先用起来,再考虑其他的。
江南孤舟
2011-12-13
这家伙很懒,什么也没写!
>你直接把SDRAM作为RW、ZI、Heap了?这样你需要在RTT跑起来之前就把SDRAM配置好。 > >你还是先用内部的,然后把SDRAM配置成Heap,这样先用起来,再考虑其他的。 --- 是我的问题,谢谢二位的指教,调试SDRAM配置先,谢谢。
江南孤舟
2011-12-14
这家伙很懒,什么也没写!
>如何开启SDRAM与RT-Thread没什么关系。 > >可以先不要在MDK里面勾上SDRAM部分,也不要在RT-Thread把SDRAM把配置为Heap. >先独立对SDRAM做一下测试, > >然后把SDRAM配置成heap做rt_malloc用。 > >mem_test可以使用: >[https://rt-thread.googlecode.com/svn/trunk/examples/test/mem_test.c](https://rt-thread.googlecode.com/svn/tr ... mem_test.c) --- 昨天测试了下,开始我的PCONP没有打开。现在测试通过,但在MDK里面勾上SDRAM部分,还是不对,你所说的“在RT-Thread把SDRAM把配置为Heap”是怎么设置的,是启动代码的内容吗?以下是我的测试代码,已通过. ``` /* * File : app.c * This file is part of RT-Thread RTOS * COPYRIGHT (C) 2006, RT-Thread Development Team * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://openlab.rt-thread.com/license/LICENSE * * Change Logs: * Date Author Notes * 2008-12-11 xuxinming the first version */ #include
#include
#define INT32U unsigned long /** * @addtogroup LPC2478 */ /*@{*/ char thread1_stack[512]; char thread2_stack[512]; struct rt_thread thread1; struct rt_thread thread2; void thread1_entry(void* parameter) { int i; while (1) { for (i = 0; i < 10; i ++) { rt_kprintf("%d ", i); rt_thread_delay(100); } } } void sysDelayNS(INT32U uiDly) { INT32U i; for(; uiDly > 0; uiDly--){ for(i = 0; i < 5000; i++); } }void SDRAMInit( void ) { volatile INT32U i, dummy ; LCD_CTRL = 0x00; sysDelayNS(10); PCONP |= 1 << 11; /* * 使能SDRAM总线连接 */ #if 1 PINSEL4 |= 0x50000000;//SRAM(CS2,CS3) PINSEL5 |= 0x05010555;//SDRAM(CS0,CS1) PINSEL6 |= 0x55555555;//D0~D15 PINSEL8 |= 0x15555555;//A0~A15 PINSEL9 |= 0x50550000;//A16~A23 , /OE , /WE , BLS0 , BLS1 , /CS0 , /CS1; EMC_CTRL = 0x00000001; /* Disable Address mirror */ #else //原程序 PINSEL4 |= 0x50000000;//SRAM(CS2,CS3) PINSEL5 |= 0x05050555;//SDRAM(CS0,CS1) PINSEL6 |= 0x55555555;//D0~D15 PINSEL8 |= 0x55555555;//A0~A15 PINSEL9 |= 0x50555555;//A16~A23 , /OE , /WE , BLS0 , BLS1 , /CS0 , /CS1; EMC_CTRL = 0x00000001; /* Disable Address mirror */ #endif /* * 设置SDRAM访问时序. */ EMC_DYN_RP = 1; EMC_DYN_RAS = 2; EMC_DYN_SREX = 1; EMC_DYN_APR = 1; EMC_DYN_DAL = 5; EMC_DYN_WR = 2; EMC_DYN_RC = 3; EMC_DYN_RFC = 3; EMC_DYN_XSR = 5; EMC_DYN_RRD = 1; EMC_DYN_MRD = 2; EMC_DYN_RD_CFG = 1; /* Command delayed strategy */ /* * Default setting, * RAS latency 3 CCLKs, * CAS latenty 3 CCLKs. */ EMC_DYN_RASCAS0 = 0x00000303; /* * 64MB, 1Mx16, * 4 banks, row=12, * column=8 */ EMC_DYN_CFG0 = 0x00000280; for (i = 0; i < 0x80; i++) { } /* * Mem clock enable, * CLKOUT runs, send command: * NOP */ EMC_DYN_CTRL = 0x00000183; for (i = 0; i < 0x80; i++) { } /* * Send command: * PRECHARGE-ALL, * shortest possible refresh period */ EMC_DYN_CTRL = 0x00000103; for (i = 0; i < 0x80; i++) { } /* * set 32 CCLKs * between SDRAM refresh * cycles */ EMC_DYN_RFSH = 0x00000004; for (i = 0; i < 0x80; i++) { /* wait 128 AHB clock cycles */ } /* * set 45 x 16CCLKs=720CCLK=15us * between SDRAM refresh * cycles */ EMC_DYN_RFSH = 45; /* * To set mode register in SDRAM, * enter mode by issue MODE command, after finishing, * bailout and back to NORMAL mode. * Mem clock enable, CLKOUT runs, send command: MODE */ EMC_DYN_CTRL = 0x00000083; dummy = *((volatile int *)(0xA0019800)); EMC_DYN_CTRL = 0x00000000; /* Send command: NORMAL */ EMC_DYN_CFG0 = 0x00080280; /* Enable buffer */ for (i = 0; i < 0x80; i++) { } } #define TEST_ADDR 0xA011FF00 /* 测试起始地址 */ #define SIZE 100 /* 测试100个SDRAM空间 */ #define BEEP (1<<0) #define BeepOFF() FIO0SET |= BEEP #define BeepON() FIO0CLR |= BEEP void thread2_entry(void* parameter) { volatile int count = 0; unsigned long i; rt_uint8_t * p_uint8_t = (rt_uint8_t *)TEST_ADDR; PINSEL0 &= ~0x00000003; SCS |= 0x01; FIO0DIR |= BEEP; BeepOFF(); // 初始化SDRAM接口 SDRAMInit(); // 测试SDRAM连接是否正常 p_uint8_t = (rt_uint8_t *)TEST_ADDR; for (i=0;i < SIZE;i++) *p_uint8_t++ = (rt_uint8_t)i; p_uint8_t = (rt_uint8_t *)TEST_ADDR; for(i=0; i
撰写答案
登录
注册新账号
关注者
0
被浏览
6.8k
关于作者
江南孤舟
这家伙很懒,什么也没写!
提问
3
回答
10
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
rt-smart启动流程分析
2
EtherKit快速上手PROFINET
3
RTThread USB转串口无法接收数据
4
HC32F4A0 SD卡挂载及热插拔的实现
5
vscode插件 - RT-Thread Studio项目助手 | 跨平台开发
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
cubemx
PWM
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
编译报错
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
812
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
1
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部