在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

RISC處理器在Verilog中實現并使用 Xilinx ISIM進行驗證

TLOc_gh_3394704 ? 來源:Hack電子 ? 作者:比特波特 ? 2021-08-10 16:22 ? 次閱讀

RISC 處理器是基于其指令集和哈佛型數據通路結構設計的。然后,RISC 處理器在Verilog 中實現并使用 Xilinx ISIM 進行驗證。

RISC處理器的指令集:A. 內存訪問指令1. 加載字:

LD ws, offset(rs1) ws:=Mem16[rs1 + offset]

2. 存儲字:

ST rs2, offset(rs1) Mem16[rs1 + offset]=rs2

B. 數據處理說明Add:

ADD ws, rs1, rs2 ws:=rs1 + rs2

Subtract:

SUB ws, rs1, rs2 ws:=rs1 – rs2

Invert (1‘s complement):

INV ws, rs1 ws:=!rs1

Logical Shift Left:

LSL ws, rs1, rs2 ws:=rs1 《《 rs2

Logical Shift Right:

LSR ws, rs1, rs2 ws:=rs1 》》 rs2

Bitwise AND:

AND ws, rs1, rs2 ws:=rs1 ? rs2

Bitwise OR

OR ws, rs1, rs2 ws:=rs1 | rs2

Set on Less Than:

SLT ws, rs1, rs2 ws:=1 if rs1 《 rs2; ws:=0 if rs1 ≥ rs2

C. 控制流說明1.等號分支:

BEQ rs1, rs2, offset

Branch to (PC + 2 + (offset 《《 1)) when rs1 = rs2

不等于分支

BNE rs1, rs2, offset

Branch to (PC + 2 + (offset 《《 1)) when rs1 != rs2

Jump:

JMP offset Jump to {PC [15:13], (offset 《《 1)}

RISC 處理器的 Verilog 代碼:

1.指令存儲器的Verilog 代碼`include “Parameter.v”

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Verilog code for Instruction Memory

module Instruction_Memory(

input[15:0] pc,

output[15:0] instruction

);

reg [`col - 1:0] memory [`row_i - 1:0];

wire [3 : 0] rom_addr = pc[4 : 1];

initial

begin

$readmemb(“。/test/test.prog”, memory,0,14);

end

assign instruction = memory[rom_addr];

endmodule

2.注冊文件的Verilog代碼:`timescale 1ns / 1ps

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Verilog code for register file

module GPRs(

input clk,

// write port

input reg_write_en,

input [2:0] reg_write_dest,

input [15:0] reg_write_data,

//read port 1

input [2:0] reg_read_addr_1,

output [15:0] reg_read_data_1,

//read port 2

input [2:0] reg_read_addr_2,

output [15:0] reg_read_data_2

);

reg [15:0] reg_array [7:0];

integer i;

// write port

//reg [2:0] i;

initial begin

for(i=0;i《8;i=i+1)

reg_array[i] 《= 16‘d0;

end

always @ (posedge clk ) begin

if(reg_write_en) begin

reg_array[reg_write_dest] 《= reg_write_data;

end

end

assign reg_read_data_1 = reg_array[reg_read_addr_1];

assign reg_read_data_2 = reg_array[reg_read_addr_2];

endmodule

3. 數據存儲器的 Verilog 代碼`include “Parameter.v”

// fpga4student.com

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Verilog code for data Memory

module Data_Memory(

input clk,

// address input, shared by read and write port

input [15:0] mem_access_addr,

// write port

input [15:0] mem_write_data,

input mem_write_en,

input mem_read,

// read port

output [15:0] mem_read_data

);

reg [`col - 1:0] memory [`row_d - 1:0];

integer f;

wire [2:0] ram_addr=mem_access_addr[2:0];

initial

begin

$readmemb(“。/test/test.data”, memory);

f = $fopen(`filename);

$fmonitor(f, “time = %d

”, $time,

“ memory[0] = %b

”, memory[0],

“ memory[1] = %b

”, memory[1],

“ memory[2] = %b

”, memory[2],

“ memory[3] = %b

”, memory[3],

“ memory[4] = %b

”, memory[4],

“ memory[5] = %b

”, memory[5],

“ memory[6] = %b

”, memory[6],

“ memory[7] = %b

”, memory[7]);

