专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
SEED-DEC6713 MCASP和AIC23B的问题
2019-03-26 15:57
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
DSP
13730
7
941
大家好,为什么我在连接AIC23B和6713时,设置AIC23B为Master,然后MCASP总是无法使能位时钟,总是停留在
MCASP_FSETS(GBLCTL1,XCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XCLKRST));
这一句
希望懂的人指点一下,多谢! 此帖出自
小平头技术问答
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
7条回答
chhtx
2019-03-26 19:32
MCASP_ConfigGbl configGbl =
{
0x00000000, /* PFUNC - All pins as McASP */
// 0x1c000002, //AXR1 out,AFSX AHCLKX ACLKX out,others are inputs
0x00000080, /* PDIR - AXR1 out,others are inputs */
0x00000000, /* DITCTL - DIT mode disable */
0x00000003, /* DLBCTL - Loopback disabled */
0x00000000 /* AMUTE - Never drive AMUTE */
};
MCASP_ConfigRcv configRcv =
{
0xffffffff, /* RMASK - Use all 32 bits */
0x000180f0, //1-bit delay,MSB first, 32-bit slots, DAT bus,
0x00000111, //AFSRCTL 2-slot word frame sync, ext FS,falling
// 0x00000113, //AFSRCTL 2-slot word frame sync, in FS,falling
0x00000000, /* ACLKRCTL - Sample on rising CLK, divide by 1, ext CLK */
// 0x00000020, // ACLKRCTL - Sample on rising CLK, divide by 1, in CLK
0x00000000, /* AHCLKRCTL - External HCLK */
// 0x0000c031, //AHCLKRCTL - in HCLK, falling AHCLK, divide by 50
0x00000003, /* RTDM - Slots 0 1 are active */
0x00000000, /* RINTCTL - No interrupts */
0x00000000 /* RCLKCHK - Not used */
};
MCASP_ConfigXmt configXmt =
{
0xffffffff, /* XMASK - Use all 32 bits */
0x000180f0, //1-bit delay,MSB first, 32-bit slots, DAT bus,
//0x00000113, //AFSXCTL-2-slot word frame sync, in FS ,falling
0x00000111, //AFSXCTL-2-slot word frame sync, ext FS ,falling
// 0x000000e0, /* ACLKXCTL - Sample on falling CLK, async,divide by 1, in CLK */
//0x000000c0, /* ACLKXCTL - Sample on falling CLK, async,divide by 1, ext CLK */
0x00000080, /* ACLKXCTL - Sample on falling CLK, sync,divide by 1, ext CLK */
// 0x0000c031, /* AHCLKXCTL - in HCLK , falling , 50 divider*/
0x00000000, /* AHCLKXCTL - External HCLK */
0x00000003, /* XTDM - Slots 0 1 are active */
0x00000000, /* XINTCTL - No interrupts */
0x00000000 /* XCLKCHK - Not used */
};
MCASP_ConfigSrctl configSrctl =
{ //SRCTL,
0x00000000, /* SRCTL0 - Inactive */
0x00000000, /* SRCTL1 - Inactive*/
0x00000000, /* SRCTL2 - Inactive */
0x00000000, /* SRCTL3 - Inactive */
0x00000000, /* SRCTL4 - Inactive */
0x00000000, /* SRCTL5 - Inactive */
0x0000000e, /* SRCTL6 - Receive, active high */
0x0000000d /* SRCTL7 - Transmit, active high */
};
MCASP_configRcv(hMcASP, &configRcv);
for(i=0;i<10;i++);
MCASP_configXmt(hMcASP, &configXmt);
for(i=0;i<10;i++);
MCASP_configSrctl(hMcASP, &configSrctl);
for(i=0;i<10;i++);
MCASP_configGbl(hMcASP, &configGbl);
for(i=0;i<10;i++);
//启动高频时钟AHCLKX和AHCLKR
MCASP_FSETS(GBLCTL1,XHCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XHCLKRST));
MCASP_FSETS(GBLCTL1,RHCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RHCLKRST));
//启动时钟ACLKX和ACLKR
MCASP_FSETS(GBLCTL1,XCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XCLKRST));
MCASP_FSETS(GBLCTL1,RCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RCLKRST));
//启动串并转换器
MCASP_RSET(XSTAT1,0xffff);
MCASP_RSET(RSTAT1,0xffff);
MCASP_FSETS(GBLCTL1,XSRCLR,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XSRCLR));
MCASP_FSETS(GBLCTL1,RSRCLR,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RSRCLR));
//使状态机退出复位状态
MCASP_FSETS(GBLCTL1,XSMRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XSMRST));
MCASP_FSETS(GBLCTL1,RSMRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RSMRST));
// 将帧同步发生器退出复位状态
MCASP_FSETS(GBLCTL1,XFRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XFRST));
MCASP_FSETS(GBLCTL1,RFRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RFRST));
加载中...
查看其它7个回答
一周热门
更多
>
相关问题
相关文章
事件管理器――PWM
0个评论
FPGA时序分析基础(二):vivado中常用的时序约束命令
0个评论
LDO和BUCK降压稳压器对比
0个评论
伺服控制系统教学实验平台
0个评论
asoc之动态PCM
0个评论
ADS7928
0个评论
基于AD9957实现射频数字化变频模块和AD转换模块的方案详细教程
0个评论
多功能车载DVD智能导航平台
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
{
0x00000000, /* PFUNC - All pins as McASP */
// 0x1c000002, //AXR1 out,AFSX AHCLKX ACLKX out,others are inputs
0x00000080, /* PDIR - AXR1 out,others are inputs */
0x00000000, /* DITCTL - DIT mode disable */
0x00000003, /* DLBCTL - Loopback disabled */
0x00000000 /* AMUTE - Never drive AMUTE */
};
MCASP_ConfigRcv configRcv =
{
0xffffffff, /* RMASK - Use all 32 bits */
0x000180f0, //1-bit delay,MSB first, 32-bit slots, DAT bus,
0x00000111, //AFSRCTL 2-slot word frame sync, ext FS,falling
// 0x00000113, //AFSRCTL 2-slot word frame sync, in FS,falling
0x00000000, /* ACLKRCTL - Sample on rising CLK, divide by 1, ext CLK */
// 0x00000020, // ACLKRCTL - Sample on rising CLK, divide by 1, in CLK
0x00000000, /* AHCLKRCTL - External HCLK */
// 0x0000c031, //AHCLKRCTL - in HCLK, falling AHCLK, divide by 50
0x00000003, /* RTDM - Slots 0 1 are active */
0x00000000, /* RINTCTL - No interrupts */
0x00000000 /* RCLKCHK - Not used */
};
MCASP_ConfigXmt configXmt =
{
0xffffffff, /* XMASK - Use all 32 bits */
0x000180f0, //1-bit delay,MSB first, 32-bit slots, DAT bus,
//0x00000113, //AFSXCTL-2-slot word frame sync, in FS ,falling
0x00000111, //AFSXCTL-2-slot word frame sync, ext FS ,falling
// 0x000000e0, /* ACLKXCTL - Sample on falling CLK, async,divide by 1, in CLK */
//0x000000c0, /* ACLKXCTL - Sample on falling CLK, async,divide by 1, ext CLK */
0x00000080, /* ACLKXCTL - Sample on falling CLK, sync,divide by 1, ext CLK */
// 0x0000c031, /* AHCLKXCTL - in HCLK , falling , 50 divider*/
0x00000000, /* AHCLKXCTL - External HCLK */
0x00000003, /* XTDM - Slots 0 1 are active */
0x00000000, /* XINTCTL - No interrupts */
0x00000000 /* XCLKCHK - Not used */
};
MCASP_ConfigSrctl configSrctl =
{ //SRCTL,
0x00000000, /* SRCTL0 - Inactive */
0x00000000, /* SRCTL1 - Inactive*/
0x00000000, /* SRCTL2 - Inactive */
0x00000000, /* SRCTL3 - Inactive */
0x00000000, /* SRCTL4 - Inactive */
0x00000000, /* SRCTL5 - Inactive */
0x0000000e, /* SRCTL6 - Receive, active high */
0x0000000d /* SRCTL7 - Transmit, active high */
};
MCASP_configRcv(hMcASP, &configRcv);
for(i=0;i<10;i++);
MCASP_configXmt(hMcASP, &configXmt);
for(i=0;i<10;i++);
MCASP_configSrctl(hMcASP, &configSrctl);
for(i=0;i<10;i++);
MCASP_configGbl(hMcASP, &configGbl);
for(i=0;i<10;i++);
//启动高频时钟AHCLKX和AHCLKR
MCASP_FSETS(GBLCTL1,XHCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XHCLKRST));
MCASP_FSETS(GBLCTL1,RHCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RHCLKRST));
//启动时钟ACLKX和ACLKR
MCASP_FSETS(GBLCTL1,XCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XCLKRST));
MCASP_FSETS(GBLCTL1,RCLKRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RCLKRST));
//启动串并转换器
MCASP_RSET(XSTAT1,0xffff);
MCASP_RSET(RSTAT1,0xffff);
MCASP_FSETS(GBLCTL1,XSRCLR,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XSRCLR));
MCASP_FSETS(GBLCTL1,RSRCLR,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RSRCLR));
//使状态机退出复位状态
MCASP_FSETS(GBLCTL1,XSMRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XSMRST));
MCASP_FSETS(GBLCTL1,RSMRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RSMRST));
// 将帧同步发生器退出复位状态
MCASP_FSETS(GBLCTL1,XFRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,XFRST));
MCASP_FSETS(GBLCTL1,RFRST,ACTIVE);
while(!MCASP_FGET(GBLCTL1,RFRST));
一周热门 更多>