金牌会员
 
- 积分
- 1007
- 金钱
- 1007
- 注册时间
- 2015-7-26
- 在线时间
- 108 小时
|
5金钱
这是基于原子的sram驱动写的,只不过原子的是512k*16,我的是256k*16;我定义一个数组testsram然后对他循环赋值,发现如果testsram是u16型的话,他循环赋值赋到127时,下一个testsram[128]=128时,会将testsram[0]也变成128,testsram[129]=129时testsram[1]=129,然后循环,就是说以128为一个单位,第二个单位会覆盖第一个单位,第四个单位会覆盖第三个单位,如果testsram是u32型的话,就会发现以64为一个单位,在网上看了一些但是不太明白,例如这个精华帖http://www.openedv.com/posts/list/33759.htm,只定义了一个数组然后sram初始化,然后直接对数组赋值,就是这个赋值过程就出现了问题,是我初始化问题呢?还是我硬件焊接问题?
这是fsmc和sram连接图
#define Bank1_SRAM3_ADDR ((u32)(0x68000000))
void FSMC_SRAM_Init(void)
{
FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;
FSMC_NORSRAMTimingInitTypeDef readWriteTiming;
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD|RCC_APB2Periph_GPIOE|RCC_APB2Periph_GPIOF|RCC_APB2Periph_GPIOG,ENABLE);
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC,ENABLE);
GPIO_InitStructure.GPIO_Pin = 0xFF33; //PORTD¸′óÃíÆíìêä3ö ¸ßμçÆ½ÎaÑ¡ÖDòy½Å
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //¸′óÃíÆíìêä3ö
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOD, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = 0xFF83; //PORTE¸′óÃíÆíìêä3ö
GPIO_Init(GPIOE, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = 0xF03F; //PORTD¸′óÃíÆíìêä3ö
GPIO_Init(GPIOF, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = 0x043F; //PORTD¸′óÃíÆíìêä3ö
GPIO_Init(GPIOG, &GPIO_InitStructure);
readWriteTiming.FSMC_AddressSetupTime = 10; //μØÖ·½¨á¢ê±¼ä£¨ADDSET£©Îa1¸öHCLK 1/36M=27ns
readWriteTiming.FSMC_AddressHoldTime = 10; //μØÖ·±£3Ö걼䣨ADDHLD£©Ä£ê½AÎ′óÃμ½
readWriteTiming.FSMC_DataSetupTime = 2; //êy¾Y±£3Ö걼䣨DATAST£©Îa3¸öHCLK 4/72M=55ns(¶ÔEMμÄSRAMD¾Æ¬)
readWriteTiming.FSMC_BusTurnAroundDuration = 0x00;
readWriteTiming.FSMC_CLKDivision = 0x00;
readWriteTiming.FSMC_DataLatency = 0x00;
readWriteTiming.FSMC_AccessMode = FSMC_AccessMode_A; //Ä£ê½A
FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3;// ÕaàïÎòÃÇê1óÃNE3 £¬ò2¾í¶Ôó|BTCR[4],[5]¡£
FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;
FSMC_NORSRAMInitStructure.FSMC_MemoryType =FSMC_MemoryType_SRAM;// FSMC_MemoryType_SRAM; //SRAM
FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;//′æ′¢Æ÷êy¾Y¿í¶èÎa16bit
FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode =FSMC_BurstAccessMode_Disable;// FSMC_BurstAccessMode_Disable;
FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait=FSMC_AsynchronousWait_Disable;
FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;
FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable; //′æ′¢Æ÷D′ê1Äü
FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; // ¶áD′ê1óÃÏàí¬μÄê±Dò
FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &readWriteTiming;
FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &readWriteTiming; //¶áD′í¬Ñùê±Dò
FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure); //3õê¼»ˉFSMCÅäÖÃ
FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE); // ê1ÄüBANK3
}
#define num 200
u16 testsram[num] __attribute__((at(0X68000000)));//2aêÔóÃêy×é
int main(void)
{
u16 ts=0;
delay_init(); //Ñóê±oˉêy3õê¼»ˉ
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//éèÖÃÖD¶ÏóÅÏè¼¶·Ö×éÎa×é2£o2λÇàÕ¼óÅÏè¼¶£¬2λÏìó|óÅÏè¼¶
uart_init(9600); //′®¿ú3õê¼»ˉÎa115200
LCD_hard_Init(); //3õê¼»ˉLCD
POINT_COLOR=RED; //éèÖÃ×ÖìåÎaoìé«
LCD_ShowString(30,50,200,16,16,"WarShip STM32");
LCD_ShowString(30,70,200,16,16,"SRAM TEST");
POINT_COLOR=BLUE;//éèÖÃ×ÖìåÎaà¶é«
FSMC_SRAM_Init(); //3õê¼»ˉía2¿SRAM
delay_ms(1000);
for(ts=0;ts<120;ts+=1)
testsram[ts]=ts;
for(ts=120;ts<num;ts+=1)
testsram[ts]=ts;
}
|
|