xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)

分享产品试用报告,测试板卡是基于Xilinx Zynq-7000系列XC7Z010/XC7Z020高性能低功耗处理器设计的异构多核SoC工业级核心板。

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(1)

以下为测评内容,欢迎阅读:

Petalinux制作linux系统1配置

基本配置信息如下:

(1) 配置启动项

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(2)

(2) 配置SD卡分区

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(3)

(3) 首选SD启动设置

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(4)

(4) 主机名设定

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(5)

2文件系统配置

主要包括如下:

(1) gcc编译支持

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(6)

(2) python支持

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(7)

3 设备树

另一个一个最重要的就是编写设备树文件,主要包括LED以及按键的设备树和axi_uart16550设备树文件的编写,内容如下:

/include/ "system-conf.dtsi"

/ {

aliases{

ethernet0= &gem0;

serial0= &uart1;

};

gpio-keys{

compatible = "gpio-keys";

#gpio-cells = <2>;

SW0 {

label= "SW0";

#gpio-cells= <2>;

gpios= <&axi_gpio_1 0x0 0x0 0x0>;

linux,code= <108>;

gpio-key,wakeup;

autorepeat;

};

SW1 {

label= "SW1";

#gpio-cells= <2>;

gpios= <&axi_gpio_1 0x1 0x0 0x0>;

linux,code= <108>;

gpio-key,wakeup;

autorepeat;

};

SW2 {

label= "SW2";

#gpio-cells= <2>;

gpios= <&axi_gpio_1 0x2 0x0 0x0>;

linux,code= <108>;

gpio-key,wakeup;

autorepeat;

};

};

gpio-leds{

compatible= "gpio-leds";

#gpio-cells= <2>;

led-ld0{

label= "led-ld0";

#gpio-cells= <2>;

gpios= <&axi_gpio_0 0x0 0 0x0>;

default-state= "on";

linux,default-trigger= "default-on";

};

led-ld1{

label= "led-ld1";

#gpio-cells= <2>;

gpios= <&axi_gpio_0 0x1 0 0x0>;

default-state= "on";

linux,default-trigger= "default-on";

};

led-ld2{

label= "led-ld2";

#gpio-cells= <2>;

gpios= <&axi_gpio_0 0x2 0 0x0>;

default-state= "on";

linux,default-trigger= "default-on";

};

};

};

&axi_uart16550_0 {

status= "okay";

port-number= <1>;

current-speed= <57600>;

xlnx,use-modem-ports= <0x0>;

xlnx,use-user-ports= <0x0>;

};

&axi_uart16550_1 {

status= "okay";

port-number= <1>;

current-speed= <57600>;

xlnx,use-modem-ports= <0x0>;

xlnx,use-user-ports= <0x0>;

};

实验

启动界面如下:

Boot

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(8)

Kernel

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(9)

登录

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(10)

从上述界面可知,linux系统启动成功,输入密码和账户名即可。

1查看各项驱动

(1) gpio驱动

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(11)

(2) uart 16550驱动

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(12)

从上述信息可知成功启动了相应驱动。

2 MIO LED实验

该实验的LED实验情况如下:

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(13)

实验现象如下:

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(14)

代码如下:

#include <stdio.h>

#include <fcntl.h>

#include <stdlib.h>

#include <unistd.h>

int main()

{

int value;

int export;

int direction;

//export GPIO controller

export = open("/sys/class/gpio/export", O_WRONLY);

if(export < 0)

{

printf("Cannot open GPIO controller export\n");

exit(1);

}

write(export, "909", 4);

close(export);

printf("GPIO controller export successfully\n");

//Modify GPIO controller direction

direction = open("/sys/class/gpio/gpio909/direction",O_WRONLY);

if(direction < 0)

{

printf("Cannot open GPIO controller direction\n");

exit(1);

}

write(direction, "out", 4);

close(direction);

printf("GPIO controller direction changed to outputsuccessfully\n");

// Modify GPIO controller value

value = open("/sys/class/gpio/gpio909/value", O_RDWR);

if(value < 0)

{

printf("Cannot open GPIO controller value\n");

exit(1);

}

//Swap GPIO control value each 1 second

while (1)

{

sleep(1);

write(value,"1", 2);

printf("GPIO controller value changed to 1 successfully\n");

sleep(1);

write(value,"0", 2);

printf("GPIO controller value changed to 0 successfully\n");

}

}

3 axi gpio led实验

该实验情况如下:

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(15)

实验如下:

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(16)

代码如下:

#include <stdio.h>

#include <fcntl.h>

#include <stdlib.h>

#include <unistd.h>

int main()

{

int led0;

int led1;

int led2;

//export GPIO controller

led0 = open("/sys/class/leds/led-ld0/brightness", O_WRONLY);

led1 = open("/sys/class/leds/led-ld1/brightness", O_WRONLY);

led2 = open("/sys/class/leds/led-ld2/brightness", O_WRONLY);

if(led0 < 0 | led1 < 0 | led2 < 0)

{

printf("Cannot open GPIO controller export\n");

exit(1);

}

write(led0,"0", 2);

write(led1,"0", 2);

write(led2,"0", 2);

//Swap GPIO control value each 1 second

while (1)

{

sleep(1);

write(led0,"255", 4);

sleep(1);

write(led1,"255", 4);

sleep(1);

write(led2,"255", 4);

printf("GPIO controller value changed to 1 successfully\n");

sleep(1);

write(led0,"0", 2);

sleep(1);

write(led1,"0", 2);

sleep(1);

write(led2,"0", 2);

printf("GPIO controller value changed to 0 successfully\n");

}

}

4 uart16550实验

根据上述信息可知,串口的驱动字符名为ttyS1和ttyS2,因此实验现象如下:

xilinx fpga发展路线图(XilinxXC7Z020双核ARMFPGA开发板试用合集)(17)

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页