`simulation_time;

$fclose(f);

end

always @(posedge clk) begin

if (mem_write_en)

memory[ram_addr] 《= mem_write_data;

end

assign mem_read_data = (mem_read==1’b1) ? memory[ram_addr]: 16‘d0;

endmodule

4. ALU 單元的 Verilog 代碼:// fpga4student.com

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Verilog code for ALU

module ALU(

input [15:0] a, //src1

input [15:0] b, //src2

input [2:0] alu_control, //function sel

output reg [15:0] result, //result

output zero

);

always @(*)

begin

case(alu_control)

3’b000: result = a + b; // add

3‘b001: result = a - b; // sub

3’b010: result = ~a;

3‘b011: result = a《《b;

3’b100: result = a》》b;

3‘b101: result = a & b; // and

3’b110: result = a | b; // or

3‘b111: begin if (a《b) result = 16’d1;

else result = 16‘d0;

end

default:result = a + b; // add

endcase

end

assign zero = (result==16’d0) ? 1‘b1: 1’b0;

endmodule

5. RISC處理器的ALU控制單元的Verilog代碼:`timescale 1ns / 1ps

//fpga4student.com: FPGA projects, Verilog projects, VHDL projects

// Verilog code for 16-bit RISC processor

// ALU_Control Verilog code

module alu_control( ALU_Cnt, ALUOp, Opcode);

output reg[2:0] ALU_Cnt;

input [1:0] ALUOp;

input [3:0] Opcode;

wire [5:0] ALUControlIn;

assign ALUControlIn = {ALUOp,Opcode};

always @(ALUControlIn)

casex (ALUControlIn)

6‘b10xxxx: ALU_Cnt=3’b000;

6‘b01xxxx: ALU_Cnt=3’b001;

6‘b000010: ALU_Cnt=3’b000;

6‘b000011: ALU_Cnt=3’b001;

6‘b000100: ALU_Cnt=3’b010;

6‘b000101: ALU_Cnt=3’b011;

6‘b000110: ALU_Cnt=3’b100;

6‘b000111: ALU_Cnt=3’b101;

6‘b001000: ALU_Cnt=3’b110;

6‘b001001: ALU_Cnt=3’b111;

default: ALU_Cnt=3‘b000;

endcase

endmodule

6. RISC處理器Datapath的Verilog代碼:`timescale 1ns / 1ps

// fpga4student.com

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Verilog code for Data Path of the processor

module Datapath_Unit(

input clk,

input jump,beq,mem_read,mem_write,alu_src,reg_dst,mem_to_reg,reg_write,bne,

input[1:0] alu_op,

output[3:0] opcode

);

reg [15:0] pc_current;

wire [15:0] pc_next,pc2;

wire [15:0] instr;

wire [2:0] reg_write_dest;

wire [15:0] reg_write_data;

wire [2:0] reg_read_addr_1;

wire [15:0] reg_read_data_1;

wire [2:0] reg_read_addr_2;

wire [15:0] reg_read_data_2;

wire [15:0] ext_im,read_data2;

wire [2:0] ALU_Control;

wire [15:0] ALU_out;

wire zero_flag;

wire [15:0] PC_j, PC_beq, PC_2beq,PC_2bne,PC_bne;

wire beq_control;

wire [12:0] jump_shift;

wire [15:0] mem_read_data;

// PC

initial begin

pc_current 《= 16’d0;

end

always @(posedge clk)

begin

pc_current 《= pc_next;

end

assign pc2 = pc_current + 16‘d2;

// instruction memory

Instruction_Memory im(.pc(pc_current),.instruction(instr));

// jump shift left 2

assign jump_shift = {instr[11:0],1’b0};

// multiplexer regdest

assign reg_write_dest = (reg_dst==1‘b1) ? instr[5:3] :instr[8:6];

// register file

assign reg_read_addr_1 = instr[11:9];

assign reg_read_addr_2 = instr[8:6];

// GENERAL PURPOSE REGISTERs

GPRs reg_file

.clk(clk),

.reg_write_en(reg_write),

.reg_write_dest(reg_write_dest),

.reg_write_data(reg_write_data),

.reg_read_addr_1(reg_read_addr_1),

.reg_read_data_1(reg_read_data_1),

.reg_read_addr_2(reg_read_addr_2),

.reg_read_data_2(reg_read_data_2)

);

// immediate extend

assign ext_im = {{10{instr[5]}},instr[5:0]};

// ALU control unit

alu_control ALU_Control_unit(.ALUOp(alu_op),.Opcode(instr[15:12]),.ALU_Cnt(ALU_Control));

// multiplexer alu_src

assign read_data2 = (alu_src==1’b1) ? ext_im : reg_read_data_2;

// ALU

ALU alu_unit(.a(reg_read_data_1),.b(read_data2),.alu_control(ALU_Control),.result(ALU_out),.zero(zero_flag));

// PC beq add

assign PC_beq = pc2 + {ext_im[14:0],1‘b0};

assign PC_bne = pc2 + {ext_im[14:0],1’b0};

// beq control

assign beq_control = beq & zero_flag;

assign bne_control = bne & (~zero_flag);

// PC_beq

assign PC_2beq = (beq_control==1‘b1) ? PC_beq : pc2;

// PC_bne

assign PC_2bne = (bne_control==1’b1) ? PC_bne : PC_2beq;

// PC_j

assign PC_j = {pc2[15:13],jump_shift};

// PC_next

assign pc_next = (jump == 1‘b1) ? PC_j : PC_2bne;

/// Data memory

Data_Memory dm

.clk(clk),

.mem_access_addr(ALU_out),

.mem_write_data(reg_read_data_2),

.mem_write_en(mem_write),

.mem_read(mem_read),

.mem_read_data(mem_read_data)

);

// write back

assign reg_write_data = (mem_to_reg == 1’b1)? mem_read_data: ALU_out;

// output to control unit

assign opcode = instr[15:12];

endmodule

7. RISC 處理器控制單元的 Verilog 代碼:`timescale 1ns / 1ps

