1. pl端的encoder模块实现了可选的外部复位信号 2. pl端修改encoder模块的ENCODER_CR寄存器复位值,为仅限内部复位以及内部默认处于复位状态 3. 驱动层实现外部复位的开启和关闭功能,驱动open时退出默认的复位清零状态 由于驱动程序已在open时退出复位状态,应用程序可不做更改,驱动程序close后不会自动切换回复位状态 4. 更新了驱动测试应用程序
74 lines
6.0 KiB
Markdown
74 lines
6.0 KiB
Markdown
# 硬件平台
|
||
|
||
PL端主要由4个外设组成,分别时**风扇控制器**(FAN),**编码和分频控制器**(ENCODER),**先入先出队列**(FIFO),**阀板控制器**(VALVE)。其中阀板控制器没有提供AXI接口,因此并没有映射寄存器,软件也无法进行控制。各个控制器的连接关系如下图所示。
|
||
|
||

|
||
|
||
由于开发板的PL端没有自带晶振,所以4个外设由统一的同步时钟驱动,时钟源来自PS端,为200MHz,软件不可修改。外部编码器信号输入**编码和分频控制器**,控制器根据软件设置的阀触发分频值和相机触发分频值对编码器信号进行分频,分频后的信号用于驱动喷阀动作和触发相机拍照。上位机的识别结果存储到**先入先出队列**中。
|
||
|
||
为同步触发相机和队列移出信号以及保持队列中数据的动态平衡,两个先入先出队列在相机触发同时输出一个数据,即**先入先出队列**的读信号和相机触发共用同一个信号。而由于电磁阀的物理特性导致电磁阀可能无法以触发相机的频率进行开关,因此**阀板控制器**对先入先出队列输出总线上的数据重采样,即按照**编码和分频控制器**输出的阀触发信号读入。两个先入先出队列移出的数据在**阀板控制器**中进行按位或运算,得到的数据转换为阀板协议,输出给阀板。**风扇控制器**用于驱动风扇的启停,给ZYNQ芯片进行降温,防止芯片过热导致工作中出现问题。由于风扇寿命短,因此目前采用散热片方案,风扇不开。
|
||
|
||
## PS模块
|
||
|
||
下面列出需要开启的外设和采用的IO口,BANK0为LVCMOS3.3V,BANK1为LVCOMS1.8V
|
||
|
||
| 外设 | IO | 备注 |
|
||
| --------------------------------------------------- | ---------------------- | -------------------------------------- |
|
||
| Quad SPI Flash | 1~6 | Single SS 4bit IO,Fast , ss_b pullup |
|
||
| Ethernet 0<br />MDIO | 16~27<br /> 52~53 | Fast, all pullup |
|
||
| USB0 | 28~39 | Fast, all pullup |
|
||
| SD0 | 40~45 | Fast, all pullup |
|
||
| SD1 | 46~51 | Fast, all pullup |
|
||
| UART0 | 14~15 | all pullup, baud 115200, 8bits, 1 stop |
|
||
| TTC0 | EMIO | |
|
||
| GPIO MIO<br />Ethernet PHY Reset<br />USB PHY Reset | 所有剩下的<br/>7<br/>8 | Fast, all pullup |
|
||
|
||
时钟配置上,ARM为666.66MHz,DDR为533.33MHz,用IOPLL给PL端提供200MHz的FCLK_CLK0。
|
||
|
||
如果用的是7010的板子,内存选忽略下面这一段:内存配置上,选择DDR3,数据位宽32bit=16bit/chip \* 2chip, 4096Mbits/chip,频率533.33,速度等级为1066F,行/列/Bank地址宽度为15/10/3,CL=7,CWL=6,RCD=7,RP=7,RC=51ns,FAW=40ns
|
||
|
||
ARM核上还开启AXI GP0接口与PL通信
|
||
|
||
## ENCODER模块
|
||
|
||
encoder模块主要接口为in_signal、out_signal_camera_a_posedge、out_signal_camera_b_posedge、out_signal_camera_c_posedge、out_signal_camera_d_posedge、out_signal_valve_posedge、out_signal_camera_a、out_signal_camera_b、out_signal_camera_c、out_signal_camera_d、out_signal_valve、exrst_n
|
||
|
||
终于,我们重新实现了被老倪乱起八糟的需求搞的几乎奔溃的模块,现在这个模块已经比较简洁了
|
||
|
||
1. in_signal接口与外部编码器相连,接收外部编码器信号
|
||
2. out_signal_camera_a到d最多课用于触发共4个相机
|
||
3. out_signal_camera_posedge_a到d为上述信号的上升沿,其中out_signal_camera_posedge_a控制FIFO的读出
|
||
4. out_signal_valve_posedge为out_signal_valve的上升沿,驱动**阀板控制器**动作
|
||
5. exrst_n为可选的外部复位清零信号,可用于连接物体传感器,根据需要屏蔽相机触发输出
|
||
|
||
|
||
ENCODER模块输入输出频率的详细计算方式和寄存器说明见[doc/pl_reference_mannual.md](pl_reference_mannual.md)中的ENCODER控制器部分
|
||
|
||
## FIFO模块
|
||
|
||
FIFO模块的主要接口为rd_en、dout[383:0]、empty、full、almost_full、almost_empty、data_count[11:0]、fifo_valid
|
||
|
||
1. rd_en接收ENCODER模块传来的信号,控制模块内部FIFO按ENCODER模块所需频率进行读取和输出
|
||
2. dout[383:0]为FIFO中读出数据,数据位宽为384bit
|
||
3. empty信号为1表示fifo中数据已经为空,无法输出有效数据,但输出寄存器仍然保持上次输出的值
|
||
|
||
FIFO模块寄存器说明见[doc/pl_reference_mannual.md](pl_reference_mannual.md)中的FIFO控制器部分
|
||
|
||
## FAN模块
|
||
|
||
fan模块接口fan输出为PWM波形,连接到外部的风扇驱动电路。
|
||
|
||
fan模块寄存器说明见[doc/pl_reference_mannual.md](pl_reference_mannual.md)中的FAN控制器部分
|
||
|
||
> Note:fan模块代码中设计了PWM调速功能,对于带程序的交流风扇,无法观察到调速现象。但正常的启停可以做到
|
||
|
||
## VALVE_INTERFACES模块
|
||
|
||
VALVE_INTERFACES模块的主要接口为total_valve_data[383:0]、empty、valve_en、sclk[7:0]、sen[7:0]、sdata[7:0]。VALVE_INTERFACES会将total_valve_data_a和total_valve_data_b两路数据进行或运算,得到同为384位的单路数据。
|
||
|
||
1. total_valve_data接收FIFO模块中读出的数据。
|
||
|
||
2. empty信号与两个FIFO模块的empty信号相连。检测到任意一个empty信号为高时,无论输入数据如何,只按协议输出全关给阀板。
|
||
3. valve_en信号上升沿将total_valve_data按协议发送给阀板
|
||
4. sclk[7:0]、sen[7:0]、sdata[7:0]连接到外部差分芯片,为最多8块阀板的时钟信号线、使能信号线以及数据信号线
|