zynq开发学习记录:Linux与FreeRTOS AMP运行

  • Linux + FreeRTOS

1.创建FreeRTOS工程

  • 使用ps7_cortexa9_1创建FreeRTOS工程,示例如下

  • 修改main.c 去掉xil_printf相关的调用,根据FPGA工程师提供的寄存器地址和bit文件操作LED周期闪烁
  • 修改lscript.ld文件地址(不要和cpu0使用地址冲突)

  • 打开board support package setting界面,添加 -DUSE_AMP=1 宏

  • 打开board support package setting界面,去除stdin及stdout配置为none

  • 修改FreeRTOS  bsp工程中中的boot.s文件,注释地址映射部分(Vivado 2016无需此步骤)。如下图所示:

  • 编译生成FreeRTOS可执行文件

2.修改Linux相关文件

  • U-boot、Linux设备树修改
memory {

device_type = "memory";

reg = <0x0 0x30000000>;

};/*修改CPU0地址空间范围*/
  • Linux内核启动参数,修改设置为SMP,CPU个数为1

            bootargs "console=ttyPS0,115200 maxcpus=1 root=/dev/ram rw earlyprintk "

  • 编译u-boot、内核

3.创建fsbl工程

  • 在ps7_cortexa9_0上创建普通fsbl工程
  • 在main.c中,main函数前添加如下函数定义
#define sev() __asm__("sev")

#define CPU1STARTADR 0xfffffff0

void LoadCpu1(void)

{

#if 1



    *(volatile unsigned int *)0x2F000000 = 0x12345678;

    *(volatile unsigned int *)0x2F000010 = 0x87654321;

    *(volatile unsigned int *)0x3F000000 = 0x19890314;

    *(volatile unsigned int *)0x3F000010 = 0x20170427;

    fsbl_printf(DEBUG_GENERAL,"FSBL: DDR Test:%x,%x,%x,%x\n\r",*(volatile unsigned int *)0x2F000000,*(volatile unsigned int *)0x2F000010,*(volatile unsigned int *)0x3F000000,*(volatile unsigned int *)0x3F000010);



    fsbl_printf(DEBUG_GENERAL,"FSBL: writing startaddress for cpu1\n\r");

    Xil_Out32(CPU1STARTADR, 0x30000000);

    dmb(); //waits until write has finished



    fsbl_printf(DEBUG_GENERAL,"FSBL: sending the SEV to wake up CPU1\n\r");

    sev();



#endif

}
  • 在main函数中,如下位置添加函数调用

 

  /*

     * Load boot image

     */

    HandoffAddress = LoadBootImage();



    fsbl_printf(DEBUG_INFO,"Handoff Address: 0x%08lx\r\n",HandoffAddress);

    LoadCpu1();
  • 编译生成fsbl.elf
  • 创建BOOT.bin运行
    • 利用SDK创建BOOT.bin文件,文件顺序为fsbl.elf、zynq.bit(FPGA工程师提供)、u-boot.elf以及freeRtos.elf。
    • 将生成的BOOT.bin放进SD卡,启动模式修改为SD启动。

       上电后可以观察到:

             CPU0 终端串口上 Linux启动正常

             CPU1 测试LED一直在闪烁

  • 2
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值