// fpga4student.com

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Verilog code for Control Unit

module Control_Unit(

input[3:0] opcode,

output reg[1:0] alu_op,

output reg jump,beq,bne,mem_read,mem_write,alu_src,reg_dst,mem_to_reg,reg_write

);

always @(*)

begin

case(opcode)

4‘b0000: // LW

begin

reg_dst = 1’b0;

alu_src = 1‘b1;

mem_to_reg = 1’b1;

reg_write = 1‘b1;

mem_read = 1’b1;

mem_write = 1‘b0;

beq = 1’b0;

bne = 1‘b0;

alu_op = 2’b10;

jump = 1‘b0;

end

4’b0001: // SW

begin

reg_dst = 1‘b0;

alu_src = 1’b1;

mem_to_reg = 1‘b0;

reg_write = 1’b0;

mem_read = 1‘b0;

mem_write = 1’b1;

beq = 1‘b0;

bne = 1’b0;

alu_op = 2‘b10;

jump = 1’b0;

end

4‘b0010: // data_processing

begin

reg_dst = 1’b1;

alu_src = 1‘b0;

mem_to_reg = 1’b0;

reg_write = 1‘b1;

mem_read = 1’b0;

mem_write = 1‘b0;

beq = 1’b0;

bne = 1‘b0;

alu_op = 2’b00;

jump = 1‘b0;

end

4’b0011: // data_processing

begin

reg_dst = 1‘b1;

alu_src = 1’b0;

mem_to_reg = 1‘b0;

reg_write = 1’b1;

mem_read = 1‘b0;

mem_write = 1’b0;

beq = 1‘b0;

bne = 1’b0;

alu_op = 2‘b00;

jump = 1’b0;

end

4‘b0100: // data_processing

begin

reg_dst = 1’b1;

alu_src = 1‘b0;

mem_to_reg = 1’b0;

reg_write = 1‘b1;

mem_read = 1’b0;

mem_write = 1‘b0;

beq = 1’b0;

bne = 1‘b0;

alu_op = 2’b00;

jump = 1‘b0;

end

4’b0101: // data_processing

begin

reg_dst = 1‘b1;

alu_src = 1’b0;

mem_to_reg = 1‘b0;

reg_write = 1’b1;

mem_read = 1‘b0;

mem_write = 1’b0;

beq = 1‘b0;

bne = 1’b0;

alu_op = 2‘b00;

jump = 1’b0;

end

4‘b0110: // data_processing

begin

reg_dst = 1’b1;

alu_src = 1‘b0;

mem_to_reg = 1’b0;

reg_write = 1‘b1;

mem_read = 1’b0;

mem_write = 1‘b0;

beq = 1’b0;

bne = 1‘b0;

alu_op = 2’b00;

jump = 1‘b0;

end

4’b0111: // data_processing

begin

reg_dst = 1‘b1;

alu_src = 1’b0;

mem_to_reg = 1‘b0;

reg_write = 1’b1;

