OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3460|回复: 2

STM32F103通过FSMC读取FPGA时读取不过来

[复制链接]

1

主题

2

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2020-11-20
在线时间
2 小时
发表于 2020-11-20 17:15:57 | 显示全部楼层 |阅读模式
1金钱
想写一个FPGA测频程序,然后通过FSMC读取到STM32中,但是读取不过来,用逻辑分析仪看到FPGA中数据是正确的,不知道是不是FSMC配置这块出现了问题,请大佬们看一下,截取部分代码如下:

void FSMC_SRAM_Init(void)
{
        FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure;                       
        FSMC_NORSRAMTimingInitTypeDef readWriteTiming;                                       
        GPIO_InitTypeDef GPIO_InitStructure;                                                                       

        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD, ENABLE);   
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE, ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);       
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_14                                       
                                     |GPIO_Pin_15|GPIO_Pin_0|GPIO_Pin_1;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                                               
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOD,&GPIO_InitStructure);
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10                                       
                                     |GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14
                                     |GPIO_Pin_15;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                                               
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOE,&GPIO_InitStructure);
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_13;                                                                       
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                                               
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOD,&GPIO_InitStructure);

        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5                                               
                                                                                                                         |GPIO_Pin_6;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                                               
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOE,&GPIO_InitStructure);
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_7;                                                                                       
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                                               
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOD,&GPIO_InitStructure);

        readWriteTiming.FSMC_AddressSetupTime = 0;                                                               
        readWriteTiming.FSMC_AddressHoldTime = 0;                                                       
        readWriteTiming.FSMC_DataSetupTime = 2;                                                               
        readWriteTiming.FSMC_BusTurnAroundDuration = 0;
        readWriteTiming.FSMC_CLKDivision = 0;
        readWriteTiming.FSMC_DataLatency = 0;
        readWriteTiming.FSMC_AccessMode = FSMC_AccessMode_A;
       
        FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1;                                                                                                                               
        FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable;                                                               
        FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM;                                                                                               
        FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b;                                                                       
        FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable;                                                       
        FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low;
        FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable;
        FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState;
        FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable;
        FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable;
        FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable;
        FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable;                                                                       
        FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable;                                                                               
        FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &readWriteTiming;                                                                               
        FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &readWriteTiming;                                                                                               
       
        FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure);
       
        FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1,ENABLE);
}

void FSMC_SRAM_GPIO_Init(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
       
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_4;                //Sel[2:0]--PA2,PA1,PA0                fgate--PA4
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                                               
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
       
        GPIO_Init(GPIOA, &GPIO_InitStructure);
       
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;                                                                        //nRST--PC0
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                                               
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
       
        GPIO_Init(GPIOC, &GPIO_InitStructure);
       
        FSMC_Sel2_0;
        FSMC_Sel1_0;
        FSMC_Sel0_0;
       
        FSMC_fgate_0;
}


void FREQmeasure_100k_1M(void)
{
        FSMC_Sel2_1;
        FSMC_Sel1_0;
        FSMC_Sel0_0;
}


uint16_t FSMC_FPGA_ReadByte(uint32_t ReadAddr)
{
        uint16_t tmp;
        tmp = *(volatile uint16_t*)(Bank1_SRAM1_ADDR + (ReadAddr << 17));
        return tmp;
}

最佳答案

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

2

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2020-11-20
在线时间
2 小时
 楼主| 发表于 2020-11-20 17:15:58 | 显示全部楼层
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2020-11-21 01:32:55 | 显示全部楼层
帮顶
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-22 18:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表