你的浏览器版本过低,可能导致网站不能正常访问!为了你能正常使用网站功能,请使用这些浏览器。
butterflyspring 发表于 2018-3-5 17:23 你这个i--在while里面?你没有到DMA的接收完成中断?你最好检测两个频率下的miso和clk的区别. ...
使ç¨i--ï¼æ²¡æ使ç¨ä¸ææ¹å¼
ç´æ¥whileï¼1ï¼ï¼ä½¿ç¨DMAä¼ è¾å®æä¸æ
maxtch 发表于 2018-3-5 17:03 CS 不是高速信号,长一点无所谓,不加 delay 应该也是没有问题的。DMA 溢出是有可能,这么快的速率 DMA ...
dh2964169 发表于 2018-3-6 15:07 现在只需要对100KHz的正弦信号,采取500个点,也就是DMA缓存500个数据就行了,spi的sclk才2.8MHz,DMA存 ...
maxtch 发表于 2018-3-6 19:51 DMA 的溢出问题不是速度太慢 FIFO 溢出,而是分配的内存区域太小或者和别的东西重叠导致的指针溢出。500 ...
dh2964169 发表于 2018-3-6 20:56 啊啊,我直接是定义了一个数组变量ADC_ConvertedValue[500],然后让DMA指向这个数组,当500个数据存入了 ...
maxtch 发表于 2018-3-6 21:11 我做嵌入式到现在还没用到过这么大数据流量用单片机处理的东西,到了这种数据吞吐我一般就直接上能跑 Lin ...
dh2964169 发表于 2018-3-7 12:15 哦哦,是数据量太大了啊,但是32分频没有问题额。速度提高到16分频2.8MHz的SCLK就出现问题。谢谢您的建议 ...
查看全部评分
maxtch 发表于 2018-3-7 14:14 32 分频的时候程序端消耗数据足够快。16 分频的时候没等程序吧数据给消耗掉就被 DMA 覆盖了。如果你确定 ...
dh2964169 发表于 2018-3-8 09:03 呃呃,@maxtch 我并没有对采样数据作处理哦,只是通过DMA方式,将外设SPI_DR数据传输到内存ADC_C ...
maxtch 发表于 2018-3-8 11:28 中断服务程序太大啦! 另外,打印的过程就是我所说的数据处理过程,而且远远要比 DMA 慢,吞吐量不够了 ...
dh2964169 发表于 2018-3-8 19:13 这一点可能您理解有些错误哦。 程序是的中断标志位是:500个数据全部存入到ADC_ConvertedValue[500 ...
maxtch 发表于 2018-3-8 19:42 中断服务程序里面大量打印东西这做法本身就有问题。
dh2964169 发表于 2018-3-8 20:01 确实是这样子的。但是在上面的程序中进入中断后,就是程序进行的最后一段了。不会被SPI和DMA所影响 ...
maxtch 发表于 2018-3-8 21:40 DMA 停了吗?
再贴出两种方式的采集数据,并在EXCEL中绘制的波形图(两种情况波形都差不多,但是无法得到标准的波形)
使ç¨i--ï¼æ²¡æ使ç¨ä¸ææ¹å¼
ç´æ¥whileï¼1ï¼ï¼ä½¿ç¨DMAä¼ è¾å®æä¸æ
现在只需要对100KHz的正弦信号,采取500个点,也就是DMA缓存500个数据就行了,spi的sclk才2.8MHz,DMA存取的速度很快,所以又觉得不是DMA 溢出问题,有些矛盾。请帮我在观察下,那里还有问题呢,谢谢啦
DMA 的溢出问题不是速度太慢 FIFO 溢出,而是分配的内存区域太小或者和别的东西重叠导致的指针溢出。500 个数据就要分配 1k 到 2k 的内存缓冲区,你给够了吗?
啊啊,我直接是定义了一个数组变量ADC_ConvertedValue[500],然后让DMA指向这个数组,当500个数据存入了这个数组后,再在DMA完成中断服务函数中打印出、
好像我理解的太简单了,随意定义一个数组就可以装数据了。请问下@maxtch 我该如何去解决这个,请给与指点啊,谢谢你
我做嵌入式到现在还没用到过这么大数据流量用单片机处理的东西,到了这种数据吞吐我一般就直接上能跑 Linux 的高速 SoC 了。
DMA 的内存分配往往有特殊要求,你要看芯片手册里面是怎么描述的。
哦哦,是数据量太大了啊,但是32分频没有问题额。速度提高到16分频2.8MHz的SCLK就出现问题。谢谢您的建议
32 分频的时候程序端消耗数据足够快。16 分频的时候没等程序吧数据给消耗掉就被 DMA 覆盖了。如果你确定你的程序吞吐量足够,那就尝试一下乒乓 DMA;要不然就优化你的算法,或者换更快的主控。
评分
查看全部评分
呃呃,@maxtch 我并没有对采样数据作处理哦,只是通过DMA方式,将外设SPI_DR数据传输到内存ADC_ConvertedValue[500]中,最后在全部数据传输完成后再在中断服务函数中打印。
所以应该不是上面您说的,程序消耗数据的过程吧,不知我是否理解清楚,请再指教啊
中断服务程序太大啦!
另外,打印的过程就是我所说的数据处理过程,而且远远要比 DMA 慢,吞吐量不够了。
这一点可能您理解有些错误哦。
程序是的中断标志位是:500个数据全部存入到ADC_ConvertedValue[500]后,然后DMA的传输完成标志位置1,然后再中断服务函数中打印已经存好的500个数据,所以啊这个打印数据的过程和DMA过程不是交替进行,而是DMA全部完成后,再打印数据的;
您看看这样理解的有偏差没,如果这里没有错的话,那是哪里还可能有问题呢,谢谢你
中断服务程序里面大量打印东西这做法本身就有问题。
确实是这样子的。但是在上面的程序中进入中断后,就是程序进行的最后一段了。不会被SPI和DMA所影响,还有就是,32分频的时候,还是没有问题。会不会是其他地方的问题呢
DMA 停了吗?
我在中断服务函数中,在打印数据之前或者之后关闭DMA和SPI ,然而16分频的SPI设置依然不能准确采样。麻烦了,谢谢你啊