mem_read = 1‘b0;

mem_write = 1’b0;

beq = 1‘b0;

bne = 1’b0;

alu_op = 2‘b00;

jump = 1’b0;

end

4‘b1000: // data_processing

begin

reg_dst = 1’b1;

alu_src = 1‘b0;

mem_to_reg = 1’b0;

reg_write = 1‘b1;

mem_read = 1’b0;

mem_write = 1‘b0;

beq = 1’b0;

bne = 1‘b0;

alu_op = 2’b00;

jump = 1‘b0;

end

4’b1001: // data_processing

begin

reg_dst = 1‘b1;

alu_src = 1’b0;

mem_to_reg = 1‘b0;

reg_write = 1’b1;

mem_read = 1‘b0;

mem_write = 1’b0;

beq = 1‘b0;

bne = 1’b0;

alu_op = 2‘b00;

jump = 1’b0;

end

4‘b1011: // BEQ

begin

reg_dst = 1’b0;

alu_src = 1‘b0;

mem_to_reg = 1’b0;

reg_write = 1‘b0;

mem_read = 1’b0;

mem_write = 1‘b0;

beq = 1’b1;

bne = 1‘b0;

alu_op = 2’b01;

jump = 1‘b0;

end

4’b1100: // BNE

begin

reg_dst = 1‘b0;

alu_src = 1’b0;

mem_to_reg = 1‘b0;

reg_write = 1’b0;

mem_read = 1‘b0;

mem_write = 1’b0;

beq = 1‘b0;

bne = 1’b1;

alu_op = 2‘b01;

jump = 1’b0;

end

4‘b1101: // J

begin

reg_dst = 1’b0;

alu_src = 1‘b0;

mem_to_reg = 1’b0;

reg_write = 1‘b0;

mem_read = 1’b0;

mem_write = 1‘b0;

beq = 1’b0;

bne = 1‘b0;

alu_op = 2’b00;

jump = 1‘b1;

end

default: begin

reg_dst = 1’b1;

alu_src = 1‘b0;

mem_to_reg = 1’b0;

reg_write = 1‘b1;

mem_read = 1’b0;

mem_write = 1‘b0;

beq = 1’b0;

bne = 1‘b0;

alu_op = 2’b00;

jump = 1‘b0;

end

endcase

end

endmodule

8. 16 位 RISC 處理器的 Verilog 代碼:`timescale 1ns / 1ps

// fpga4student.com

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

module Risc_16_bit(

input clk

);

wire jump,bne,beq,mem_read,mem_write,alu_src,reg_dst,mem_to_reg,reg_write;

wire[1:0] alu_op;

wire [3:0] opcode;

// Datapath

Datapath_Unit DU

.clk(clk),

.jump(jump),

.beq(beq),

.mem_read(mem_read),

.mem_write(mem_write),

.alu_src(alu_src),

.reg_dst(reg_dst),

.mem_to_reg(mem_to_reg),

.reg_write(reg_write),

.bne(bne),

.alu_op(alu_op),

.opcode(opcode)

);

// control unit

Control_Unit control

.opcode(opcode),

.reg_dst(reg_dst),

.mem_to_reg(mem_to_reg),

.alu_op(alu_op),

.jump(jump),

.bne(bne),

.beq(beq),

.mem_read(mem_read),

.mem_write(mem_write),

.alu_src(alu_src),

.reg_write(reg_write)

);

endmodule

9. 16 位 RISC 處理器的 Verilog 測試平臺代碼:`timescale 1ns / 1ps

`include “Parameter.v”

// fpga4student.com

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Verilog testbench code to test the processor

module test_Risc_16_bit;

// Inputs

reg clk;

// Instantiate the Unit Under Test (UUT)

Risc_16_bit uut (

.clk(clk)

);

initial

begin

clk 《=0;

`simulation_time;

$finish;

end

always

begin

#5 clk = ~clk;

end

endmodule

參數文件:`ifndef PARAMETER_H_

`define PARAMETER_H_

// fpga4student.com

// FPGA projects, VHDL projects, Verilog projects

// Verilog code for RISC Processor

// Parameter file

`define col 16 // 16 bits instruction memory, data memory

`define row_i 15 // instruction memory, instructions number, this number can be changed. Adding more instructions to verify your design is a good idea.

`define row_d 8 // The number of data in data memory. We only use 8 data. Do not change this number. You can change the value of each data inside test.data file. Total number is fixed at 8.

`define filename “。/test/50001111_50001212.o”

