搜索
bottom↓
回复: 2

PIC24EP使用DMA进行UART通讯的问题,求解答

[复制链接]

出0入0汤圆

发表于 2015-12-1 11:53:07 | 显示全部楼层 |阅读模式
char uart1SendBuffer[UART1_SEND_BUF_NUM] __attribute__((space(dma)));
上面这段代码我从PIC24HJ64GP504的项目移植到PIC24EP512GU810的项目上,编译器都是XC16 V1.25,在PIC24HJ64GP504项目上可以顺利编译通过,但是在PIC24EP512GU810的项目上编译的时候出现了下面的错误:
build/default/production/uart1.o: Link Error: Could not allocate section _0498B8A0565bfcb8, size = 128 bytes, attributes = bss dma

仔细看了手册也没有看出来两个芯片在这方面的区别,求解,非常感谢

出20入12汤圆

发表于 2015-12-1 12:17:34 | 显示全部楼层
Section 22. Direct Memory Access (DMA),
DS70348C 41~42页,
unsigned int BufferA[8];
unsigned int BufferB[8];
DMA0CON = 0x2001; // One-Shot, Post-Increment, RAM-to-Peripheral
DMA0CNT = 7; // Eight DMA requests
DMA0REQ = 0x001F; // Select UART2 transmitter
DMA0PAD = (volatile unsigned int) &U2TXREG;
DMA0STAL = __builtin_dmaoffset(BufferA);
DMA0STAH = 0x0000;
IFS0bits.DMA0IF = 0; // Clear DMA Interrupt Flag
IEC0bits.DMA0IE = 1; // Enable DMA interrup

并没有专门修饰__attribute__((space(dma)));

出0入0汤圆

 楼主| 发表于 2015-12-1 17:35:06 | 显示全部楼层
gaolf_2012 发表于 2015-12-1 12:17
Section 22. Direct Memory Access (DMA),
DS70348C 41~42页,
unsigned int BufferA[8];


首先多谢解答,我的理解__builtin_dmaoffset(BufferA)这个内建函数返回的实际上是bufferA在DPSRAM(DMA RAM)中相对起始地址的偏移值,
如果之前不用__attribute__((space(dma)))来修饰,编译器如何知道给bufferA分配内存的时候是在DPSRAM空间还是在普通的RAM空间?
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-29 09:04

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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