zoukankan      html  css  js  c++  java
  • SOPC与 hello world

     本次设计实验源码位于:http://download.csdn.net/detail/noticeable/9922865

    实验目的:通过系统的搭建进一步了解FPGA的SOPC开发流程,并借此了姐pll IP核的应用以及用DE-SOC自带的SDRAM缓存输出数据,并为后面的工程实施提供基础。

    实验现象:uart接口连接串口调试助手显示hellowold

    实验步骤:

    新建sopc_lesson1工程:

    并新建一个sopc_lesson1.v文件

    通过打开qsys工具,修改clk_0的默认时钟

     添加NIOS processor内核,且暂时不进行修改,直接finish即可。

     添加存储器,由于DE-SOC开发板FPGA部分板载一块64M的SDRAM,所以这里添加SDRAM

    这里的设置是按照开发板上实际的芯片参数设置的,详细操作看芯片手册,芯片手册下载地址:http://download.csdn.net/detail/noticeable/9922132

    由芯片手册有

    配置结果如下

    timing部分的时序约束部分先不改,后面在专门运用SDRAM时再详细说明。

    添加uart调试接口

     uart设置如下

    基本功能设置完成后,之后即为一些与开发板相关的外设的添加:

    添加pio_led的IO口

     

    添加pio_key的IO口

    下面即是进行总线的连接

    首先即是clk、控制总线和数据总线的连接

     配置rst

     将中断连接到CPU

    指定中断向量

    分配基地址

    将引脚导出

    导出后发现还有一个警告,发现是uart 的s1未连接到 instruction_master上,连接上即可

    连接完成后的总体连接图

    将系统保存,然后点击generate->show instantiation自动生成template

    然后将template复制下后,粘贴到之前生成的sopc_lesson.v文件中

    最后点击generate hdl 文件

    至此,设计需要的nios II软件核即设计完成了,在quartus II中将cpu.qsys文件添加到文件夹即可。

     添加锁相环IP核对时钟进行倍频和移相

    下面,对sopc_lesson1.v文件进行编写

    module sopc_lesson1 (
            input  wire        clk_50m,        //     clk.clk
            input  wire [2:0]  pio_key_export, // pio_key.export
            output wire [9:0]  pio_led_export, // pio_led.export
            input  wire        reset_reset_n,  //   reset.reset_n
            output wire        sdram_clk,             //这里自己添加一个SDRAM_CLK
            output wire [12:0] sdram_addr,     //   sdram.addr
            output wire [1:0]  sdram_ba,       //        .ba
            output wire        sdram_cas_n,    //        .cas_n
            output wire        sdram_cke,      //        .cke
            output wire        sdram_cs_n,     //        .cs_n
            inout  wire [15:0] sdram_dq,       //        .dq
            output wire [1:0]  sdram_dqm,      //        .dqm
            output wire        sdram_ras_n,    //        .ras_n
            output wire        sdram_we_n,     //        .we_n
            input  wire        uart_0_rxd,     //  uart_0.rxd
            output wire        uart_0_txd      //        .txd
        );
        //这一块可以直接ctrl+o打开H:SOPCcpusynthesis路径下的cpu.v文件复制粘贴
            wire nios_clk;
            wire nios_reset_n;
        pll pll(
            .refclk(clk_50m),   //  refclk.clk
            .rst(~reset_reset_n),      //   reset.reset
            . outclk_0(nios_clk), // outclk0.clk
            . outclk_1(sdram_clk), // outclk1.clk
            .  locked(nios_reset_n)    //  locked.export
        );
    
        cpu u0 (
            .clk_clk                        (nios_clk),        //     clk.clk
            .pio_key_export             (pio_key_export), // pio_key.export
            .pio_led_export             (pio_led_export), // pio_led.export
            .reset_reset_n                (nios_reset_n),  //   reset.reset_n
            .sdram_addr                   (sdram_addr),     //   sdram.addr
            .sdram_ba                     (sdram_ba),       //        .ba
            .sdram_cas_n                 (sdram_cas_n),    //        .cas_n
            .sdram_cke                   (sdram_cke),      //        .cke
            .sdram_cs_n                  (sdram_cs_n),     //        .cs_n
            .sdram_dq                     (sdram_dq),       //        .dq
            .sdram_dqm                  (sdram_dqm),      //        .dqm
            .sdram_ras_n                (sdram_ras_n),    //        .ras_n
            .sdram_we_n                (sdram_we_n),     //        .we_n
            .uart_0_rxd                    (uart_0_rxd),     //  uart_0.rxd
            .uart_0_txd                   (uart_0_txd)      //        .txd
        );
        
         
    endmodule 

    分配引脚:

     

    到这里,整个板载部分逻辑设计及nios相关的设计就完成了,下面即是编写EDS文件然后进行仿真。

    编写EDS工程:

    打开tool->NIOS II Software Build Tools for eclipse 并将workspace设定到自己本次工程的目录下

    选则创建模板和bsp工程

     

     对nios_bsp进行设置

    发现其已经默认设置好了uart_0为输出,默认即可,所以退出。

    编译整个工程

     烧写.sof文件

    设置关连文件,将hello与bsp关联起来

    烧写.elf文件

    选择project

    执行下面这步,点击运行

     至此程序烧写完成。

     

    实验现象:

    将USB-TTL按照GND->GND

            TXD->GPIOD0

            TXD->GPIOD1

     串口调试助手波特率设为9600

     .sof文件烧写进开发板时,led灯全亮,按复位键串口调试没有数据接收,

    将.elf文件烧写到FPGA后,按下KEY0,串口调试助手接收到信息如图

    最后对hello_world.c进行如下编程,完成对I/O和基本函数的调用

    /*
     * "Hello World" example.
     *
     * This example prints 'Hello from Nios II' to the STDOUT stream. It runs on
     * the Nios II 'standard', 'full_featured', 'fast', and 'low_cost' example
     * designs. It runs with or without the MicroC/OS-II RTOS and requires a STDOUT
     * device in your system's hardware.
     * The memory footprint of this hosted application is ~69 kbytes by default
     * using the standard reference design.
     *
     * For a reduced footprint version of this template, and an explanation of how
     * to reduce the memory footprint for a given application, see the
     * "small_hello_world" template.
     *
     */
    
    #include <stdio.h>
    #include <system.h>//添加包含了系统宏定义的文件
    #include <altera_avalon_pio_regs.h>//添加包含IO操作函数的.h文件
    #include <unistd.h>//添加包含usleep的头文件进行精确延时
    
    int main()
    {
      printf("Hello from Nios II!
    ");
      while(1)
      {
      IOWR_ALTERA_AVALON_PIO_DATA(PIO_LED_BASE,0);//通过向PIO的基地址写数据,实现对GPIO的控制
      //delay(1000000);
      usleep(1000000);//us级延时
      IOWR_ALTERA_AVALON_PIO_DATA(PIO_LED_BASE,0x3ff);//通过向PIO的基地址写数据,实现对GPIO的控制
    //  delay(1000000);
      usleep(1000000);//us级延时
      }
      return 0;
    }

    同样的方法再次烧写程序

    实验现象:LED以2HZ的频率闪烁

     

  • 相关阅读:
    Dockerfile + Nginx.conf文件记录(用于前端项目部署)
    Dockerfile文件记录(用于后端项目部署)
    结合docker发布后端项目(基于gradle包管理)的shell脚本
    结合docker发布前端项目(基于npm包管理)的shell脚本
    Docker+Nginx使用流程(笔记)
    AntDesign getFieldDecorator 获取自定义组件的值
    c++ primer 第五版第七章
    c++ primer 第五版第六章
    c++ primer 第五版第五章
    c++ Primer 第五版习题答案第四章
  • 原文地址:https://www.cnblogs.com/noticeable/p/7290679.html
Copyright © 2011-2022 走看看