`define simulation_time #160

`endif

以上提供了 16 位 RISC 處理器所需的所有 Verilog 代碼。現在,只需要創建一個 test.data(數據存儲器的初始內容)和 test.prog(指令存儲器)。然后,運行仿真以查看該過程如何處理仿真波形和內存文件。

示例指令內存文件:

0000_0100_0000_0000 // load R0 《- Mem(R2 + 0)

0000_0100_0100_0001 // load R1 《- Mem(R2 + 1)

0010_0000_0101_0000 // Add R2 《- R0 + R1

0001_0010_1000_0000 // Store Mem(R1 + 0) 《- R2

0011_0000_0101_0000 // sub R2 《- R0 - R1

0100_0000_0101_0000 // invert R2 《- !R0

0101_0000_0101_0000 // logical shift left R2 《- R0《《R1

0110_0000_0101_0000 // logical shift right R2 《- R0》》R1

0111_0000_0101_0000 // AND R2《- R0 AND R1

1000_0000_0101_0000 // OR R2《- R0 OR R1

1001_0000_0101_0000 // SLT R2 《- 1 if R0 《 R1

0010_0000_0000_0000 // Add R0 《- R0 + R0

1011_0000_0100_0001 // BEQ branch to jump if R0=R1, PCnew= PC+2+offset《《1 = 28 =》 offset = 1

1100_0000_0100_0000 // BNE branch to jump if R0!=R1, PCnew= PC+2+offset《《1 = 28 =》 offset = 0

1101_0000_0000_0000 // J jump to the beginning address

示例數據存儲器文件:

0000_0000_0000_0001

0000_0000_0000_0010

0000_0000_0000_0001

0000_0000_0000_0010

0000_0000_0000_0001

0000_0000_0000_0010

0000_0000_0000_0001

0000_0000_0000_0010

參考鏈接:https://www.fpga4student.com/2016/11/plate-license-recognition-verilogmatlab.html

https://baike.baidu.com/item/%E7%B2%BE%E7%AE%80%E6%8C%87%E4%BB%A4%E9%9B%86%E8%AE%A1%E7%AE%97%E6%9C%BA/661859?fromtitle=risc&fromid=62696&fr=aladdin

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19404

    瀏覽量

    230921
  • Verilog
    +關注

    關注

    28

    文章

    1351

    瀏覽量

    110298
  • RISC
    +關注

    關注

    6

    文章

    465

    瀏覽量

    83826

原文標題:用Verilog設計一個16 位 RISC 處理器

文章出處:【微信號:gh_339470469b7d,微信公眾號:FPGA與數據通信】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Andes晶心科技推出D45-SE RISC-V處理器

    Andes晶心科技(TWSE:6533; SIN US03420C2089; ISIN:US03420C1099)是全球高效能、低功耗 32/64 位 RISC-V 處理器的領導廠商,也是
    的頭像 發表于 12-26 10:54 ?280次閱讀

    Verilog 電路仿真常見問題 Verilog 芯片設計的應用

    。然而,實際應用,設計師可能會遇到各種問題,這些問題可能會影響仿真的準確性和設計的可靠性。 Verilog電路仿真常見問題 仿真環境的搭建問題 仿真環境的搭建是進行
    的頭像 發表于 12-17 09:53 ?386次閱讀

    使用 RISC-V 進行高效數據處理的方法

    使用RISC-V進行高效數據處理的方法涉及多個方面,包括處理器內核與DSA(領域特定加速)之間的通信優化、內存管理優化、多線程性能提升等。
    的頭像 發表于 12-11 17:52 ?458次閱讀

    Rivos全新產品采用Andes晶心科技NX45 RISC-V處理器

    專注于加速數據分析和生成式AI工作負載的RISC-V主要會員公司Rivos與32/64位RISC-V處理器內核的領先供貨商、RISC-V創始會員Andes晶心科技,宣布Rivos已獲得
    的頭像 發表于 12-04 10:37 ?327次閱讀

    RISC-V能否復制Linux 的成功?》

    ,創建實現自有加速算法的自定義異構集群。RISC-V作為一種ISA,我們一開始是處理器內核
    發表于 11-26 20:20

    risc-v人工智能圖像處理應用前景分析

    RISC-V人工智能圖像處理的應用案例 目前,已有多個案例展示了RISC-V人工智能圖像
    發表于 09-28 11:00

    盛顯科技:拼接處理器上配置混合矩陣的步驟是什么?

    相信大家都知道,拼接處理器上配置混合矩陣,主要涉及到將混合矩陣的輸出與拼接處理器的輸入相連接,通過拼接處理器的軟件或界面
    的頭像 發表于 09-26 18:09 ?371次閱讀

    Xilinx? Zynq?UltraScale?系列多處理器的VCCINT_VCU軌供電

    電子發燒友網站提供《為Xilinx? Zynq?UltraScale?系列多處理器的VCCINT_VCU軌供電.pdf》資料免費下載
    發表于 09-25 10:54 ?0次下載
    為<b class='flag-5'>Xilinx</b>? Zynq?UltraScale?系列多<b class='flag-5'>處理器</b><b class='flag-5'>中</b>的VCCINT_VCU軌供電

    淺談國產異構雙核RISC-V+FPGA處理器AG32VF407的優勢和應用場景

    技術手段提高系統的安全性和可靠性,適用于對安全要求較高的應用場景。 應用場景 邊緣計算 : 物聯網、智能城市等邊緣計算場景,異構雙核RISC-V+FPGA處理器可以
    發表于 08-31 08:32

    請問ESP32s3 ULP RISC-V協處理器是否支持ADC的讀取?

    ULP RISC-V協處理器的例程,沒有發現有對ADC的操作,請問RISC-V協處理器目前
    發表于 06-14 07:38

    處理器的定義和種類

    處理器,作為計算機系統的核心部件,承載著執行指令、處理數據的重要任務。隨著信息技術的飛速發展,處理器的種類和性能也不斷提升。本文將對處理器
    的頭像 發表于 05-12 18:12 ?2922次閱讀

    RISC-V服務方面應用與發展前景

    RISC-V服務方面的應用與發展前景十分廣闊。作為一種開源、開放、簡潔、靈活的指令集,RISC-V近年來芯片產業中發展迅速,
    發表于 04-28 09:04

    Achronix FPGA增加對Bluespec提供的基于Linux的RISC-V軟處理器的支持,以實現可擴展數據處理

    Speedster?7t系列。這是業界首創,Bluespec的RISC-V處理器現在無縫集成到Achronix的二維片上網絡(2D NoC)架構,簡化了集成,使工程師能夠輕松地將可
    的頭像 發表于 04-19 18:08 ?734次閱讀

    淺談RISC-V微架構驗證方式

    RISC-V 是一個開放的 ISA,任何人都可以接受它實現處理器。但RISC-V市場的領導者知道,僅僅因為他們不需要支付許可使用費,并不意
    發表于 04-15 11:34 ?780次閱讀
    淺談<b class='flag-5'>RISC</b>-V微架構<b class='flag-5'>驗證</b>方式

    fpga和risc-v處理器的區別

    FPGA(現場可編程門陣列)和RISC-V處理器多個方面存在顯著的區別。
    的頭像 發表于 03-27 14:21 ?1241次閱讀
    主站蜘蛛池模板: 午夜黄色影片 | 色多多免费观看在线 | 天天夜夜人人 | 成人三级电影在线观看 | 免费高清视频在线观看 | 亚洲网在线观看 | 97色在线视频 | 色综合久久久久综合99 | 午夜毛片不卡高清免费 | 成人国产精品一级毛片视频 | 欧美a色爱欧美综合v | 国内精品视频 | 天天干天天操天天做 | 天堂网在线资源 | 99热久久久久久久免费观看 | 美女网站一区二区三区 | 天堂网在线www资源网 | 欧美一区二区三区精品 | 亚洲黄色性视频 | 国产handjob手交在线播放 | 国产小视频在线免费 | h网站在线播放 | 免费啪啪网 | 成年网站在线播放 | 国产二区三区 | 好爽~~~~嗯~~~再快点明星 | 国产拍拍拍免费视频网站 | 欧美高清在线观看视频 | 卡1卡2卡3精品推荐老狼 | 欧美zoozzooz在线观看 | 日本口工全彩无遮拦漫画大 | 天天做天天操 | 伊人久久大香线蕉综合高清 | 神马午夜影视 | tube69hdxxxx日本| 美女又爽又黄视频 | 直接看黄的网站 | 久久精品视频7 | 久久亚洲精品国产精品婷婷 | 免费人成年短视频在线观看免费网站 | 一级特黄aaa大片在 一级特黄aaa大片在线观看视频 |