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

本文介绍了如何通过位操作检测8位数据的最高位,阐述了内存地址的理解,将其比喻为房子的门牌号,强调寻址在内存操作中的重要性。此外,讲解了在Zynq系统中,利用FPGA实现硬件加速,通过PS-PL互联将OLED的读写功能转移到FPGA,以减少指令周期,提高系统性能。
摘要由CSDN通过智能技术生成

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_O
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值