OpenEdv-开源电子网

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

AD7616硬件并口模式配置问题

[复制链接]

2

主题

11

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
294
金钱
294
注册时间
2017-1-18
在线时间
90 小时
发表于 2018-7-11 20:22:12 | 显示全部楼层 |阅读模式
5金钱
最近在调试AD7616硬件模式,并口传输。采取方案是STM32+FSMC控制并读取AD7616数据。 现在模式配置上出现疑问,需要大佬给个正确配置思路。现在现象是FSMC配置确保无问题,但是AD7616 DB0-DB15全部为“1”,AD上面数据没有更新。初步认为AD的配置存在问题。

FSMC读取AD时序

FSMC读取AD时序

AD7616模式配置

AD7616模式配置

FSMC_BANK1 读取数据全部为FFFF

FSMC_BANK1 读取数据全部为FFFF
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2018-7-12 01:23:14 | 显示全部楼层
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
15
金钱
15
注册时间
2018-7-24
在线时间
1 小时
发表于 2018-7-24 14:36:41 | 显示全部楼层
我也遇到了相同的情况 也是用的FSMC的方式 采集的也全部是FFFF 时序也都是对的 和你的一样
但是我发现在并口的各个io口电平不太一样 有的io口出现类似三角波一样的 所以建议你也看下波形 我用spi的方式是没有问题的
回复

使用道具 举报

0

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
97
金钱
97
注册时间
2017-1-3
在线时间
20 小时
发表于 2019-4-16 10:00:05 | 显示全部楼层
请问楼主是否调通了,我用的跟你一样的方案,也遇到这样的情况了
回复

使用道具 举报

7

主题

88

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
276
金钱
276
注册时间
2015-1-10
在线时间
70 小时
发表于 2019-6-19 15:08:13 | 显示全部楼层
大家调通了吗?
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
7
金钱
7
注册时间
2019-8-3
在线时间
1 小时
发表于 2019-8-3 20:41:22 | 显示全部楼层
大家有没有调试通的
回复

使用道具 举报

2

主题

27

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
267
金钱
267
注册时间
2012-8-31
在线时间
66 小时
发表于 2019-8-22 16:05:22 | 显示全部楼层
dinghh 发表于 2019-8-3 20:41
大家有没有调试通的

我用的7616 + F4 可以采集到数据
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手上路

积分
43
金钱
43
注册时间
2017-10-9
在线时间
10 小时
发表于 2019-9-18 11:01:10 | 显示全部楼层
大家有调试通的,能共享下软件配置代码么?只用硬件模式调试通了,软件模式始终不能用!
回复

使用道具 举报

0

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
57
金钱
57
注册时间
2020-9-10
在线时间
12 小时
发表于 2020-9-10 09:40:12 | 显示全部楼层
你这个问题我可以解答,FSMC要用模式A读取,AddressSetupTime>10ns,DataSetupTime>20ns,这样就可以读取,不过我遇到另外的问题,软件模式切换通道不可靠,而且寄存器内容不能正确读出。我怀疑是NWE信号上升沿后的数据保持时间只有1个HCLK时间是不够的,但是我又不会增加。
回复

使用道具 举报

2

主题

27

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
267
金钱
267
注册时间
2012-8-31
在线时间
66 小时
发表于 2020-10-30 10:09:40 | 显示全部楼层
along1213 发表于 2020-9-10 09:40
你这个问题我可以解答,FSMC要用模式A读取,AddressSetupTime>10ns,DataSetupTime>20ns,这样就可以读取, ...

也遇到了F4用FMC驱动7616的一些问题,想请教。DMA读出的数据都点乱。想探讨探讨!
回复

使用道具 举报

0

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
57
金钱
57
注册时间
2020-9-10
在线时间
12 小时
发表于 2020-11-13 15:22:07 | 显示全部楼层
zhengwending 发表于 2020-10-30 10:09
也遇到了F4用FMC驱动7616的一些问题,想请教。DMA读出的数据都点乱。想探讨探讨!

