void AD9959_Set_Fre(uint8_t Channel,uint32_t Freq) { uint8_t CHANNEL[1] = {0x00}; CHANNEL[0]=Channel; AD9959_WriteData(CSR_ADD,1,CHANNEL);//¿ØÖƼĴæÆ÷дÈëCHnͨµÀ£¬Ñ¡ÔñCHn Write_CFTW0(Freq);//Êä³öCHnÉ趨ƵÂÊ }
时间: 2024-04-24 08:21:25 浏览: 106
根据你提供的代码,这是一个名为`AD9959_Set_Fre`的函数,用于设置AD9959芯片的频率。函数接受两个参数,`Channel`表示通道号,`Freq`表示要设置的频率。
在函数中,首先定义了一个名为`CHANNEL`的数组,并将传入的`Channel`赋值给数组的第一个元素。然后调用了`AD9959_WriteData`函数,将通道号写入了AD9959芯片的CSR寄存器中,以选择要操作的通道。最后,调用了`Write_CFTW0`函数,将传入的频率设置到对应通道的CFTW0寄存器中,以设置输出频率。
如果你遇到了问题或者需要进一步的帮助,请提供更多的上下文信息或者具体的错误描述。
相关问题
always@(posedge sys_clk or negedge sys_rst_n) if(sys_rst_n == 1'b0) fre_add <= 32'd0; else fre_add <= fre_add + FREQ_CTRL; //rom_addr:ROM读地址 always@(posedge sys_clk or negedge sys_rst_n) if(sys_rst_n == 1'b0) begin rom_addr <= 14'd0; rom_addr_reg <= 11'd0; end else case(wave_select) sin_wave: begin rom_addr_reg <= fre_add[31:20] + PHASE_CTRL; rom_addr <= rom_addr_reg; end //正弦波 squ_wave: begin rom_addr_reg <= fre_add[31:20] + PHASE_CTRL; rom_addr <= rom_addr_reg + 14'd4096; end //方波 tri_wave: begin rom_addr_reg <= fre_add[31:20] + PHASE_CTRL; rom_addr <= rom_addr_reg + 14'd8192; end //三角波 saw_wave: begin rom_addr_reg <= fre_add[31:20] + PHASE_CTRL; rom_addr <= rom_addr_reg + 14'd12288; end //锯齿波 default: begin rom_addr_reg <= fre_add[31:20] + PHASE_CTRL; rom_addr <= rom_addr_reg; end //正弦波 endcase
这段代码是一个 Verilog 的模块,它定义了一个时钟和复位信号,以及一些参数。这个模块的功能是根据不同的波形选择,从一个 ROM 中读取数据,并且根据频率和相位控制,生成不同的波形信号。其中,FREQ_CTRL 和 PHASE_CTRL 是控制频率和相位的参数,wave_select 是波形选择信号,sin_wave、squ_wave、tri_wave 和 saw_wave 分别对应正弦波、方波、三角波和锯齿波。ROM 的读地址 rom_addr 是根据不同的波形选择和频率相位控制计算得到的。这段代码实现了一个基本的波形生成器。
void PowerON() { if(!statepower) { C_Power_ON(); DelayMs(200); led_7p7s_init(); Reload(); if(KEY_Turn_channel) { FREQData = BUFF/100; } else { FREQData = BUFF2/100; } led_7p7s_disp_CHorVOL(); fSYSON = 1; Pair_Flag=0; KEY_count = 0; OPEN_flag = 1; while(!KEY_ONOFF) { if(KEY_count >= 4300) { Pair_Flag=1; break; } } KEY_count = 0; OPEN_flag = 0; C_Power_ON(); DelayMs(500); CE = 1; InitALL(); while(!KEY_ONOFF) { if(Pair_Flag) { led_7p7s_disp_CHorVOL(); DelayMs(350); led_7p7s_clear(); DelayMs(350); } } while(Pair_Flag) { led_7p7s_disp_CHorVOL(); DelayMs(350); if(!KEY_ONOFF) { Pair_Flag = 0; KT_WirelessMicTx_PowerDownProcedure(); DelayMs(100); InitALL(); break; } led_7p7s_clear(); DelayMs(350); if(!KEY_ONOFF) { Pair_Flag = 0; KT_WirelessMicTx_PowerDownProcedure(); DelayMs(100); InitALL(); break; } } while(!KEY_ONOFF); Pair_Flag = 0; statepower = 1; OPEN_flag = 1; Clear_Fre_flag = 1; Clear_Fre_count = 0; ID_change_count = 0; ID_change_flag = 0; Fre_change_count = 0; Fre_change_flag = 0; } }
这段代码是一个函数,名为PowerON,用于开启设备。函数体中的代码依次完成以下操作:
1. 判断设备是否已经处于开启状态,如果未开启则执行以下操作:
2. 执行C_Power_ON函数,开启电源;
3. 延时200毫秒;
4. 初始化7段LED数码管;
5. 调用Reload函数;
6. 根据KEY_Turn_channel变量的值确定频率数据;
7. 在7段LED数码管上显示当前频率或通道号;
8. 设置fSYSON标志位为1,表示设备已经开启;
9. 清空配对标志Pair_Flag;
10. 将KEY_count计数器清零;
11. 设置OPEN_flag为1;
12. 在while循环中,如果KEY_ONOFF标志位为0且KEY_count计数器小于4300,则继续等待;
13. 如果KEY_count计数器超过4300,则设置配对标志Pair_Flag为1,并跳出while循环;
14. 将KEY_count计数器清零;
15. 设置OPEN_flag为0;
16. 再次执行C_Power_ON函数,开启电源;
17. 延时500毫秒;
18. 将CE引脚设置为1;
19. 执行InitALL函数;
20. 在while循环中,如果KEY_ONOFF标志位为0且Pair_Flag标志位为1,则在7段LED数码管上显示当前频率或通道号;
21. 如果Pair_Flag标志位为1,则在7段LED数码管上显示当前频率或通道号,并进行闪烁;
22. 如果KEY_ONOFF标志位为0,则设置Pair_Flag标志位为0,关闭无线麦克风,并执行InitALL函数;
23. 在while循环中,如果Pair_Flag标志位为1,则在7段LED数码管上显示当前频率或通道号,并进行闪烁;
24. 如果KEY_ONOFF标志位为0,则设置Pair_Flag标志位为0,关闭无线麦克风,并执行InitALL函数;
25. 在while循环中,如果KEY_ONOFF标志位为0,则继续等待;
26. 将Pair_Flag标志位设置为0;
27. 将statepower标志位设置为1,表示设备已经开启;
28. 设置OPEN_flag为1;
29. 设置Clear_Fre_flag标志位为1;
30. 将Clear_Fre_count计数器清零;
31. 将ID_change_count计数器清零;
32. 将ID_change_flag标志位清零;
33. 将Fre_change_count计数器清零;
34. 将Fre_change_flag标志位清零;
总之,这段代码是对设备开启过程中的状态和标志位进行了一系列的初始化和设置,包括开启电源、初始化数码管、设置频率、配对等。
阅读全文