高云SOC芯片GW1NSR-LV4CQN48的ARM总线

国产GOWIN高云出的一款芯片是GW1NSR-LV4CQN48PC7/I6,QN48封装,资源是4608,有10个18K BRAM,以及2个PLL,内置HyperRAM 64Mb, 可以用于电机,图像测试。内置ARM-M3硬核,可以替换简单的MCU应用。

其中ARM和FPGA的总线连接是两种AHB和APB总线。以下介绍的基本总线的连接代码。

其中AHB总线是包含BURST突发模式读取数据内容。实际从波形调试可以得到每次突发模式8个数据内容。

module Gowin_AHB_Multiple

(

output      wire [31:0]        AHB_HRDATA,

output      wire                    AHB_HREADY,

output      wire [ 1:0]         AHB_HRESP,

input         wire [ 1:0]  AHB_HTRANS,

input         wire [ 2:0]  AHB_HBURST,

input         wire [ 3:0]  AHB_HPROT,

input         wire [ 2:0]         AHB_HSIZE,

input         wire                    AHB_HWRITE,

input         wire                    AHB_HMASTLOCK,

input         wire [ 3:0]         AHB_HMASTER,

input         wire [31:0]        AHB_HADDR,

input         wire [31:0]  AHB_HWDATA,

input         wire                    AHB_HSEL,

input         wire                    AHB_HCLK,

input         wire                    AHB_HRESETn

);

//The AHB BUS is always ready

assign AHB_HREADY = 1'b1; //ready signal, slave to MCU master

//Response OKAY

assign AHB_HRESP  = 2'b0;//response signal, slave to MCU master

//Define Reg for AHB BUS

reg [31:0]  ahb_address;

reg           ahb_control;

reg         ahb_sel;

reg         ahb_htrans;

always @(posedge AHB_HCLK or negedge AHB_HRESETn)

begin

if(~AHB_HRESETn)

begin

ahb_address  <= 32'b0;

ahb_control  <= 1'b0;

ahb_sel      <= 1'b0;

ahb_htrans   <= 1'b0;

end

else              //Select The AHB Device

begin                             //Get the Address of reg

ahb_address  <= AHB_HADDR;

ahb_control  <= AHB_HWRITE;

ahb_sel      <= AHB_HSEL;

ahb_htrans   <= AHB_HTRANS[1];

end

end

wire write_enable = ahb_htrans & ahb_control    & ahb_sel;

wire read_enable  = ahb_htrans & (!ahb_control) & ahb_sel;

//The register of Multiple AHB bus

reg [7:0 ] Multiplier;

reg [7:0 ] Multiplicand;

reg [15:0] The_result;

reg [1:0 ] Cmd_reg; //The Bit0 -> Start

//The Bit1 -> The State of Multiple

wire        cmd_finished_status ;

wire [15:0] wire_multiple_result;

//write data to AHB bus

always @(posedge AHB_HCLK or negedge AHB_HRESETn)

begin

if(~AHB_HRESETn)

begin

Multiplier   <= 8'b0;

Multiplicand <= 8'b0;

end

else if(write_enable)

begin

case (ahb_address[15:0])

16'h0000: Multiplier       <= AHB_HWDATA[7:0];

16'h0004: Multiplicand  <= AHB_HWDATA[7:0];

endcase

end

end

//Status

always @(posedge AHB_HCLK or negedge AHB_HRESETn)

begin

if(~AHB_HRESETn)

begin

Cmd_reg  <=  2'b0;

end