FMC设置:p.FMC_AddressSetupTime = 4;
  p.FMC_AddressHoldTime = 0;
  p.FMC_DataSetupTime = 10;
  p.FMC_BusTurnAroundDuration = 0;
  p.FMC_CLKDivision = 0;
  p.FMC_DataLatency = 0;
  p.FMC_AccessMode = FMC_AccessMode_A;

  FMC_NORSRAMInitStructure.FMC_Bank = FMC_Bank1_NORSRAM1;
  FMC_NORSRAMInitStructure.FMC_DataAddressMux = FMC_DataAddressMux_Disable;
  FMC_NORSRAMInitStructure.FMC_MemoryType = FMC_MemoryType_SRAM;
  FMC_NORSRAMInitStructure.FMC_MemoryDataWidth = FMC_NORSRAM_MemoryDataWidth_16b;
  FMC_NORSRAMInitStructure.FMC_BurstAccessMode = FMC_BurstAccessMode_Disable;
  FMC_NORSRAMInitStructure.FMC_AsynchronousWait = FMC_AsynchronousWait_Disable;  
  FMC_NORSRAMInitStructure.FMC_WaitSignalPolarity = FMC_WaitSignalPolarity_Low;
  FMC_NORSRAMInitStructure.FMC_WrapMode = FMC_WrapMode_Disable;
  FMC_NORSRAMInitStructure.FMC_WaitSignalActive = FMC_WaitSignalActive_BeforeWaitState;
  FMC_NORSRAMInitStructure.FMC_WriteOperation = FMC_WriteOperation_Enable;
  FMC_NORSRAMInitStructure.FMC_WaitSignal = FMC_WaitSignal_Disable;
  FMC_NORSRAMInitStructure.FMC_ExtendedMode = FMC_ExtendedMode_Enable;
  FMC_NORSRAMInitStructure.FMC_WriteBurst = FMC_WriteBurst_Disable;
  FMC_NORSRAMInitStructure.FMC_ContinousClock = FMC_CClock_SyncOnly;
  FMC_NORSRAMInitStructure.FMC_ReadWriteTimingStruct = &p;
  FMC_NORSRAMInitStructure.FMC_WriteTimingStruct = &p;

  FMC_NORSRAMInit(&FMC_NORSRAMInitStructure);
        FMC_NORSRAMCmd(FMC_Bank1_NORSRAM1,ENABLE);
DMA设置:
DMA_StructInit(&DMA_InitStructure);
        DMA_InitStructure.DMA_Channel =DMA_Channel_7;
  DMA_InitStructure.DMA_PeripheralBaseAddr = 0x60000000;
  DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)ADC_BUF[1];
  DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;
  DMA_InitStructure.DMA_BufferSize =DEEP;
  DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
  DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
  DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
  DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
  DMA_InitStructure.DMA_Mode = DMA_Mode_Normal;
  DMA_InitStructure.DMA_Priority = DMA_Priority_Medium;
        DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;         
  DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_Full;
        DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
        DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;//íaéèí»·¢μ¥′Î′«êä
  DMA_Init(DMA2_Stream4, &DMA_InitStructure);
               
        DMA_InitStructure.DMA_PeripheralBaseAddr = 0x60000000;
  DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)ADC_BUF[0];
        DMA_Init(DMA2_Stream3, &DMA_InitStructure);
定时器设置:
GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_AF;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;   
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;      //íÆíìêä3ö
  GPIO_InitStructure.GPIO_PuPd  = GPIO_PuPd_NOPULL;
        GPIO_InitStructure.GPIO_Pin =GPIO_Pin_6;
        GPIO_Init(GPIOC, &GPIO_InitStructure);
        GPIO_PinAFConfig(GPIOC, GPIO_PinSource6 , GPIO_AF_TIM8);

       
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM8,ENABLE);          //TIM8ê±Öóê1Äü  
        TIM_DeInit(TIM8);
        TIM_TimeBaseStructure.TIM_Prescaler=5;  //¶¨ê±Æ÷·ÖÆμ,30MHZ
        TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounterMode_Up; //ÏòéϼÆêyÄ£ê½
        TIM_TimeBaseStructure.TIM_Period=psc;
        TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1;
        TIM_TimeBaseStructure.TIM_RepetitionCounter=0;
        TIM_TimeBaseInit(TIM8,&TIM_TimeBaseStructure);//3õê¼»ˉ¶¨ê±Æ÷1
       
        TIM_OCStructInit(&TIM_OCInitStructure);
        TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
        TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
        TIM_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Disable;
        TIM_OCInitStructure.TIM_Pulse =4;
        TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Reset;
        TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
        TIM_OC1Init(TIM8,&TIM_OCInitStructure);
        TIM_OC1PreloadConfig(TIM8,TIM_OCPreload_Enable);
       
        TIM_OCInitStructure.TIM_Pulse =22;//19
        TIM_OC2Init(TIM8,&TIM_OCInitStructure);
        TIM_OC2PreloadConfig(TIM8,TIM_OCPreload_Enable);
        TIM_OCInitStructure.TIM_Pulse =32;//27
        TIM_OC3Init(TIM8,&TIM_OCInitStructure);
        TIM_OC3PreloadConfig(TIM8,TIM_OCPreload_Enable);
CONV是用PC6定时器触发的
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

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

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-22 09:41

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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