2019.06.16 Zynq学习【PS与PL互联2】

1.如果要判断一个8位数据第一位是不是1,可以用如下方式:

if(data&0x80)。除1以外任何数与0相与都是0,因此能检测出data最高位是不是1。若要检测次高位,则if(data&0x40)。因为0x40=0b01000000。

2.内存地址的理解:在SDK中,通常都是对内存地址进行操作,而不是直接对内存中的数据进行操作。如果把内存空间比喻成房子,那内存地址就是门牌号,内存空间中的数据就是房子里的人,如果要找某个人,肯定得先知道他的门牌号,才能定位到他的房子,这个过程就叫寻址。另外,内存一般都是以字节(Byte)为单位。比如:#define OLED_BASE_ADDR 0X43C00000,意为用OLED_BASE_ADDR来表示OLED驱动的基地址:0X43C00000。它的地址范围:0000-FFFF一共64KB(2^16个字节)。也就是说,CPU为OLED一共分配了64KB大小的内存空间。

3.硬件加速:原本对OLED进行读写是在PS中

void write_data(u8 data)
{	u8 i;

	Set_OLED_DC;		//将OLED_BASE_ADDR置1,表示进行数据和命令的传输。

	for(i=0;i<8;i++)	//
	{
		Clr_OLED_SCLK;//清除OLED的时钟,不让其工作

		if(data&0x80)	//判断data最高位是否为1,若是,则将OLED_SDIN位置1,表示开始写入数据,否则置0,不能写入数据
			Set_OLED_SDIN;
		else
			Clr_OLED_SDIN;
		Set_OLED_SCLK;	//开始让OLED_SCLK工作
		data<<=1;	//等效于data=data<<1;让data的次高位变成最高位来进行下一次if判断输出。
//data的8位数据经由上面的if判断和8次for循环输出到OLED_BASE_ADDR前4个字节的第OLED_SDIN(2)位。
//因为PL端的AXI4核的寄存器是32位的,即4个字节。对应0x43c00000-0x43c00003这4个字节。
//此位对应到PL端的AXI4的IP核中的第一个寄存器的第2位。PL端将次高位作为output port输出到板子上
//的外设:OLED模块的OLED_SDIN引脚。
	}
}

但PS端需要用到很多条指令,指令周期也比较长。但FPGA没有指令周期这一概念。因此可以将数据和命令读写功能用FPGA实现,从而达到硬件加速的目的。只需要在PS端把数据赋给寄存器所对应的地址即可,至于输出这些数据就由FPGA来完成,无需再用PS的for循环等指令。这样既可以减少运行时间,又能充分利用PL资源。达到了用面积换时间的目的。

 

你可能感兴趣的:(Xilinx,Zynq学习)