else if(write_enable &(ahb_address[15:0] == 16'h0008))

begin

Cmd_reg  <= AHB_HWDATA[1:0];

end

else if(cmd_finished_status)

begin

Cmd_reg  <=  2'b10;

end

end

//read data to AHB bus

always @(posedge AHB_HCLK or negedge AHB_HRESETn)

begin

if(~AHB_HRESETn)

begin

The_result     <=    16'b0;

end

else if(cmd_finished_status)

begin

The_result      <=     wire_multiple_result;

end

end

//register address

reg [31:0] ahb_rdata;

always @(*)

begin

if(read_enable)  //read cmd

begin

case (ahb_address[15:0])

32'h0000:  ahb_rdata = Multiplier;

32'h0004:  ahb_rdata = Multiplicand;

32'h0008:  ahb_rdata = Cmd_reg;

32'h000C:  ahb_rdata = The_result;

default:ahb_rdata = 32'hFFFFFFFF;

endcase

end

else

begin

ahb_rdata = 32'hFFFFFFFF;

end

end

assign AHB_HRDATA = ahb_rdata;

而对于APB的总线,一次性只能读取一个数据内容。

module Gowin_APB2_Multiple

(

//---------------------The Port declartion--------

input          pclk,       // master clock input

input          presetn,    //synchronous active low reset

input          psel,       //slave sel

input          penable,    //enable

input          pwrite,     //transmit direction

input   [11:2] paddr,      //lower address bits

input   [31:0] pwdata,     //write data

output  [31:0] prdata      //read data

);

wire write_enable = psel    & pwrite    & (!penable);

wire read_enable  = psel    & (!pwrite) &   penable;

//The register of apb bus

reg [7:0 ] Multiplier;

reg [7:0 ] Multiplicand;

reg [15:0] The_result;

reg [1:0 ] Cmd_reg; //The Bit0 -> Start

//The Bit1 -> The State of Multiple

//write Block

always @(posedge pclk or negedge presetn)

begin

if(~presetn)

begin

Multiplier      <=  8'b0;

Multiplicand    <=  8'b0;

end

else

begin

if(write_enable)

begin

case (paddr[11:2])

10'h00: Multiplier      <= pwdata;

10'h01: Multiplicand    <= pwdata;

endcase

end

end

end

reg [31:0] prdata_out;

//Read Block

always @(*)

begin

if (read_enable)

begin

case (paddr[11:2])

10'h00:  prdata_out = Multiplier;

10'h01:  prdata_out = Multiplicand;

10'h02:  prdata_out = Cmd_reg;

10'h03:  prdata_out = The_result;

default: prdata_out = 32'hFFFFFFFF;//Indicate the unvalid state

endcase

end

else

begin

prdata_out  = 32'hFFFFFFFF;

end

end

assign prdata = prdata_out;

高云SOC芯片GW1NSR-LV4CQN48的ARM总线的更多相关文章

  1. ARM总线方面知识

    AMBA简介 随着深亚微米工艺技术日益成熟,集成电路芯片的规模越来越大.数字IC从基于时序驱动的设计方法,发展到基于IP复用的设计方法,并在SOC设计中得到了广泛应用.在基于IP复用的SoC设计中,片 ...

  2. SOC芯片的FPGA原型验证

    FPGA验证在SOC设计非常重要,一般而言,做一些RAM和FIFO的替换以及相应代码转换.具体分下面几步: 1 替换RAM,FIFO和时钟 RAM和FIFO控制器需要RAM的接口都放在了设计顶层,方便 ...

  3. IN612 IN612L蓝牙5.0 SoC芯片替换NRF52832/NRF52840

    IN612L是美国公司INPLAY的SOC产品系列之一,具有多模协同2.4G无线协议栈,支持2.4G私有协议栈以及蓝牙5.0全协议栈的SOC芯片.如2mbps高数据速率模式,125kbps/500kb ...

  4. ASR6601:国产化lora SOC芯片兼容SX1262/SX1268

    ASR6601为目前首颗国产化支持LoRaWAN低功耗广域网无线通信SoC芯片.ASR6601在单芯片上集成了通用微控制器和射频单元(SX1262),包括射频收发器,调制解调器和48 MHz 主频.A ...

  5. Hi3518 网络监控SOC芯片规格参数

    Hi3518 网络监控SOC芯片 视频编解码   处理器内核 ●   ARM926@ 440MHz,16KB I-Cache ,16KB D-Cache 视频编码 ●   H.264 Main Pro ...

  6. CPU缓存是位于CPU与内存之间的临时数据交换器,它的容量比内存小的多但是交换速度却比内存要快得多。CPU缓存一般直接跟CPU芯片集成或位于主板总线互连的独立芯片上

    一.什么是CPU缓存 1. CPU缓存的来历 众所周知,CPU是计算机的大脑,它负责执行程序的指令,而内存负责存数据, 包括程序自身的数据.在很多年前,CPU的频率与内存总线的频率在同一层面上.内存的 ...

  7. CI2454国产8位RISC核SoC芯片

    Ci2454是一款集成无线收发器和8位RISC(精简指令集)MCU的SOC芯片.主要应用在遥控玩具.智能灯控.数据透传.工业控制等领域.无线收发器主要特性 工作在 2.4GHz ISM 频段. 调制方 ...

  8. 手机Soc芯片简介

    手机SoC(System On a Chip,在一个芯片里面集成CPU.GPU.SP.ISP.RAM内存.Wi-Fi控制器.基带芯片以及音频芯片等)芯片(基于arm架构指令集) 高通骁龙(Snapdr ...

  9. ARM总线架构

    S3C2440集成了丰富了外设控制器(LCD控制器.USB Device控制器.USB Host控制器.NAND FLASH控制器.I2C控制器.SPI控制器等).要控制这些外设就要设置相应控制器的寄 ...

  10. Nordic nRF52820超低功耗蓝牙5.2 SoC芯片-低端无线连接方案首选

    nRF52820是功耗超低的低功耗蓝牙 (Bluetooth Low Energy /Bluetooth LE).蓝牙mesh.Thread.Zigbee和2.4 GHz专有低端无线连接解决方案.nR ...

随机推荐

  1. Java基础全程复习笔记(值得参考)

    Java基础复习笔记 第01章:Java语言概述 1. Java基础学习的章节划分 第1阶段:Java基本语法 Java语言概述.Java的变量与进制.运算符.流程控制语句(条件判断.循环结构).br ...

  2. 有了net/http, 为什么还要有gin

    1. 简介 在Go语言中,net/http 包提供了一个强大且灵活的标准HTTP库,可以用来构建Web应用程序和处理HTTP请求.这个包是Go语言标准库的一部分,因此所有的Go程序都可以直接使用它.既 ...

  3. 一些Clion使用记录

    一些Clion使用记录 编译链设置 在设置"工具链"中可以按需增加不同的编译链 访问越界溢出debug AddressSanitizer介绍:AddressSanitizer 交的 ...

  4. npm 添加 淘宝代理

    npm config set registry https://registry.npm.taobao.org

  5. 在运行程序是出现sh: 行 1: cls: 未找到命令

    在运行程序是出现sh: 行 1: cls: 未找到命令 原因是system("cls");--这是在程序中调用系统命令,但是linux识别不了.功能是清除当前的终端显示数据.找到l ...

  6. c语言中int和char之间的转换实例解析

    壹:     经常用到c,积累一些小函数,免得下次还要重新写,极大的提升工作效率啊. 贰:    代码很简单,直接上源码: #include <stdio.h> typedef unsig ...

  7. vue入门教程之基础语法

    vue入门教程之基础语法 欢迎关注博主公众号「java大师」, 专注于分享Java领域干货文章, 关注回复「资源」, 免费领取全网最热的Java架构师学习PDF, 转载请注明出处 https://ww ...

  8. 通过抓包分析RTP包头格式信息

    目录 RTP概览 RTP Header格式 Rtp 数据包拆解 Version Padding X(扩展) CC(CSRC计数) M(marker) PT(payload type) sequence ...

  9. C#的窗体防闪烁解决方案 - 开源研究系列文章

    昨天编码的时候想到了关于无边框窗体的闪烁问题,主要是改变窗体大小的时候会闪烁,默认的窗体没这个问题.而现在无边框窗体的应用比较多,所以就找了度娘,然后结合自己的经验进行了测试,得到了这个例子,简单有效 ...

  10. 一款超酷、功能强大的一体化网站测试工具:Web-Check

    今天给大家一款网站一体化测试工具:Web-Check! Web-Check 是一款功能强大的一体化工具,用于发现网站/主机的相关信息.用于检查网页的工具,用于确保网页的正确性和可访问性.它可以帮助开发 ...