|
analog 中对 ADC 的剪裁目前的 analog 样例中,支持 3 个 ADC(每个 16 路)和 2 个 DAC,1 个比较器 CMP(2 路)。 该 analog 在 cpld 中编译后,总大小大概 1.4K 个逻辑单元。 如果用户需要更多的 cpld 空间,并且只用了 adc 通道,可以对 analog 进行剪裁。 实测下来,如果只用 1 个 ADC,且只用 6 路,剪裁后大概只占 500 个逻辑单元。 (详细的测试数据,请参考文末附录) 举例:剪裁为只有 1 个 ADC,只有 6 路。 剪裁方法: 1. 在 analog_ip.v 修改 adc 个数: 修改 parameter PER_CNT = 6 为:parameter PER_CNT = 1 从代码中可以看出,PER_CNT 原先为 6,就是 3 个 adc + 2 个 dac + 1 个 cmp。 如果只需要 1 路 ADC,则该值改为 1 即可。 改为 1 后,后续的 for 循环实例化 adc/dac/cmp 时,将只实例化一个 ADC。 【实例化循环:for (i = 0; i < PER_CNT; i = i + 1)】 修改后,再次编译时,会出错。对出错点进行修改: 把 assign ext_dma_DMACBREQ = dma_req[3:0] | (dma_req[4] << 2) 修改为: assign ext_dma_DMACBREQ = dma_req[0] 原因是,修改后只有 1 路,而不再是 5 路。 此时,直接点【编译】按钮编译时,由于缓存没有清除,仍然会有报错。 这时可以重跑一次【tool】->【Tcl Scripts...】->弹出框中选 af_quartus.tcl 再点下边【Run】。 跑完后编译成功。可以看到逻辑单元变成 588 个。 2. 在 analog_ip.v 修改 adc 的 channal 数: 修改 parameter SEQ_MAX = 16 为 parameter SEQ_MAX = 6 在代码中,SEQ_MAX 表示 ADC 的最大通路数。 修改完后,重新编译。成功后看到逻辑单元变成 501 个。 注意,这样裁剪后,在 mcu 中就只能使用 1 个 ADC 裁剪出 DAC 或 CMP: 方式同上。 需要修改的点,就是 for 循环实例化时,按自己的需求产生出来 ADC/DAC/CMP 即可。 (裁剪后,不需要的代码可以注掉,减少编程时的干扰) ---------------------------------------------------------------------------------------------------------- 附录: ADC/DAC/CMP 各种情况下使用的逻辑单元数: 空模板工程:219 //注:空模板工程为支撑 mcu 运行的最简 cpld 工程 开 ADC0 1 路:438 //指在空模板工程上只开一个 ADC 的 1 路 开 ADC0 6 路:515 开 ADC0 11 路:544 开 ADC0 16 路:584 开 ADC0+ADC1 各 16 路:890 开 ADC0+ADC1+ADC2 各 16 路:1184 开 ADC0+ADC1+ADC2+1 个 DAC: 1306 开 ADC0+ADC1+ADC2+2 个 DAC: 1322 开 ADC0+ADC1+ADC2+2 个 DAC+1 个 CMP: 1362 开 ADC0+ADC1+ADC2+2 个 DAC+1 个 CMP(开 DMA):1404 开 ADC0(16 路)+1 个 CMP:617 开 ADC0(7 路)+1 个 CMP:528 开 ADC0(7 路)+1 个 CMP(开 DMA):536 由以上结果大致可推出: 1. 空模板工程需要 219 个 LE; 2. ADC 占用资源不是线性增加的(开第一路是占用的比较多,约 220 个 LE,后边新增一路 占用不多,约 8 个 LE); 3. DAC 占用资源也不是线性增加的(开第一个占用 122 个 LE,开第二个占用 16 个 LE) 4. CMP 占用逻辑单元大概 40 个; 组合不同,可能会有一些出入,但数量级应该就是这个数量级。 需要获取更多的“资料”和“支持”和“样片测样申请”可以联系我们 提供“芯片测样-发送资料-技术支持-批量采购” 联系方式: 姚工 13661545024(VX同号) (加的时候备注下公司名和个人名字) 在线商城:agm-micro.taobao.com 公司网站:www.agm-micro.com 资料网站: www.tcx-micro.com |