FPGA后面DA的程序设计问题,望高手指导!!

FPGA后面DA的程序设计问题,望高手指导!!,第1张

不知道你具体想要干什么,只能简单说下:根据你的设计需求选取一个DA芯片(问老师),每个芯片都有配套的手册,上面写了使用方法,包括输入输出管脚,输入输出瞎团信号的格式,每个管脚磨链橘的外围电路唤拿怎么连,最重要的提供芯片的内部配置(就是配置DA芯片的寄存器)。自己编写硬件描述语言配准DA芯片,FPGA连接DA。

比如我现在用的CH7301是DVI接口的DA芯片,使用VHDL语言,根据IIC总线协议配置 CH7301的工作方式。 还是比较麻烦的。

//DAC通道1输出初始化

void Dac1_Init(void)

{

GPIO_InitTypeDef GPIO_InitStructure

DAC_InitTypeDef DAC_InitType

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE ) //使能PORTA通道时钟

RCC_APB1PeriphClockCmd(RCC_APB1Periph_DAC, ENABLE ) //使能DAC通道时钟

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4 // 端口配置

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN //模拟输入

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz

GPIO_Init(GPIOA, &GPIO_InitStructure)

GPIO_SetBits(GPIOA,GPIO_Pin_4) //PA.4 输出高

DAC_InitType.DAC_Trigger=DAC_Trigger_None //不使用触发功能 TEN1=0

DAC_InitType.DAC_WaveGeneration=DAC_WaveGeneration_None//不神梁汪使用波形发生

DAC_InitType.DAC_LFSRUnmask_TriangleAmplitude=DAC_LFSRUnmask_Bit0//屏蔽、幅值设置

DAC_InitType.DAC_OutputBuffer=DAC_OutputBuffer_Disable //DAC1输出缓存关闭 BOFF1=1

DAC_Init(DAC_Channel_1,&DAC_InitType) //初始化DAC通道1

DAC_Cmd(DAC_Channel_1, ENABLE) //使能DAC1

DAC_SetChannel1Data(DAC_Align_12b_R, 0) //12位右对齐数据格式设置DAC值

}

//设置通道1输出电压

//vol:0~3300,代表0~3.3V

void Dac1_Set_Vol(u16 vol)

{

float temp=vol

temp/=1000

temp=temp*4096/3.3

DAC_SetChannel1Data(DAC_Align_12b_R,temp)//12位右对齐数游仔据格式设渣誉置DAC值

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12341263.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存