Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
V
VME SBC A25 PCIe to VME bridge
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
1
Issues
1
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Wiki
Wiki
image/svg+xml
Discourse
Discourse
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
Projects
VME SBC A25 PCIe to VME bridge
Commits
e6f37e44
Commit
e6f37e44
authored
Jan 23, 2024
by
Tristan Gingold
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fully inline address decoder in A25_top
Remove z091_01_wb_adr_dec.vhd
parent
f96ca368
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
28 additions
and
162 deletions
+28
-162
A25_top.vhd
hdl/top/A25_top.vhd
+28
-9
Manifest.py
hdl/top/Manifest.py
+0
-1
z091_01_wb_adr_dec.vhd
hdl/top/z091_01_wb_adr_dec.vhd
+0
-152
No files found.
hdl/top/A25_top.vhd
View file @
e6f37e44
...
...
@@ -373,16 +373,35 @@ pll: pll_pcie
locked
=>
pll_locked
);
z091_01_wb_adr_dec_comp
:
entity
work
.
z091_01_wb_adr_dec
generic
map
(
NR_OF_WB_SLAVES
=>
NR_OF_WB_SLAVES
)
port
map
(
pci_cyc_i
=>
wbmo_0_cyc_bar
,
wbm_adr_o_q
=>
wbmo_0
.
adr
(
31
downto
2
),
-- Chameleon Table - cycle 0 - offset 0 - size 200 --
wbmo_0_cyc_int
(
0
)
<=
'1'
when
wbmo_0_cyc_bar
(
0
)
=
'1'
AND
wbmo_0
.
adr
(
17
DOWNTO
9
)
=
"000000000"
else
'0'
;
wbm_cyc_o
=>
wbmo_0_cyc_int
);
-- 16Z126_SERFLASH - cycle 1 - offset 200 - size 20 --
wbmo_0_cyc_int
(
1
)
<=
'1'
when
wbmo_0_cyc_bar
(
0
)
=
'1'
AND
wbmo_0
.
adr
(
17
DOWNTO
5
)
=
"0000000010000"
else
'0'
;
-- 16z002-01 VME regs - cycle 2 - offset 10000 - size 10000 --
wbmo_0_cyc_int
(
2
)
<=
'1'
when
wbmo_0_cyc_bar
(
0
)
=
'1'
AND
wbmo_0
.
adr
(
17
DOWNTO
16
)
=
"01"
else
'0'
;
-- 16z002-01 VME A16D16 - cycle 3 - offset 20000 - size 10000 --
wbmo_0_cyc_int
(
3
)
<=
'1'
when
wbmo_0_cyc_bar
(
0
)
=
'1'
AND
wbmo_0
.
adr
(
17
DOWNTO
16
)
=
"10"
else
'0'
;
-- 16z002-01 VME A16D32 - cycle 4 - offset 30000 - size 10000 --
wbmo_0_cyc_int
(
4
)
<=
'1'
when
wbmo_0_cyc_bar
(
0
)
=
'1'
AND
wbmo_0
.
adr
(
17
DOWNTO
16
)
=
"11"
else
'0'
;
-- 16z002-01 VME SRAM - cycle 5 - offset 0 - size 100000 --
wbmo_0_cyc_int
(
5
)
<=
wbmo_0_cyc_bar
(
1
);
-- 16z002-01 VME A24D16 - cycle 6 - offset 0 - size 1000000 --
wbmo_0_cyc_int
(
6
)
<=
'1'
when
wbmo_0_cyc_bar
(
2
)
=
'1'
AND
wbmo_0
.
adr
(
24
)
=
'0'
else
'0'
;
-- 16z002-01 VME A24D32 - cycle 7 - offset 1000000 - size 1000000 --
wbmo_0_cyc_int
(
7
)
<=
'1'
when
wbmo_0_cyc_bar
(
2
)
=
'1'
AND
wbmo_0
.
adr
(
24
)
=
'1'
else
'0'
;
-- 16z002-01 VME A32 - cycle 8 - offset 0 - size 20000000 --
wbmo_0_cyc_int
(
8
)
<=
wbmo_0_cyc_bar
(
3
);
-- 16z002-01 VME CRCSR - cycle 9 - offset 0 - size 1000000 --
wbmo_0_cyc_int
(
9
)
<=
wbmo_0_cyc_bar
(
4
);
wbmo_0_cyc
<=
-- +-Module Name--------------+-cyc-+---offset-+-----size-+-bar-+
"0001"
WHEN
wbmo_0_cyc_int
(
0
)
=
'1'
ELSE
-- | Chameleon Table | 0 | 0 | 200 | 0 |
...
...
hdl/top/Manifest.py
View file @
e6f37e44
...
...
@@ -26,5 +26,4 @@ files = [
"sram.vhd"
,
"wb_bus.vhd"
,
"wb_pkg.vhd"
,
"z091_01_wb_adr_dec.vhd"
,
]
hdl/top/z091_01_wb_adr_dec.vhd
deleted
100644 → 0
View file @
f96ca368
-- SPDX-FileCopyrightText: 2016, MEN Mikro Elektronik GmbH
-- SPDX-License-Identifier: CERN-OHL-S-2.0+
--------------------------------------------------------------------------------
-- Title : 16z091-01 specific Wishbone bus
-- Project :
-------------------------------------------------------------------------------
-- File : z091_01_wb_adr_dec.vhd
-- Author : Susanne Reinfelder
-- Organization : MEN Mikro Elektronik GmbH
-- Created : 2012-12-19
-------------------------------------------------------------------------------
-- Simulator :
-- Synthesis :
-------------------------------------------------------------------------------
-- +-Module Name-------------------+-cyc-+---offset-+-----size-+-bar-+
-- | Chameleon Table | 0 | 0 | 200 | 0 |
-- | 16Z126_SERFLASH | 1 | 200 | 20 | 0 |
-- | 16z002-01 VME | 2 | 10000 | 10000 | 0 |
-- | 16z002-01 VME A16D16 | 3 | 20000 | 10000 | 0 |
-- | 16z002-01 VME A16D32 | 4 | 30000 | 10000 | 0 |
-- | 16z002-01 VME SRAM | 5 | 0 | 100000 | 1 |
-- | 16z002-01 VME A24D16 | 6 | 0 | 1000000 | 2 |
-- | 16z002-01 VME A24D32 | 7 | 1000000 | 1000000 | 2 |
-- | 16z002-01 VME A32 | 8 | 0 | 20000000 | 3 |
-- +-------------------------------+-----+----------+----------+-----+
--
--------------------------------------------------------------------------------
--
--------------------------------------------------------------------------------
LIBRARY
ieee
;
use
ieee
.
std_logic_1164
.
all
;
use
ieee
.
std_logic_arith
.
all
;
use
ieee
.
std_logic_misc
.
all
;
entity
z091_01_wb_adr_dec
is
generic
(
NR_OF_WB_SLAVES
:
integer
range
63
downto
1
:
=
1
);
port
(
pci_cyc_i
:
in
std_logic_vector
(
6
downto
0
);
wbm_adr_o_q
:
in
std_logic_vector
(
31
downto
2
);
wbm_cyc_o
:
out
std_logic_vector
(
NR_OF_WB_SLAVES
-1
downto
0
)
);
end
z091_01_wb_adr_dec
;
-------------------------------------------------------------------------
-- sim_test_arch implements a sample pcie address decoder to enable
-- the simulation iram models
-------------------------------------------------------------------------
architecture
a25_arch
of
z091_01_wb_adr_dec
is
begin
PROCESS
(
wbm_adr_o_q
,
pci_cyc_i
)
VARIABLE
wbm_cyc_o_int
:
std_logic_vector
(
NR_OF_WB_SLAVES
-1
DOWNTO
0
);
CONSTANT
zero
:
std_logic_vector
(
NR_OF_WB_SLAVES
-1
downto
0
):
=
(
OTHERS
=>
'0'
);
BEGIN
wbm_cyc_o_int
:
=
(
OTHERS
=>
'0'
);
-- Chameleon Table - cycle 0 - offset 0 - size 200 --
IF
pci_cyc_i
(
0
)
=
'1'
AND
wbm_adr_o_q
(
17
DOWNTO
9
)
=
"000000000"
THEN
wbm_cyc_o_int
(
0
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
0
)
:
=
'0'
;
END
IF
;
-- 16Z126_SERFLASH - cycle 1 - offset 200 - size 20 --
IF
pci_cyc_i
(
0
)
=
'1'
AND
wbm_adr_o_q
(
17
DOWNTO
5
)
=
"0000000010000"
THEN
wbm_cyc_o_int
(
1
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
1
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME - cycle 2 - offset 10000 - size 10000 --
IF
pci_cyc_i
(
0
)
=
'1'
AND
wbm_adr_o_q
(
17
DOWNTO
16
)
=
"01"
THEN
wbm_cyc_o_int
(
2
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
2
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME A16D16 - cycle 3 - offset 20000 - size 10000 --
IF
pci_cyc_i
(
0
)
=
'1'
AND
wbm_adr_o_q
(
17
DOWNTO
16
)
=
"10"
THEN
wbm_cyc_o_int
(
3
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
3
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME A16D32 - cycle 4 - offset 30000 - size 10000 --
IF
pci_cyc_i
(
0
)
=
'1'
AND
wbm_adr_o_q
(
17
DOWNTO
16
)
=
"11"
THEN
wbm_cyc_o_int
(
4
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
4
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME SRAM - cycle 5 - offset 0 - size 100000 --
IF
pci_cyc_i
(
1
)
=
'1'
THEN
wbm_cyc_o_int
(
5
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
5
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME A24D16 - cycle 6 - offset 0 - size 1000000 --
IF
pci_cyc_i
(
2
)
=
'1'
AND
wbm_adr_o_q
(
24
)
=
'0'
THEN
wbm_cyc_o_int
(
6
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
6
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME A24D32 - cycle 7 - offset 1000000 - size 1000000 --
IF
pci_cyc_i
(
2
)
=
'1'
AND
wbm_adr_o_q
(
24
)
=
'1'
THEN
wbm_cyc_o_int
(
7
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
7
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME A32 - cycle 8 - offset 0 - size 20000000 --
IF
pci_cyc_i
(
3
)
=
'1'
THEN
wbm_cyc_o_int
(
8
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
8
)
:
=
'0'
;
END
IF
;
-- 16z002-01 VME CRCSR - cycle 9 - offset 0 - size 1000000 --
IF
pci_cyc_i
(
4
)
=
'1'
THEN
wbm_cyc_o_int
(
9
)
:
=
'1'
;
ELSE
wbm_cyc_o_int
(
9
)
:
=
'0'
;
END
IF
;
IF
or_reduce
(
pci_cyc_i
)
=
'1'
AND
wbm_cyc_o_int
=
zero
THEN
wbm_cyc_o_int
(
0
)
:
=
'1'
;
END
IF
;
wbm_cyc_o
<=
wbm_cyc_o_int
;
END
PROCESS
;
end
a25_arch
;
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment