Skip to content

Commit

Permalink
add native bus protocol (#7, rggen/rggen#234)
Browse files Browse the repository at this point in the history
  • Loading branch information
taichi-ishitani authored Jan 16, 2025
1 parent 0fabf55 commit 7af23dd
Show file tree
Hide file tree
Showing 4 changed files with 118 additions and 0 deletions.
1 change: 1 addition & 0 deletions lib/rggen/veryl.rb
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
'veryl/register_block/protocol/apb',
'veryl/register_block/protocol/axi4lite',
'veryl/register_block/protocol/wishbone',
'veryl/register_block/protocol/native',
'veryl/register_file/veryl_top',
'veryl/register/veryl_top',
'veryl/register/type',
Expand Down
18 changes: 18 additions & 0 deletions lib/rggen/veryl/register_block/protocol/native.erb
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
inst u_adapter: rggen::rggen_native_adapter #(
ADDRESS_WIDTH: <%= address_width %>,
LOCAL_ADDRESS_WIDTH: <%= local_address_width %>,
BUS_WIDTH: <%= bus_width %>,
STROBE_WIDTH: <%= strobe_width %>,
REGISTERS: <%= total_registers %>,
PRE_DECODE: <%= pre_decode %>,
BASE_ADDRESS: <%= base_address %>,
BYTE_SIZE: <%= byte_size %>,
ERROR_STATUS: <%= error_status %>,
DEFAULT_READ_DATA: <%= default_read_data %>,
INSERT_SLICER: <%= insert_slicer %>
)(
i_clk: <%= register_block.clock %>,
i_rst: <%= register_block.reset %>,
csrbus_if: <%= csrbus_if %>,
register_if: <%= register_block.register_if %>
);
17 changes: 17 additions & 0 deletions lib/rggen/veryl/register_block/protocol/native.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# frozen_string_literal: true

RgGen.define_list_item_feature(:register_block, :protocol, :native) do
veryl do
build do
param :strobe_width, {
name: 'STROBE_WIDTH', type: :u32, default: bus_width / 8
}
modport :csrbus_if, {
name: 'csrbus_if',
interface_type: 'rggen::rggen_bus_if', modport: 'slave'
}
end

main_code :register_block, from_template: true
end
end
82 changes: 82 additions & 0 deletions spec/rggen/veryl/register_block/protocol/native_spec.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
#! frozen_string_literal: true

RSpec.describe 'register_block/protocol/native' do
include_context 'veryl common'
include_context 'clean-up builder'

before(:all) do
RgGen.enable(:global, [:bus_width, :address_width, :enable_wide_register])
RgGen.enable(:register_block, [:name, :protocol, :byte_size])
RgGen.enable(:register_block, :protocol, [:native])
RgGen.enable(:register, [:name, :offset_address, :size, :type])
RgGen.enable(:register, :type, [:external])
RgGen.enable(:register_block, [:veryl_top])
end

let(:address_width) do
16
end

let(:bus_width) do
32
end

let(:register_block) do
create_register_block do
name 'block_0'
byte_size 256
register { name 'register_0'; offset_address 0x00; size [1]; type :external }
register { name 'register_1'; offset_address 0x10; size [1]; type :external }
register { name 'register_2'; offset_address 0x20; size [1]; type :external }
end
end

def create_register_block(&)
configuration =
create_configuration(
address_width:, bus_width:, protocol: :native
)
create_veryl(configuration, &).register_blocks.first
end

it 'パラメータ#strobe_widthを持つ' do
expect(register_block)
.to have_param(
:strobe_width,
name: 'STROBE_WIDTH', type: :u32, default: bus_width / 8
)
end

it 'modport #csrbus_ifを持つ' do
expect(register_block)
.to have_modport(
:csrbus_if,
name: 'csrbus_if', interface_type: 'rggen::rggen_bus_if', modport: 'slave'
)
end

describe '#generate_code' do
it 'rggen_native_adapterをインスタンスするコードを生成する' do
expect(register_block).to generate_code(:register_block, :top_down, <<~'VERYL')
inst u_adapter: rggen::rggen_native_adapter #(
ADDRESS_WIDTH: ADDRESS_WIDTH,
LOCAL_ADDRESS_WIDTH: 8,
BUS_WIDTH: 32,
STROBE_WIDTH: STROBE_WIDTH,
REGISTERS: 3,
PRE_DECODE: PRE_DECODE,
BASE_ADDRESS: BASE_ADDRESS,
BYTE_SIZE: 256,
ERROR_STATUS: ERROR_STATUS,
DEFAULT_READ_DATA: DEFAULT_READ_DATA,
INSERT_SLICER: INSERT_SLICER
)(
i_clk: i_clk,
i_rst: i_rst,
csrbus_if: csrbus_if,
register_if: register_if
);
VERYL
end
end
end

0 comments on commit 7af23dd

Please sign in to comment.