zoukankan      html  css  js  c++  java
  • [原创].怎样在Nios II上跑μC/OSII

    硬件:艾米电子EP2C8 FPGA-Nios开发板 板载8MB SDRAM和EPCS4

    软件:QII+NII SBTE 9.1 SP1

    一 硬件部分:构建SOPC平台

    1 新建QII工程及其他

    (1)新建QII工程

    图1 新建QII工程

    图1-1 新建QII工程

    (2)选择器件

    图2 选择器件

    图1-2 选择器件

    (3)其他设置

    图3 将不用管脚设置为三态输入

    图1-3 将不用管脚设置为三态输入

    图4 将AS配置芯片设置为EPCS4

    图1-4 将AS配置芯片设置为EPCS4

    2 构建Nios II软核

    (1)打开SOPC Builder,新建软核系统。

    图2-1 新建软核系统

    图2-1 新建软核系统

    由于我想将SDRAM跑到125MHz,那么先修改一下软核输入时钟的频率为125Mhz。

    图2-2 修改软核输入时钟频率

    图2-2 修改软核输入时钟频率

    (2)添加处理器及存储器

    配置SDRAM控制器。此处使用SDRAM的是三星的K4S641632K-UC60:64Mbit;16bit位宽;最大运行频率为166MHz ,CL=3。

    图2-3 配置SDRAM为16bit模式

    图2-3 配置SDRAM为16bit模式

    图2-3 配置SDRAM的CL=3

    图2-3 配置SDRAM的CL=3

    图2-4 配置处理器的复位向量和异常向量

    图2-4 配置处理器的复位向量和异常向量

    (3)添加Interval Timer核

    由于sys_clk_timer为μC/OS-II所必需,因此必须添加此核。

    图2-5 配置Interval Timer核

    图2-5 配置Interval Timer核

    (4)添加其他调试所需的核

    图2-6 添加其他调试所需的核

    图2-6 添加其他调试所需的核

    注:大家有没有注意到所有的组件后面都自动带一个编号,“_0”,挺难看的。其实不然,由于每一个组件都会被例化成一个HDL文件,而一个SOPC系统中可以构建多个Nios II软核或其他软核,如果不带编号的话,就会相互覆盖,以致于编译错误。当然,单核的时候,去掉也无妨。

    (5)自动分配基地址和中断号

    自动分配基地址和中断号

    图2-7 自动分配基地址和中断号

    (6)编译软核系统

    3 编译QII工程

    (1)配置锁相环

    输入50Mhz时钟;输出两个125Mhz时钟,其中一个相位滞后-3.5ns,作为SDRAM的时钟。由于要使用Verilog语言描述顶层模块。故在生成PLL的映射文件时候,需做如下选择。

    图3-1 选择输出例化模板文件和Verilog黑盒文件

    图3-1 选择输出例化模板文件和Verilog黑盒文件

    (2)编辑顶层模块

    新建一个Verilog文件,并命名为与工程名相同的名称。将 *_inst.v (sdram_pll_inst.v、nios_core_0_inst.v)中的代码复制进去。

    代码1 ucos_ii_test.v雏形

    sdram_pll    sdram_pll_inst (
        .inclk0 ( inclk0_sig ),
        .c0 ( c0_sig ),
        .c1 ( c1_sig )
    );
      
      
    //Example instantiation for system 'nios_core_0'
    nios_core_0 nios_core_0_inst
    (
      .clk_0                         (clk_0),
      .reset_n                       (reset_n),
      .zs_addr_from_the_sdram_0      (zs_addr_from_the_sdram_0),
      .zs_ba_from_the_sdram_0        (zs_ba_from_the_sdram_0),
      .zs_cas_n_from_the_sdram_0     (zs_cas_n_from_the_sdram_0),
      .zs_cke_from_the_sdram_0       (zs_cke_from_the_sdram_0),
      .zs_cs_n_from_the_sdram_0      (zs_cs_n_from_the_sdram_0),
      .zs_dq_to_and_from_the_sdram_0 (zs_dq_to_and_from_the_sdram_0),
      .zs_dqm_from_the_sdram_0       (zs_dqm_from_the_sdram_0),
      .zs_ras_n_from_the_sdram_0     (zs_ras_n_from_the_sdram_0),
      .zs_we_n_from_the_sdram_0      (zs_we_n_from_the_sdram_0)
    );

    有了这些模块的例化模板后,我们只要加上输入输出声明,以及略微改动即可。

    代码2 ucos_ii_test.v

    module ucos_ii_test(
      // CLOCK_
      input         CLOCK_50,
      // SDRAM
      output [11:0] SDRAM_ADDR,
      output [1:0]  SDRAM_BA,
      output        SDRAM_CAS_N,
      output        SDRAM_CLK,
      output        SDRAM_CKE,
      output        SDRAM_CS_N,
      inout  [15:0] SDRAM_DQ,
      output [1:0]  SDRAM_DQM,
      output        SDRAM_RAS_N,
      output        SDRAM_WE_N
    );  
    
    wire nios_core_clk;
    sdram_pll    sdram_pll_inst(
      .inclk0                 (CLOCK_50), 
      .c0                     (nios_core_clk), 
      .c1                     (SDRAM_CLK)
    );
    
    nios_core_0 nios_core_0_inst(
      //
      .clk_0                         (nios_core_clk),
      //
      .reset_n                       (1'b1),
      
      .zs_addr_from_the_sdram_0      (SDRAM_ADDR),
      .zs_ba_from_the_sdram_0        (SDRAM_BA),
      .zs_cas_n_from_the_sdram_0     (SDRAM_CAS_N),
      .zs_cke_from_the_sdram_0       (SDRAM_CKE),
      .zs_cs_n_from_the_sdram_0      (SDRAM_CS_N),
      .zs_dq_to_and_from_the_sdram_0 (SDRAM_DQ),
      .zs_dqm_from_the_sdram_0       (SDRAM_DQM),
      .zs_ras_n_from_the_sdram_0     (SDRAM_RAS_N),
      .zs_we_n_from_the_sdram_0      (SDRAM_WE_N)
    );
    
    endmodule

    编译之,生成的RTL视图。

    图3-2 该工程的RTL视图

    图3-2 该工程的RTL视图

    (3)分配管脚

    请参考:[原创].在Quartus II中分配管脚的两种常用方法.[Quartus II]

     

    二 软件部分

    1 使用模板创建软件工程

    图1-1 使用模板创建软件工程

    图1-1 使用模板创建软件工程

    图1-2 选择Hello MicroC/OS-II模板

    图1-2 选择Hello MicroC/OS-II模板

    2 编译软件工程

    图2-1 编译软件工程

    图2-1 编译软件工程

    3 运行工程

    图3-1 选择运行Nios II硬件

    图3-1 选择运行Nios II硬件

    图3-2 查看JTAG是否连接正确

    图3-2 查看JTAG是否连接正确

    运行之。

    4 查看运行结果

    image

    图4-1 模板的运行结果

    至此,一个可以运行的μC/OS-II的平台搭建完毕。想要深入研究μC/OS-II,只需增减相应的C代码即可。

    5 附录:模板代码

    #include <stdio.h>
    #include "includes.h"
    
    /* Definition of Task Stacks */
    #define   TASK_STACKSIZE       2048
    OS_STK    task1_stk[TASK_STACKSIZE];
    OS_STK    task2_stk[TASK_STACKSIZE];
    
    /* Definition of Task Priorities */
    
    #define TASK1_PRIORITY      1
    #define TASK2_PRIORITY      2
    
    /* Prints "Hello World" and sleeps for three seconds */
    void task1(void* pdata)
    {
      while (1)
      { 
        printf("Hello from task1\n");
        OSTimeDlyHMSM(0, 0, 3, 0);
      }
    }
    /* Prints "Hello World" and sleeps for three seconds */
    void task2(void* pdata)
    {
      while (1)
      { 
        printf("Hello from task2\n");
        OSTimeDlyHMSM(0, 0, 3, 0);
      }
    }
    /* The main function creates two task and starts multi-tasking */
    int main(void)
    {
      
      OSTaskCreateExt(task1,
                      NULL,
                      (void *)&task1_stk[TASK_STACKSIZE-1],
                      TASK1_PRIORITY,
                      TASK1_PRIORITY,
                      task1_stk,
                      TASK_STACKSIZE,
                      NULL,
                      0);
                  
                   
      OSTaskCreateExt(task2,
                      NULL,
                      (void *)&task2_stk[TASK_STACKSIZE-1],
                      TASK2_PRIORITY,
                      TASK2_PRIORITY,
                      task2_stk,
                      TASK_STACKSIZE,
                      NULL,
                      0);
      OSStart();
      return 0;
    }

    三 一些说明

    注意:sys_clk_timer是运行μC/OS-II所必需的组件。PLL为什么不加延时复位模块?我猜测Cyclone II的PLL初始化已经很快了;不需要过多延时,就可输出稳定的时钟源;但也不确定是否如此,以后再研究。

    此外,使用HDL来描述顶层文件,比原理图描述方便了许多;推荐大家使用HDL。

    四 参考

    1 Altera.Hello MicroC/OS-II

    2 Altera.Using the MicroC/OS-II RTOS with the Nios II Processor Tutorial

    3 Altera. MicroC/OS-II Real Time Operating System

    4 [原创].在Quartus II中分配管脚的两种常用方法.[Quartus II]

  • 相关阅读:
    【前端优化之渲染优化】大屏android手机动画丢帧的背后
    ES6/ES2015核心内容(上)
    ES6/ES2015核心内容(上)
    ES6/ES2015核心内容(上)
    ES6/ES2015核心内容(上)
    Java实现zip文件解压[到指定目录]
    Java实现zip文件解压[到指定目录]
    Java实现zip文件解压[到指定目录]
    Java实现zip文件解压[到指定目录]
    spring boot项目中处理Schedule定时任务
  • 原文地址:https://www.cnblogs.com/yuphone/p/1729752.html
Copyright © 2011-2022 走看看