Files
fpga6502/fpga/ip/gTSE/Testbench/ncsim/gTSE.sv
2026-04-14 21:34:37 -07:00

9955 lines
521 KiB
Systemverilog

// =============================================================================
// Generated by efx_ipmgr
// Version: 2025.2.288.2.10
// IP Version: 7.1
// =============================================================================
////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2013-2025 Efinix Inc. All rights reserved.
//
// This document contains proprietary information which is
// protected by copyright. All rights are reserved. This notice
// refers to original work by Efinix, Inc. which may be derivitive
// of other work distributed under license of the authors. In the
// case of derivative work, nothing in this notice overrides the
// original author's license agreement. Where applicable, the
// original license agreement is included in it's original
// unmodified form immediately below this header.
//
// WARRANTY DISCLAIMER.
// THE DESIGN, CODE, OR INFORMATION ARE PROVIDED “AS IS” AND
// EFINIX MAKES NO WARRANTIES, EXPRESS OR IMPLIED WITH
// RESPECT THERETO, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES,
// INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY, NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR
// PURPOSE. SOME STATES DO NOT ALLOW EXCLUSIONS OF AN IMPLIED
// WARRANTY, SO THIS DISCLAIMER MAY NOT APPLY TO LICENSEE.
//
// LIMITATION OF LIABILITY.
// NOTWITHSTANDING ANYTHING TO THE CONTRARY, EXCEPT FOR BODILY
// INJURY, EFINIX SHALL NOT BE LIABLE WITH RESPECT TO ANY SUBJECT
// MATTER OF THIS AGREEMENT UNDER TORT, CONTRACT, STRICT LIABILITY
// OR ANY OTHER LEGAL OR EQUITABLE THEORY (I) FOR ANY INDIRECT,
// SPECIAL, INCIDENTAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES OF ANY
// CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF
// GOODWILL, DATA OR PROFIT, WORK STOPPAGE, OR COMPUTER FAILURE OR
// MALFUNCTION, OR IN ANY EVENT (II) FOR ANY AMOUNT IN EXCESS, IN
// THE AGGREGATE, OF THE FEE PAID BY LICENSEE TO EFINIX HEREUNDER
// (OR, IF THE FEE HAS BEEN WAIVED, $100), EVEN IF EFINIX SHALL HAVE
// BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO
// NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR
// CONSEQUENTIAL DAMAGES, SO THIS LIMITATION AND EXCLUSION MAY NOT
// APPLY TO LICENSEE.
//
////////////////////////////////////////////////////////////////////////////////
`define IP_UUID _4c19f37180ff465ca20760e199a0613f
`define IP_NAME_CONCAT(a,b) a``b
`define IP_MODULE_NAME(name) `IP_NAME_CONCAT(name,`IP_UUID)
module gTSE
(
input mac_reset,
input proto_reset,
output rx_mac_aclk,
input tx_mac_aclk,
output [2:0] eth_speed,
input rx_axis_clk,
output rx_axis_mac_tuser,
output rx_axis_mac_tlast,
output rx_axis_mac_tvalid,
input rx_axis_mac_tready,
input tx_axis_clk,
input tx_axis_mac_tvalid,
input tx_axis_mac_tlast,
input tx_axis_mac_tuser,
output tx_axis_mac_tready,
output [3:0] rgmii_txd_HI,
output [3:0] rgmii_txd_LO,
output rgmii_tx_ctl_HI,
output rgmii_tx_ctl_LO,
output rgmii_txc_HI,
output rgmii_txc_LO,
input [3:0] rgmii_rxd_HI,
input [3:0] rgmii_rxd_LO,
input rgmii_rx_ctl_HI,
input rgmii_rx_ctl_LO,
input rgmii_rxc,
input s_axi_aclk,
output [7:0] rx_axis_mac_tdata,
input [7:0] tx_axis_mac_tdata,
input [0:0] tx_axis_mac_tstrb,
output [0:0] rx_axis_mac_tstrb,
output MdoEn,
output Mdo,
input Mdi,
output Mdc,
input [9:0] s_axi_araddr,
output s_axi_arready,
input s_axi_arvalid,
input [9:0] s_axi_awaddr,
output s_axi_awready,
input s_axi_awvalid,
input s_axi_bready,
output [1:0] s_axi_bresp,
output s_axi_bvalid,
output [31:0] s_axi_rdata,
input s_axi_rready,
output [1:0] s_axi_rresp,
output s_axi_rvalid,
input [31:0] s_axi_wdata,
output s_axi_wready,
input s_axi_wvalid
);
`IP_MODULE_NAME(efx_mac1gbe)
#(
.VERSION (16),
.TXFIFO_EN (1'b1),
.RXFIFO_EN (1'b1),
.TXFIFO_DTH (4096),
.RXFIFO_DTH (4096),
.PHY_INTF_MODE (0),
.AXIS_DW (8),
.RGMII_RXC_EDGE (1'b1),
.RGMII_TXC_DLY (1'b1),
.INTER_PACKET_GAP (6'd12),
.MTU_FRAME_LENGTH (16'd1518),
.MAC_SOURCE_ADDRESS (48'd0),
.ENABLE_BROADCAST_FILTERING (1'b1),
.LOOPBACK_EN (1'b1),
.APBIF (1'b0),
.FAMILY ("TITANIUM")
)
u_efx_mac1gbe
(
.mac_reset ( mac_reset ),
.proto_reset ( proto_reset ),
.rx_mac_aclk ( rx_mac_aclk ),
.tx_mac_aclk ( tx_mac_aclk ),
.eth_speed ( eth_speed ),
.rx_axis_clk ( rx_axis_clk ),
.rx_axis_mac_tuser ( rx_axis_mac_tuser ),
.rx_axis_mac_tlast ( rx_axis_mac_tlast ),
.rx_axis_mac_tvalid ( rx_axis_mac_tvalid ),
.rx_axis_mac_tready ( rx_axis_mac_tready ),
.tx_axis_clk ( tx_axis_clk ),
.tx_axis_mac_tvalid ( tx_axis_mac_tvalid ),
.tx_axis_mac_tlast ( tx_axis_mac_tlast ),
.tx_axis_mac_tuser ( tx_axis_mac_tuser ),
.tx_axis_mac_tready ( tx_axis_mac_tready ),
.rgmii_txd_HI ( rgmii_txd_HI ),
.rgmii_txd_LO ( rgmii_txd_LO ),
.rgmii_tx_ctl_HI ( rgmii_tx_ctl_HI ),
.rgmii_tx_ctl_LO ( rgmii_tx_ctl_LO ),
.rgmii_txc_HI ( rgmii_txc_HI ),
.rgmii_txc_LO ( rgmii_txc_LO ),
.rgmii_rxd_HI ( rgmii_rxd_HI ),
.rgmii_rxd_LO ( rgmii_rxd_LO ),
.rgmii_rx_ctl_HI ( rgmii_rx_ctl_HI ),
.rgmii_rx_ctl_LO ( rgmii_rx_ctl_LO ),
.rgmii_rxc ( rgmii_rxc ),
.s_axi_aclk ( s_axi_aclk ),
.rx_axis_mac_tdata ( rx_axis_mac_tdata ),
.tx_axis_mac_tdata ( tx_axis_mac_tdata ),
.tx_axis_mac_tstrb ( tx_axis_mac_tstrb ),
.rx_axis_mac_tstrb ( rx_axis_mac_tstrb ),
.MdoEn ( MdoEn ),
.Mdo ( Mdo ),
.Mdi ( Mdi ),
.Mdc ( Mdc ),
.s_axi_araddr ( s_axi_araddr ),
.s_axi_arready ( s_axi_arready ),
.s_axi_arvalid ( s_axi_arvalid ),
.s_axi_awaddr ( s_axi_awaddr ),
.s_axi_awready ( s_axi_awready ),
.s_axi_awvalid ( s_axi_awvalid ),
.s_axi_bready ( s_axi_bready ),
.s_axi_bresp ( s_axi_bresp ),
.s_axi_bvalid ( s_axi_bvalid ),
.s_axi_rdata ( s_axi_rdata ),
.s_axi_rready ( s_axi_rready ),
.s_axi_rresp ( s_axi_rresp ),
.s_axi_rvalid ( s_axi_rvalid ),
.s_axi_wdata ( s_axi_wdata ),
.s_axi_wready ( s_axi_wready ),
.s_axi_wvalid ( s_axi_wvalid )
);
endmodule
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AnxLCEXIwWGNUbKODuvDDj9z3+IsvyasQalysUi/itDT2wwInQ3bBdLVigviyZBs
KfNqHVcHh1PkyYw6Tc63TbVvrM0JlKHeRk9d4Ni755Frdl+e0Yeh82+Cu7JAI77V
toSbtXAPtD6vOVPzzed5ozvhLM0NSdRFehAG9pksl3iYjKFZP6TayMWce09NBstN
j+KnL6lB7cNlu0ejMJXS7VgJ8dx8NGBDtFHQEZ5XfZo3IKXu2RTPmQkW3pU8QhlH
F8qGcX2EikZvcV+7xxJnVc8CjsdqEa+f2tIVEtB7gpGdCQYhsfE4ScprrVpuFhH+
2Rn6AkA5iTdD385b26iafw==
//pragma protect end_key_block
//pragma protect digest_block
45gGFciNrCTJZXxwMOIqQD36VKE=
//pragma protect end_digest_block
//pragma protect data_block
/fAtlRv3M2ytzKM0VXXGACIycHPm8M1coZKa23W5ckG5VSaPQWRKFrb6mgu8TO0l
bsYYbh10DRf4e0UeK3eUMlW2Nv7PK5r0WlNsZ9MnO0NK/lbgmAILp5iX5xNmPGF7
gjcW59pKt2Qrn7vnwhWQ63Z39ta8HP6ePI71JfesQqoYcpBSA8AmFzMf1qI1uHz2
7ErMZ/087JXzS1/EfWz+HieVw9qNIkgQ+VC0HOg62kSOuyGGx0OlFaSSRqrkQBa2
l5wr1Q5Xfy1pQTbh/5tHAygoyKtL/Xnlgi1THjm3FM9dv+TuX+phlOCiGL4to09Z
Qo7SWTIezt44KA9UucO1/gadJ70aQGrwfgvSO+G8xE5x+lcGeo+7NzoXvFsi0s+j
9eTGqKPEnw71QadHcPTSkKxTN0NE7Xwx076L8bPZ9m8ANfnfKX3m3i8tMSfSW+6F
PSqPF5XddstKumMgnP1oWtr8G7Zn+VyShR7G3E9tmtfgVzQsrLUHluUZogE/ESfw
AeYeJjEoRkzLwRFCKzy0R6BEzeZvZfZ0xv+s38XgmKvEpE/bVplAqDpmFaWpNcWF
Ru8sYhk8Cdyodw8M7YzSE+sqGI4OKHHoZdV75dQof86i87NiQiesruNAVRwbXW7x
fMohhn/h/mhmuE8nKssOyKahZuFxL1ich1gkQPdFZHvvwynRBdS/e5i/6AaaBIBP
bR8p9b8hk3ni1xPjf3lHM+s8LvIwWOC9hoOSzaeJh0K6n39T0LnH9uegg/eGrSg9
hYUOhRon3mkfbIm3pswVQL/fxjjfwRy1u5yT+1Sxg7JfShqilW/BxEVRr9Vxd+rO
5Cflt4nrXlSTPZrTQSnGiwNKHhSFBEe0RzV+8w1yfbi2NXVWG0US1iKg4p+Op354
0kJQhKlWcJRODiobUArS4ggIcIR5w/GB1xjpY/MmP7Ow6X8ZkybvsDzXK3bP5UME
hPRFCZKfj2muvkYTY4dNgUhNzvPf3WsIbbgif6UKDDNPoTTUK/GXMfbPqAwF6Zwo
mAkIN054CU5DC8H6Emh5/7fLohI0Z6HQGUV2LETHFcO72lREtIo8QySjIPWGXQt3
tifo6++SzquMqk7Rekps+tUpor8nVcp1ZDq73IthGNtLY3WhuvNoaC80cno0mcjn
hPN/CggFKQcW3OCS7YPxjd8pbeBpt/4IZVjpp44BYGw572Gc3lBCzVzjxTcwJoN3
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
//pragma protect end_data_block
//pragma protect digest_block
ccHJ1CIvmCRS+nbWgLQWKS78CiY=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
ARIzM20qvQsOhlemikp1MkhOGVvOqdCptklMFViFENgrk/BZmZ/vFkAL+ZtNt+Rt
gKaoV3CumDZiaq6j1xjRczEEuHtJJdWTPTpDnzJNsuHqOJA15YIcT7YAiS+pDPrH
ba6+VIqZO/0yjRlkoCPVqy9LkQ/xrWMKVbYMlmy0Id69u06KGbU1p5j4cb76uOMu
4bWZZrwVWlKStkTuJxrQaxY4reE/4p1IFspfvCOMNbfhGS5T9NLNuz4Ar+fLhiG4
h0eIDLgy4gRmRu5lYBBfFDJkzEwoXKCyIu4bc2aTEbIes/iyxQmnggy0jAde8A39
TdTlABcW1iLl/z9STeHQ+Q==
//pragma protect end_key_block
//pragma protect digest_block
n10L4UZBiziO4pZGJcyPwOagmTY=
//pragma protect end_digest_block
//pragma protect data_block
ks92l8Pg0utWHydDDfUWK9bco9hKy99Ce8wQI89GnW51fDBoSkKipLRroDYR4L4Q
KMxBd6gEhA6tCEBZ5pXXPbMQVWfaTgWvgmvmgJM+Q87n4H2sIERbqjFxtVA4jsAQ
GKjqpvPoUxomiwwwnkEhSBcn4Ln/INnrnN5uwLCndauYhelZ6qq5wwVTsXZ18oiF
muvBDozzgaFd6dsWb6tMSgKGByOe2tbPQ3Ze64+pl6wB+UsLu8Nqrx1MybBEYqhd
XpM9Z2OoRtbv3goP0Q9FMC0F63Q0/M9t4ZMaR788I5ZOhgXiPyeovcj0cB6JgEV5
fufSyfhl3czHHTjcBqoqKlwcS23nyyugFwexhqMTa9oF7U2q8qancROWTSHDIBzL
IAy4xMe/+jC6iDSpG6X3Av7yKHUlT0gErKDciaW5NxJl6yoTx3Y8wF00QiOHTSjT
7IULO5VkuSn1wXa5uSOzKaRV+7uLVS70BtKW8IqacaGerzIohmYqxrtCa5A8tKSP
epAJld5IzBrNY430eue5o45udqkxEu9fcm+AYLm/w7lErz4Q5JDtoyDFBlRVJMXb
8PyqE3cavcbcj52fiqDfpO2upZkj5HXjknZV5vWg3ed8CC4ftVuMQjYJnDrkMtVL
a31AaGyx1vjrolR18SJn4AL46lDUF57Vfx5qPmX6/yczhMV0n5CvtwonTEtHdsRL
ceUWg+UakzBg9U+v9SOxF5G4q1dK08XqqeIWp3n/B8uy86/eAcsSZfMqGoiQ9t3k
qZF5bmYZU4a/brz5QmvqEPpEO9H1c6H4D0Y01gxeVhIT7kMyaUsLXoLx8Ou4Fcsz
YZ+jQGqXlXkMwjKdh/NTbPjZzkrwJF0JsBGFY12Sked5opcpjQca3MjF4WB4lGSB
PokbR4TTMd8r/YYSFm5C77f4HqTUUzvcUQIRUblxO4P6GD65frrIcK922fuEYvaz
//pragma protect end_data_block
//pragma protect digest_block
6Z3kBITlGBQ1queo/RSCimERKpE=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
Atz8tucueABxi6tE+6GDTFGVUzFguCPXX4a1GvHwgkopw6puuI6B/bguieeIeHkL
tgEqfHMU6A0PrYo8SKDzwI5DlGQY/DNWJhbkmWmo/igpJ24aMcFurAskETQkgSIw
IvhTjwwxL0DMnTN0Nn82TOAVMnrBgcDSPDk3+xiL00APePbf79ybpd7wV8gc5FE2
VkXmLpxK6HxOdbeNRXpD0EwIwh0rz9cRbRNhKklPnAhKLokzOFTALpd6HxvLxg+u
PXAhC0TBY0AfXEfxX9EkGMTXSRFuL4e/Z4hvMY2GFC92HLrzm+zpmFYIIXpSdqmm
mJ1+NJbHvwYN0VTqmYim+w==
//pragma protect end_key_block
//pragma protect digest_block
Hr63lrg3B3IJZh8a3CEdfiqq8kk=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
NoNN/+HOL/6XnNdLy3d9uw2O3HQ=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AbCzhd0qNN1a3YD2COxnxD9tA4+Q8AthzDbzjUhGr06Te3TXX9nYsgo3lUXkiQvh
TCqgcIyaHSmj7N4taHx2OHQM65fqZ9Kxlkmcs4uwd5L5keLAE/xHBK+oOX+mAu0n
wi9qZnDk2POmSmxaLIinPJJLXmbOu1tKcNUqryv6jGSZqxHFGYNuIrCWEPHGhH8z
ScFwZj1MH7MLTBso3FGbgqoMfAGglrHtPPIRqQToZJ5UyrJ5OnliZvjjHUct4lAt
oxuezsQeVftgh7ARe0q/34Uw5IB+tFu0T648sWtQrbOuK2lirrsT70RyQVaFNJOB
afEEkSjZUwZJ8Gim6nx7fA==
//pragma protect end_key_block
//pragma protect digest_block
ANmuh8+Z/fi0NpDa8f8OOgJt3vE=
//pragma protect end_digest_block
//pragma protect data_block
W6sMrQihbaMdI2RPKLIUTNwA3Gc4uUMkomlzSKCIsSnwjupA8mz6SVNbXWxoov96
Wq6a1C1N/Dm3topALugkZTReuwtDwAKkfPoY/lqmvwI/ZbudZA8SPZ7O5w7UAHMe
sOgMxf79xE5rvAq4xKQnAM0VLBqegLEUtz66mw4srVKttRDNIhNDpaJ47ApsJxY0
SQs98wsAI8U9feEarxvg8T1zgq5eiO9dPIa8j8lwI9bOmA1ZkuwQZ9L1UPTfDf1A
c15Aqge5ZRwClqgCuP4LrrtlPbdba15wIXIM4SrZmkT8Ymb3H6prJJvzW+LFOfTt
7JuJ4TTuwrO0F81xm25CnwSiYvzR4UeaGwMfhjU0wBKcBOD0B4XYxUVOVpqw8CnX
w7Pf4LLrSwmUMgRCHfTe2wSRUlT8/W5lGXCCKzTIeFc7e66Tv5F0dVQoTezOretn
IdrxIs+FluvZltCHWNK7wTsCYe5ZF+E1BYE6+PPZrnsEJXa9SeeWq0cssknmR14T
miF2IVo5HoRSlCrEwRGMa+oK8DVIE0ohMX/7YORCTp3m8Hco5S8vFq26NBv/w2m/
asV+1/y7N6Suk/PnG2VEwnjlliJf0CZTkY1Cgovfm6yzc1diAXGMxKdb0HTlPcKH
U+4yv2lrROslwGbgT99x7R0pecjwY5Z8v8jUn2xowXnuH5mtNAUIsWsT63+/l2wY
hzujAJnunUhPzEpiSPMlgxcCnQnZy33MXUf1ZtkooAtEfZt98i26L7QcAjDZx0/F
hQW3sMRyKlPh04dpEHWKW+lsYwXVPVIou0TbEVwnQ1rdhJH3aq9pHXc2TVBpLjjy
zZQg6ett6jU87uoffZXg0TRVVGGMH1KprdoGZR3XRg/L30ED5H5nBQ7l4Yuf/7eS
bXYec6xDUGxLDKG87iSacHYFC4hsTd2HRDggVPwAwItZCP2hsO5nrYWIgod/3ZnY
OY0gaLqbF4/fZNKr6KQUVDTP1VP1iaiFVYLNDHZ3Jw1taicnfUkIgpuOcieXHL19
1FQi7ljYZDHDLBdg/UpR50JWsGPSXrFFCyBAZdqu+Gl+doYXRD2QWqCbrHr4YFce
v0DtSjB9EUvQXQaUfj0zBpFBnmQ3alpUu3TttlGuRRwfNtnf71DclD1tqwPVF6Ii
Y+ovFZTAl6984V5t6Q9ioZWc/Ru9tB2K+Cl5/pkSCq54UMVJnYVM+aa6P3Ssb7dx
45lGpqjNKrfQ89TN9eqo63jDAKCwGFiuPQoUxDunlJpXonbZVy/UhbdtMqIW5ESI
33D0BeXiqgHE+KCNft8aBJFM3tQ8/ZoN4MzD6ZCHOuurrxsGUz0aS1SongSJFfQX
0GBsRwhzaoEgkVqAhNEkLJHG45LSLUlklYLeD5c4KWZKSYtggqLk5g+TlK72akQV
eZe/gvQQJsNIVq0A5fQoOWXoRXmKYtBSfd9VlXxbImc+Mm6OAHDk2LsYG0qNJ6hp
hPM/c2+wML7iK0uLJX6T28Gyw4dvKYEJT2pJn/RlVlggOV4vcO4VDaRLu2VPO6DY
1ne5XtWtqEEmQo6qcjo+hNHKPaLmZeuiHLLfSi0p9BKd1E5PwRejhCDp2Tl/ohut
pGAxleOWkKh3F1p5lB5/oRievr0g3KiIskFHL2CxJvG2olL3OBmeL4x/QxELGj8N
m+1cKH3PsPsIbCPjDFFVLC6dEYQQ4bnY24/o5IBwxJDUm+gaiMRVX+JaSE54DqM4
VkEMQ8d+RTEcVlORJOYYRs7bNdH6s4bIz3rtH9cZHHRIBQAQzhe5nTtWWMr01dXw
neNWPmRn4tTkXzQYmqazhY0JBUBQyyIUNoR09Wg/kkXaKaNPCxzzpoa4c5swx3Ct
WbWpkOf8uqehUOTyZ5jnccJItbhFwhV2SnbVK5RMEn0=
//pragma protect end_data_block
//pragma protect digest_block
d1Onj9prOJmn4JcwcCCC8cvvcYw=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AsnvdlQQG2G/k9b5qztkkW7Dv+FAZiPWR6QAUQ+DxyO86/iCpkBlRR6oSVI7Og+p
9CtGpeXkbt4RrFe90nWZGjqvKgB7RxmhXppMUa7bi5yTGg6r1eOI3gAVzAd0YjMy
25rpc2ixPCo14GQPh++XOQ9s40V4LBII16ArZidT3TUwXSob65RLazB/eIV/sUNy
5eBEKR7/xyx/F+evqlp6SnUvcfFe0SuOopPUCAACMa/w2N6o2t6qUgzpnKjvfpyy
aL6wquWnMYxt1ZWghTs3ESImUnkDXkLHeOrJnpqOt4oal8yNil8aDRGPYogUCq9v
nwUaPfDpVSeVWP85S9g4tg==
//pragma protect end_key_block
//pragma protect digest_block
I+eFsI6owEDO8y+cCD4HefhLDZ4=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
D7e/03/mF2BL9YuHkWwHU2Ux1m4=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
Abb/aU6vd4NK5iXNnimYoWO7UYIoJonmB0a4Z6SFd+HXx2lY6uqbs9SGpllvwPAM
Wb5IV0DhyUtyh2WTfgW93UdYA6et2F4f4KFsV1HrIgx6YyTvefxkddDkXJ2Hdt0i
DVY7dOwl8pi5G0G/iVLsg++KpwuRAqFdKMIQM5kdDn7yvb9J4fwdXXBHtykep1+4
RrEaIf+oTgqDzfalR4V1G1WlQz+6HOac8ohOpYDiASBMMrbEZBkNnw4F58YLsweu
ZFwlILhLIQ0p8ZXVNlvdC4j03Ir8B5UguySAxZby07M2EMi0wFLqi4PD493fVPKz
iiVHouTBWJlaPEyX51xzQA==
//pragma protect end_key_block
//pragma protect digest_block
pWD285A16E48GpWKY9w7PswvVQg=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
q8FQ8IPkH9SC749Sk1McZpJf12E=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AuMoHPX8Pd3mqbQO1GA1lDwNRW4jVDSCCnolu3a6qpNdY5kHzBOGmD+lMc+C6ham
DMiMRT9V4xdB/+OwhRUdvnDdS8ZdNEzgQ16Gp2C+bb8C8fxGtMhNxkoUVWf587Kn
BgG/gBlTbJeO63zuzFdgGYvAyJ2VnKYt5wWMlOEkPu9ltYfcrLIG3R13kjyTD1Ci
XIHkBgGaddrqRpVONdrM+FKVtXZ57ZAqBgLbG6DP1TCMKkiChSMPG8h480WRmgKc
dQ0b22rh00a8vsr/qVARmzjRyOJSx4rgZOEhGRcQ8evgL7SOZxu3JXy3m0oErgqT
QVYOONJeCKkvOy9Jgs+EaQ==
//pragma protect end_key_block
//pragma protect digest_block
8qSCHJneLBb6XVLZi9bJi6+NcUw=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
fISjrQLVTMznoejKTXLxneEH1rM=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
Alh+zpnsJ6NtMNwzGSTrfbMl+vFsUFiQe7E8ZGxfpOO4gXH+R8hi3eZ5VwT90lvV
JhwMoeTUKOhlOXbWgCgWxu2KaM6oRZagJxI/qLkZbLXOlM24Altu2z3sJT7Ymbi7
SifwsoPrd55gSeSnwTmdwAU/3m/+fyVWBK9zo5tri2VJTLDpm2DCcT+5aerLXXPg
ScpwP3go0xQ69IrJdZ9wx9Z2Qb+mbafejlACthfrI/qHqz0+KfF7JU3xnktro9EK
H7agWTVWTyfwEes3oAnLjcgrxQtygl2JcZ384L7W2ohbVxq0M6xNdZ4dc5E1Jd/8
wWwZ5PjU8hN3vfbePgjZkA==
//pragma protect end_key_block
//pragma protect digest_block
TtmbDmxdMg1zJG/PERb8Ra+Pms8=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
Dp33pnOzrjzNeFbe/SSVyHl2kAc=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
ADDkpHBcv1QLYI/vnbFUVBLH/vblpSm2j60Iblf8+01HHOD98Yh22bALNGILAwKs
9gQVwKC2DPK94E95kFvX/0oIAboT2fXoRjUne3mjg9Bgg6srz/UjPaq9my7Gxlp3
mZIJKplYwCFZQ/vV7OFM4LSihaRrcdzBCKY0fkk37axv3XVjuxXw08yClc1SWhob
1iNAzAl1o5YyjeSrMGjox8D3NalxWvLqTkgGJuZ/oRxlAi+t/rk9+Nec8ZCp8IrH
6lbK/r2RCMcJ0tI9SuPpOoahoEYRf7IdN6CLyP7Hoi4pDgDXpmj98vs8cRlUhfr4
46L2gqFzbwedeQRHmEcDRA==
//pragma protect end_key_block
//pragma protect digest_block
XyTDHV4JZRt+wfV76/WwR7YhVcs=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
nWrq3EPDMtEXfKvYGGpSQArDy4k=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AXMNUgx+35APeT+Uh1zoekyaEw7FKPAaxxyAa6Q8Epve4926p5t6aOUqjm31poWm
YkzJXrFJDf+MY5a65f9vjXEYavFbWfqstM5gzpnVEYrCosK5VL4V5haz6/0zm4W8
3KFU071+dSKb0Ufe4/PRgxBz5L6UD2Q6qbk8pFHXdHqOsuoYxm4jLa0FBY4eoMeF
B3X4RqxbqpDnTDp4VR0rxrbeVE6WR8yH7k/V/F98ngoo+vTi+QAfgYdJqZxlP6nx
g/VBlSVclqWtZDmfhCtSKb81AWK8TVGSJG8BSZvZv/QruxskN8UKeHq3mNnFNA0i
BAQDMmBq+wwHTXv4864ICQ==
//pragma protect end_key_block
//pragma protect digest_block
9CbqG9Bv4IqyciYIBinQCrA58GE=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
U9YB8/0V+ciChAhgBpR+Mjh1AqA=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AdFY3ddNMI5ObsRGTGZotARFS3CJ+vRLMss+z4M2RCmeWnJYSwbOVqDZT//3v1XS
eZCzvuRSef58imif0HkcVPAPNYx88rZ5R5Wx/QsXAvOU+xzC7nw4m79rzsNreJKW
TECIEiIMrfMnM8TuBS4RJ8ixg2QUxCNyypIpEwob+xA9sLT53CWnVC7PL+RGHtbm
dMfCpH7nsJAzmsF5GPYyCnYnSLmABwHoG3M+7cd1fRbjm1u0yGMCX/Vsir61hSWL
MRns9UFy1BN9D0IV7AmqeDx1lY2NfQm/6bM2X90oIAQ4R15r3rNgs/KRoFmNhAfo
l9LZHRSmPOz3WQkMiwp+vA==
//pragma protect end_key_block
//pragma protect digest_block
LMsSFqJZAXHDtTSKQpoQfkCpEXM=
//pragma protect end_digest_block
//pragma protect data_block
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
QlVOyLz3qNshjbld8wsPsg==
//pragma protect end_data_block
//pragma protect digest_block
Yac1UeXsmBvviCciB/hrnaEqr10=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AbhYTtNJq/FK+w1fFKm+6xLsSwJOb+mq9T3w8qXIOEgIUR34Njn53155UJnoKrVk
evQKf3BDVcJFLDEZFnCWmDCVW7pjhfevjP3nsAWwNYyEp75//Bba7WgJNlMzpJfT
SrvHXafsyhaZR0ZyxMM7Z2XXjvjBnjZK8vYLfi0J1br/pcztvahh/83ZQLzzfd5S
lqNwBQNiIIxS758t26qAl9x+srdZXs1gKnQgWogadySoK5ww7L7eG2yYNBXrIgnR
A6b5wT61eo+qS+69D8BjfXZ//UskIbXEXsm3bFs9DBhUZt+f8aJgupsuOVODnQly
2epty4jyyW9j/bg7csrOfA==
//pragma protect end_key_block
//pragma protect digest_block
Y5+OOUWvj9rO8MVfeQiy9t9WFcg=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
B3TkFI+3N0Wc2L+4rgj86RNP7kM=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
ANaeKJ7tSaIxxZfCymrxd1tPx/DBPXQg9P7ADT/kL709RAii9I85IereWkupiW6X
fY7mD+I0mTNaDYB55jD6uk/Tb/bYwk98jdHLh13Oiftml/rqOBjYa5s8RCFlCzqi
zH9uP6y6Poj227jCJTzfWZJaJIsGUpHvR3s+DzzFkDJQfleeW+f4VtylG3SgJckZ
b2s8xuNsNfcm1Drn1nYh8yX3AdzGbZ2UWhHYzDdqdLGLa1v8P0CGufu5lLcq1K2G
hjyMxuyqZ+cExm67cN7Y7GUi8gv/mX2r3ESjEZrKTWk9q9qQv1DcL+WaNoBn3I3T
nxFVy3bqck4R+XXscCf5qQ==
//pragma protect end_key_block
//pragma protect digest_block
qtP42qWnCaGHeHrx5eafulg95k4=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
6N9u26hVMpcbyyfmRwuCf6Az/lU=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AT1EB0I/npWqScdRvpJcRO4gQZmZ32n55aokvX66dpBReWYyfJe+e8xu3FsuL0hj
xFTYzPqCsokjEbxWJcQ7AqcTcNtY92dNwmIFk+9mtQL11nDQuEcAz+9qG+DzKQE0
wEFxB1EFOwxq3BFrmHDuIOBCt4mqLXAlzSTZW5xJI34SVmPvvsg9ljtOu5ovC1fo
qrj4xbbiOv9JlswWSL87kY3/EAlJB93cTi8uIzDi7mLeylEdcn2Jw5H8S/Vwyafw
pM9YxN44/wv1Sm/j6jj5BDCKjFZ+0zxNMHtlB96vfvM2pNIgnswgk6ZCMT8kyGMR
eLKSDiJKdiLlAm3AiIYAxg==
//pragma protect end_key_block
//pragma protect digest_block
IjTle94Bs2ph1I75fY7zPvZwn7c=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
oVKojFyDpw5GaFjaBy/xgPtTTkw=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
ALEP0YMKgY2hG6kMs04J3ytNSCr7F/iMNJKtSVcQNf2nURIh8tgmUuQpfKedON+G
spusQvansFOzVgoi8JYjVQQzMHgqtriLVUNC6Goo7dbuaEy3NYy5IyBYJ5iwOYdL
X7cIbkKxnAFeMusuwsWRkdfDLft/pCqr0wo+76mQW9Jwx+DD5JzOtHwRCqoHT21n
nrg9qzdGO7eKZEqtQ/fvFHYJr01/zn85jGx+JlaDX6ZILJP68eAUjBLbaCxb8rVM
Yi0+qmto+QZkkuAI0Lul2JJkTYGpQ6a3MMsia70DpLOnt4TBdRCMwsdmtCG4sLmS
MXuDTBs8Hpzg7J0glGHLRA==
//pragma protect end_key_block
//pragma protect digest_block
H0bopUu32ivTFDA3K9T8J8SS43U=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
1Okcq3Bx+b3XH43kFoKz4zxqo5g=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AQeRdzVOqJ4iwDoe99zvboXiU5lXFKDvlhNtq/WoiJqz4LI8dneGqViS0qW8E5cW
dFrNY74BxRuU1zUyWX2q7ND72HLZ7b43cP7d8Tx0UViZ4YnpFDbDdItwoawze53j
e7dyCusjEq4t/mD6olfwd9QnMg1orJWxZ8cPJ5j5xikDWP7ePgP4c277SWzoxnac
zaPxeAhOFGBJeIchq5UPEmXGUYcv58Xb5AlMc9yeTKOd+qgNHT2a7+6pvw0nC/Xu
X53tQILJGS8ZfJDFjSphdOcpjwpyF/M3/LJvhukvC3FT+TWVdtiq9wFcgfuQvGgP
b2syN15Zt9silhfUS78i/Q==
//pragma protect end_key_block
//pragma protect digest_block
ITI7TKpnea8mGeIScDpwDiMkohE=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
GB4TclGiedNPwOlCGOg+lt+8X2M=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
Ansv9YAwGh1QaXL1XvJIO4maHH0snzDgp0De9+9uCOGT7CK9+Roc9kV8pfYNuPlx
wSpH0ULhTI6FHPRKT6sQFmLuiJ6xFw7VzoVhPmHhpZSF57Tnwzae65R/Q1wuBFsS
VF8eDk0UtJJQ46qXepGqz24I13aL9v3MvqCcL5GprH5TkwDCgArozzr2Iwg5KsYG
fwuEPi78tJuSZd8J+iQ1mJhN1xRT4EEGZq7Q0SEJk74s8r5DQYoVZLfrqtInkP9i
gBebjMdYOLNlwGBFQJxa7r6QuNiRihf9E/lxc9CsNGzgLcfF4KFl36kNJJcMORRP
yKmksiA1VTS/ApNZ0EH+uw==
//pragma protect end_key_block
//pragma protect digest_block
0tRm4qYvLsm4+VVCglvfy7MBywQ=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
QmYdJtuhCo0aZM4+JP1v/m9eIME=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
Amajp3mby2UDUQLdpbYiAw9tFvXWC0k0x3RvEBRx1c7yL98M0GQX9AuQAM7ZWGKJ
cFuoIgVye3DoC/kXHvDRAzLJVaNEIXzaL9LtEBb0LITuFKpVhVAiUouMtvCcp0gm
C3y/rHeZEZelkSb4CpYPOF3H6YmH1phTaLaahAXTntOJAvxxNABVVs68XwhFaOe+
KEuopJkLi3hkRYWeaEyhj9kqC9IBrmXHUJYQ4qcIGIAl4tgHZPBv+0C35Cyg1Kqc
iW4Iczy8v7iNdsFAB/MxgW9Q/RNowBYIpnf61pXBeMFbwIsKxe8bTS1xu6R3+/19
3kwGS0I922iDeQiFN3Ir/w==
//pragma protect end_key_block
//pragma protect digest_block
6EuaYA9k9pp62W1ll3O8D6cdfeE=
//pragma protect end_digest_block
//pragma protect data_block
2P1SP5SmTOE7mtxtJo7zszroKRkk1HUMcgSUCN9R9oRHJ1cWYMYtBi7Xj+IeI+j+
rm41BpMtdSTMHzOQg7el4FoK32q1TPwHrqUyWfnbsozT+29fKWwaL7u+Xul0ks7C
AurHssgNXOb8BXqEVSPTL8By2mFKK07pTIf1tA+2hWYJR62nCP84hT0wueFva4U8
4Sgx4FmDf4GeDiKz/V2GfaP3rhKeB3TZWrOe7TYiAYtORG4O6Bgt79RzKGQDL91i
D74TLgVlBK8tUFtFkkGxqC2oJJM7WyUrYiZyF8NLXFsriSzCXSFFFQPHXPLDL1FD
RKR3o/6/bJBlAXtSK3zocvxL5gVknEkUSuRQ2QPKdybe75qA5pj1DlgURyXGhQCh
jP8odgxgBFLi0agq+BZfa9h3PZxM6tyobMhVkJKVZ/61Lq9wpHRuwVjlifMErrPq
5fvNWo4R1OHZyCKhf1BRXl9B8mR0KnRCJ+LNNE3CzLvjNzAZoKmpjr8hcQUHjTrm
xfFkufVtjwRUJrstnfmmzieL6QW7b6DGYsezEeEQcm7jFPxLNTn7sRPFb8dyS+MB
imyuWHrydo02j/gTWXYFv95/G8YZ6DnWwgMg2pIMvEnI3JP+8kzNQPH8YF6JIMgi
XS+XG8+0dGIA/FKC8XFwYCZIcS/p3PgYWH8S798Vdl2Ty9bo1Qx8SquB0d35+Q/c
Z8cH6ZGk5tJJ3tE1UqvqZ5CurtjQpDbfU6sMocP+q2PjEpUI7xEvK3wVp2dgDcyC
AriquFPjvXjBuVYbc3C/acE7JFt8Sfw9YaLPfm3O4XVlJFwNRch7GQhEs+P05/Jb
c8VVZlTxV1iPBvbKWn25Yurr1oLwf/O0BITPFkwTzC3oUxXKxY27ae6KYt/0ezuP
RCnpGnE5oDMRIpqyWfNgOm5FzsTgk0mW9PNtiBM7dylh+aI+3MTRhi7yOF7DVrA3
2+i2ySBjmhLxZUa4YdPOkAsuYMS66+nWeX7eCSvaiwzUX55kcf13jkmLaWL8J7Xo
qj3NqMxvHtipE7y+tw0Eqomxc511UBNg8r2oDNsG2Vd0axh812IPqBih30Go7obJ
jE4cLE/lMTta3jKhZmDLG7qMpqOYs8TyYw3Dro2ijonvGRjPU8YeDcyvDV0dO4QB
5qNV/IJh3aUvug0vwfpnPCACmfPsS4lW+Wnal4HEHzA9vevbRfwAdCiDFdm5X4mf
SJplQQJTIy0/hb58G7wDbKnTIbKJq+09n5KFMzKucUr1NDk4wqJXpyAcBQxlIO7+
ZFMVearQMMvadzYTt4b652shufiRgFIWUfmj3qBr95Yw/mNktU6mbOlFJseIwy0j
Sf/43za5cgXFf0ZqurDl4s1+eaSkQWkmDtd7l3uoblEqPdrj2Rms6xi0E3W8IRTd
7x+7w/D148akJN3tILwi8w3vj1cU7qBR6xEflQvpOJqCjep73X8hO3t3g3KzwRCw
XWEA4EUS7AF0DDfB0LUfNyfw2+13fwwZ3PUiniFd/Yfm/wv49O6ndLDa0p5H0pVQ
FJodBvYjgyF24nI2RE117sYjulpO7h6J83aoc8xpPm2AjK+uChwfqFCenmCFdzb7
6OyvZKNeE6L7KLFDDdIMUR1e9WQc3HHeiVHuTcrPVejDfDVM//jaIKCdv3zIKI5P
ud1xLhoL4Wwqg4e2eUa6sQ4NO9h9Nsun3P8PdisAxXWvzj7lYpipfwTFlzp0QRbn
CCyQFRCU6iBgbavtYiqh72V0MwMX3K0aHzzZfZOqgAJV7uzVQrHM8SE5asja/Og5
l+ABgZkKbuBWWhEHKW9HnpN2quEIpEzJrUZgXj2HpJFpGz1B7PXh8JjP9WwxYFFR
bNF2sWXolbXB1Gi1x1C91D1r+d6+BWq5j05NkojEqx5ZLpr9S0BzpTfo2uX+QsJu
TJwSJttfJg6GFOTqhEV35c5Tx1jCEY1wVKV1EpqXgdQuFi/f2HiQsQ9E3F8Z/vab
YvIaNq+DQilQ5aVbZscpwC4GMBUFbj88Z6TllBkygJ1rLHISNmpXsgRch8F1QuGs
tYFYn92x8LoGowkyFPqNJZno9z/90H95cBsQtWm4M58RVCwCttMN7j2p/5VM2ybU
5rTiFRAX/FMc+VJ5h8IB7FBJ8ljuFeK0WhwtcN0zVB/nghXITRDnWLosOkTCsSxr
x+pq0SBv0WPxoZk6Nuq/EtVDUweHnDz+XGRGyKk0/s5j9yiEDSYZ2/Cjw6RR5uRo
20H2tOSATxmRGXzEF+Md4RA6U2mpuwtXasZA491hK439jVCaga/qhaJl/Fa1nLJ3
yRU7CCRpvT9XAOaDrJiwV/4CRQMkM3gtDDVdr3kqVM96SxL7Pi9Wv0WIf8Je7qD1
OhTW0FBfDpi+GPzEMCA6KMwkPIfBpg/lctuTtKa5y4JuSo78cSx34eWYkLN0tBtU
paygCDHzXOG1pan7WdZHSmcHF68oMbsX7DxZcdtS8DU25TRlG35UHCv2fym7x8lA
5PtI9pHYLJL1JOZHVcoAtKkHd1ZcIGhuaIFquEM/kY31dXMMWKW25sNEeDF0WY3I
wTeiLBDS+xcPyZzF5WTbccoVSau21IuYCQ6tYRTsG6rIFHUdxABPk3CtHyYEhFSp
UUi2vRxFvD9JIWmOvsn8joRHz1QNIwaH5ATY8M9++EJF2t4sIpv4MWrCJfF8Ao87
rQL26AXu14Jy2UhcgoLu71llPikX6rQri54EmvtQhzS8Pd8n86TpwCtKYlEhcAVT
aXfLhl520mBnoVFn9OaXdczxDqt4GBRjuFtGefb1fzrxiZhYiQs0g1CaZJxQv8ra
uakN19vAlTR2yDmkjgUJ+ijkLJw46HRJbTD68TyXhyjWDXhfshPYBP6b2X6n1Yg7
BwY+u0p1G7c2Rd/xAwf1/37NoBjZ90SFpuIODwKMUlP/bd3aun0KaN3j2AaypRS6
nHoqmgZsZEpzJTc+L1L4ny34DB7ubrFwd5B2E7TA78GsYCGmRflai/h8m0pAuRqK
XldhZAH4WX32r7454/mI9pCO6W+iv1S2OVX840ZrLiHpdyngfS2bcxV7A8cLVjG7
NQEAskZDxxT2JxHm1giYERV0BcyrqwzUNazY5cAgT+kSfkN31sI0oQDOtLB1yJN8
Zqs4UT+FASLzgpvcGkRiqLX3L4I8MWOm2OR7zFXmc/ZozHmEdCF7c/a1qh3cTmTu
MhbKetYXsbNkXAPLhRY6Hahn0V39o0GJj2sQipUeKlM2OfuXnFlERt34ETmxn3ic
cTmvKE26Y7nEaLp0KxPrp8k5Y+VUJDuUAOq/c3F+AldmybQxBet1PENMunz44i8V
nfH6a/fsQlVToG+yvksWHI7U1Mc9YMW0eDKWzXIQB4i+qzOqzscKjc/ahR5wW9IC
xAbMpsPhbh2pWFi/OkK+9XohVvErLDGuYTmEHAhcarZquamxVdr7CCoLKbBGYZf1
4X/adjVJMZsj0c3tu6krLNUy83NCHcTVejMkrgsPEeafgnOQi+7BrtXbkzijKIyz
BMXa3+t07yANihqk2b7Kkq3aN3qcdUtWnF+lj5tZWXBXqha+DmOlWimSW1B0Ps6N
T0uTTxl9pKWiJjKLhRG4Ixn+toC31fKdlbkLagPm78cT/6yDXB9C0oTaWYij/zQh
aVv/XDDpbhFW5xsOzIn5DemvG9jror22aJDkwRcxLv/XVXU99EeMwEGJ5AtTisT3
TKj76hHXyB5kTQqQH81iF5aTunvuQSyTyeuNYxolDJMM7yDGtMwzc+eoe1zf6fHG
XsZmIYbjI0+Mw9elkudWEZT46QhAU4evFlwvs4wlI5pvf5d2MwEDxBAlFZz9zPgN
bx7HyxoBL5bSfNrhgDTxJM2pIKiHtS6u4raRH6/Njf2AWWkZV0/FDGixBH8vLwoK
/FkVLrTuay0z9h8/j1yTdDeHiQzFd7YzyxefRZ0RLZcJ0r22eAB0EYH+/tuv0Kju
/DhkbnXGq+py+VvJI3nqQDXEFc5cUPmpw1WEX7C4VkXVOm4QLwLuex2BQprlMJDS
XAeOHIhoNRiEG1BtSxYzP7CPYQtN/SAJ4h8Qb9Ah1ur9G0w6gLGqIAwfj20F5jjv
VPOvdx17iiFPPoSfIYQlGDM4Gac1UjH5Uc1hZwqsAqHze+X47DU9+8NbTza64HxZ
QphLBiTMPR5uIp39eRbRd2k3QHMKPFWONfdG5Cwi0Z7CmYMFtl4cKoTZzs2ahLrr
wW7n6Iw6UIPQRZ1d6ymynbWa+3/ip68PKd2wAYuDz5835dLjRw3AHw3CJR7MHYrY
8b4Q5U+3SuD8dMqGPIqfKZx6t2lXCUjV/br1O+evnZJCfg64Y3RNHlzaA38YNnKG
67ueHCisslw0h6ZF11oRtPywqm5RFuZdyTrBHECZNVLU7F4qyFz5H/e7b4hq5xDv
nVCk0FMPT54NoXtWdxOuTD7sscICBM6Q+nHxIgmKGdCKjEXeUOz6FmfWOIuJxqQd
ucoGMKzLX5uEPOEyGYAmuUKp6LFCCX7Muxgkha+K4UT0sDk8/RyV845MSHRt5qP0
LSi632AbpcVOavbcnaKh1WFdOtoWcRJX8jLVYBrq/EJ2Qzj9PeTQx8vKOSaTHPnq
aECNk2/wC4OxfSqz5T9sx1uu4Eg0W3blHjDjO6iYT6wCcT/7PEqpLqFKBoLGpntD
XELxIpHI03tm4uHgX1cTT2+jkr7UibWEmInP/qnzcaA2GYwkGmCgLZam3T/demZC
6qChI/Id5G9pUdeuTZLddybqjpw/8QO+acSfXuDRP5G+v4CNrXRU1WZgabbBpYfS
LWaUeUaAlAtdqf9ObKCLTc0V1aIoFjP//jKFdf1M0hzce4q7Tsc6kxuNX28pwQRD
2KqoYB9V50G0HhzeEATqGBTfSzjsBj3x1VmY9YkcqibgFpJndMq0MoBppUjnc3Qt
kBUuPWbFih01R1b6Ht+3EcSAZv6WIi/e83IMNirgw+zuYbRSn5GapmLhV8Dq8oQo
vLhUjNpUhVLP00VddE9/Y4nojU9KjS/59T/9+8ioBVnjguipZ6kKvcFU1HPmppA+
k2RcwnOBnRs+SWRgR9rGJ5hpA5hy8EyjbFwzfxEAKAzd/pVhlErdHzYIPPnNmwob
ckCU3QSxaLLCJ7oOcdEprMFFBbYTm4/G88fzRktH6rq7o0rCMLQKvr0Kziv4X3LZ
9tVcTXkDcBY/zJNivtC8e1A4VO7keTyV1MkLbZLeC1rQDjq96xAJx5s4p19QOJ59
wjwMM3PHrz/Dg2ImChWJJZ94o6u6teA1XpgO5Bg+y/u26WRQqhb0qZWdqF3FqaAC
Qj5GNVF3yCmFK6eVvZEOhHQenPfhuGZvdR0knwwFukXgrYb3DKAY2WparKQtpQh+
MvcTXHW5HjMIO88P2kDSjvBL/ktRKPFbe1xhTLzhLYE/Tm0HMIrzRGIi9obYTaMm
UYqQYysMHLRLuzZJMOcUYHldHkOA4gwgkBwVhMGb3Vl71drTcYDqUsOMvWLWPJW+
gpUEE9MiGn4hT97unKLHXIyBW2kg7c9gQkEQ23WWJ+GAojmDlC4NEUKTXGDyX/Xh
f1W5+F01+w+o3bZECblKWEuc07RlR5DJt84jkII9LmbNUM7vMjuQJKvJil6v/182
iz9bN2DNCMiVZtDgQSla41z5OgYCg52ofjiZaOOTvkg+Xl6V+k8UuZ29CdR26jRZ
ZtcwPsEDUts1OwrvD6KxeMqgjyZtu553n/kT6Rb+pq2MMiZfoWq72xnWdBEp2nyT
hLz5nmgiOSALf9MSvk0nL5VaGTZZCoDGQX3boyKINBC/wNNfEpaYAc9GN1HiLYzB
nZPFkmY8Xi121pH0gwqgSe/1Dk4vsiRfV2nvAVX3GqOfrp0cqXGCT08Xtc9/ibcf
XYVEHbNugWWShNeLF4OSfpdSjcAXms30pB6FZSqkCXsA94TD6ePziDt0pn2WKQNs
GiIPHyWb3g7YbgX2H1IgBYeyYzw6PCMJy2B5jOOa+cA8Q/CTAAzsqJMPQlRCM58r
EdPr1IxHHJUruGGe64G3MAvrC6jHIb2tzbWJ4qAHcev6ZfPKWWJtX/WS9ae3b9xU
usHDDMpnhu/n3APClE/ucjBHkpM9R3PKu0p1UYeAVKpw6ltGZkcasJ90aI/x+HK3
NcU+tGmdYkEQoSlWiVbnoMLsOBAutTiAP+O8KUFUEZDGCjBjHZ5/kMsg7wrIKrD2
bA+uvDy+NQtlrrTToPvnTPjIWpHAhuAOl7oS9ltxjUFCWYQyR9Kok7dZJAwAyG7v
QJDhtVVzIUlAJimX+T36sgJcNFEp8MrDqUj+nKxSWQHo2pFl1bGUhE65skulIwjU
1EpqX4TQYgNuscbVSfXzCnzYZoiAwxm030CzAXVY3TKC+F7l6+Bth9+2tV2wMsWm
uV0h0Vg7PxW4VX+shxkn35JREpt4rQvhtPXpnMpS1rki9jn+/3iyTn8ybfxcPPZt
fQEe2KsYLN17nskTtsoGpMoOAjLGLPTBxZIjzHfijEThbTyQ10sh4wWvfTw4P1R1
/5bqlcg+nNlgQ1Y+Bd9L2IYWjz0hLEnQZaWkH+4f7GTNEU2IfiSAimzfL45N4air
w7U9snKD88lqXtYpXD6FxVKKX18j6aeT2TAkd0OWoIjB5QT+72ou+ukrVLo6Lgrq
vgdSqVrlbNtORfWNQ0zt+8G5BuieoCFGwF1r+yGN4uKIaSpIZ6+hyrh2OyYOorPW
U5jQldBl1VeGEWUmAZSIpfncvjccEH2xbIvQytGSxz5EgtP4VnZ8tcof301XeWR+
4pzRN3idRjpawLnCE4T0R5WYKc0yiE26eb1fAwqgdaYEoYz7sAwpuiJe47RKT5Rl
BEm7SKcxHyGT8pxW27ZjwldG0eZxe2lWjLTuGR3wb3yqV4iJFcfyhFz+oENCfZDU
PluzgcuGqqSZIZoJ/cExKofh//EU8VplDSiTPvomUo+u1YHZVtqzD25ewG16zizG
g5bJ+WQ9BKD/p8/25t/XwIBn4VRLCblpFCKjycpWFpTfmZzLh5InX+j3LqkB3d8d
5vfH3NDE3aToPIUF5W/r09liQaPwvSgROqOkQslQULu+8bQX3XJ4Nd5u2QIdULEq
Cqqdrz8q2042AwatUqAJDcKpiMmA6Qb9reiAU3SDaNtOEcnRLxHVvr7sx1mtoYEq
cQw3gGLqgV5trhBDB/bZ5AmOkFBYYx/O1Z/axt4qjmqMH+/WKAC7v+46yAP5H1h3
9tr/YfDzanJHWo0PnYfpIqjJmprZXRiZ9hAYOUIi6wY2mko6f/dTkTP/+jFYmyLb
5QGBJtJ6no2rpQqDTcuZKHcsC7uv9kkC2U6a5Yz7YQrx5yyGKSJ5mGZmxJuVZi8u
0sPviuY4AW0ItKnAuZfdvXPtlQbL8Z912gA75gfOH8GbyP8TuoxfqeU9Md/gc3ic
G3TxqwOGyh0vQxO9+TfVPV/mXA4CX1ZsSWEEHadyyRDG+L1aZNKrYC1dGoK1BjaE
UrE6OQC+pwjBtJgRu7nxf1P75SCQktA+QL5BGXL+M/Fg3NWF+iAVWhcLc27FEjrO
057HmjlCrNgc8XtGRphp0PQ75Sv2q43nq5BYGCiwUQbwhpvpdR55/rZsZjfS5CME
v+/o0nHWKw9HTj0+kmUzNOORk06RMoeCRc0pG2YuF3kHusQSKq0lCri8huRFT9TU
XJ8itMLHX+mx/9t+qBMR5u2puH6NjsjsItuI7lEp4OVerTS0LEaWk0samAtceTnD
V7WeY6mkiPj1qcTsDj3NBz9t6GdI4rjwZlphBJWoP1WpABwdLHLvLTXacX8dF2oc
+Tw6ZPZF99NFF7kQJFsVKW5Qrd1FKR1N15QVGUkkGAkieD9BOYO78eVnEI7GmHLw
qVanXaIfmovukCKXtz2/0rQKacCMnHcxdZNPq6sEDnK61JWV2VhTF2RTSFD17JC2
pctrIgYEpjtC5FoXBAl2WFIu4L1jwODk6kzL4a9XPSRvKH/R7Ae/fMcXyrjeDm30
GfiXdI7iqN72h5oa66qTzlORtSvLyH5IErUK4rad8EV4vidMkyVfuTQwR50LgkGH
fo/LfOkxr5gKtPVaZqOV8pJUTG/GRnpq+3qAM1jW2XLsp3d0SgEVhHWpo8y80DPj
5YUGMZogMY/nDHP+OGfNcGSNbgoGGsiiI2DiSQRLj4tYIIdS9vDgLBkI2mPzTF8p
a6k2/T6dLrZehYXqyGNpik44k8NMvq9/6OrPFG39+/fI/TacyCiejq6N4RAj1fjR
Cv/YBNU0+IN2kttC1DQGXpOEzdAgM35TrLslmVW1cnfPuYmzMe5QlE9WcWDz661x
OLYxqCJQ4WsCyduRNDib8X6Xh3wyKShYY109tLUbK1lKARBye07JD9jtW6ZHSMT4
k/fPkTSIvhCE8N/txRmUhMx/OiZgRXsu37uT3UjN1SFjP+6AJMuj7Cx1fHFhk/hD
KdZdYfAurEWIDUnSeWA51/FjHYrJPMElhS9YKjMyHIs0WqmbqVsQIlyR9sOsy7KL
vgScuUV0qSfsjPXvNZsSY/oe1j3FpD8rAm4pmnP4EB46mBXL2lpSN3cQD9JKfQZ4
fTFKBpaWHzQpk9yaRpcVgmPcSniccnw4AYR+mDt9VDoQ2KGR/Gd8q+ZYn4DhKFi8
bqY9RkvIG27gW/74dmtuPyqTkabfOt4xrgOy+yFSK49ReVkb7der66+6GreXgvTp
f0Ms6AXOhr2FaymrvkTK5YNdeuTOOqmm/afuq7D2+5305LMC9i8uhhHayczvbmk5
FP1bLRKuWGN+RLfu4vfDY9ZXxyInQge3QKDTlVScD90oc+CS/h5rMfHT8PpC0NnH
7CbcT2Ik5XqLLyakfiGDU9WQr3JGZ2klFA3XPGi5UxqV4dO99U/MQ5+P8K1P3HiY
3Kj5uf5gq6UR6+Pb/IOYJ/bk2x1MCj/CdCQK2KUnVjgeFS6NpQMS4QXguQV7iTR5
w0XRP5EBHbrQh7GAwu0rCn7qyABQqIGVymfSFx9zJ6tlN2r3m8M4sYGv6mRA9/JL
KGeTFA+TVUXPulXlw4MApI4FVydFVJIk7/ND5WY2xlx3sbQGJUKTJnQN9WmN7Gul
stU7PQM/PyKs3X+MywnDY77twCll6n0PdhMQirVUDCdH50Z4LibIwp6J3nq+tG1T
SpcJxJdK1EuKmeBempNwUO9hZQOR6ZJTXtQUe/x1/RaIkduIhLxjhYmeswRgGTsL
8qFWabaXzyDmsqVTOnX5jb9teRnNX7gdPIOzFk7hZbV6kvRXVkw6IJifrnxaD9wO
K0BlJXIa1UuH4UGayUXYbGOsFGdY8nu8TtuWPpf+LG6XntXK09ZDBORbcuNYE3M1
/BHpZk5R268E0DPcDeGAxPM8hfZZqoJV5C+AbmngR8BlZ8ceropJR+rrco6qyEoH
U4DyeA7GKRNLbY9KZGqeBvYCvS8ymHA/zlKl+e1tG+BRC1actgCpeWBbKWNcLLGW
wXD/Ftkpjb9yGamLlHzy5Ng5XFkv9pe4fz6VuuP1YeHy2tQPXYcku7Eh2ZImNkTG
CXfaJ/7ttz654CNXTvL302w/Q7hSaKY+PofwQqc4Z7vabH5tov56W/XCUTNdTy0R
GI4EmjTw0JtfDMMWa0c8Sch0PIfgFap0FJSG9E1CAapPQXYmL96iEmtWFxtYOeBJ
bqgXLl54zMrIeFyXm84DVLe+RrVwI/ECinmEyukVJfGzYmllwfk2cWL5g7e1AWNZ
whK9g29uQwOOsEjvV0ooc6GSboHT9GIqU1wdOMWA2VBRpg/zhknTKpIGB08xZX3R
TS5NikBOi/VRiuG3EXidXIKr7NB4NPYKbzk6m5RKkprNvsOpy2jdgndMkY4haYSc
IyCT0bwa+UeOW2jb36awyOKD0TkYfBFoomOiLP6Ra3rrAqqNYkVDZx6S43gcg+Tl
xqGvSH2aq/uR0yi+XeFYibvz0iAmbOILZCiEvjhF8E23GGmaU0jR2wz3ECAV+HUy
FfMI8NgqmTiTIgDRlSG/jWtI/MLBvnDU3TS0AHL9DiFJ43N9oK3dUTUWW4vUAWRa
RaRLfTxdS1wCF4GgmsVXWtEZP52lxzI51viOt8r3O9akGPEo9DqfGwifDIRVxxmY
1KarqSQQ+KaHzqGj8ORFGMlNFzkMfuqb5dYdy1p/POOE/lTL60zbN/RbeWAAUJsx
cLjweXJcsK7qc0xFHa+SDuVyv6ZN+PnN019yZTlgc/bvjZiK8Gm8kJ9gDQs5J4rX
bF9FRo19DcIq3O/SQcGBePepssEHeC21UjgQ+EocC1SfOs/X0Rgq24tgUJZqTWfs
k0Zd2gg8ll9b7b0fAZPYRRksnwjqg501jloioeG7ykHA1od7UzR+N7OLzg3/B6pA
3URIwSBf3I5Zr2op7mi0aUAQtQlB/Jg9so4GFsPef3vHUzYhDjLabTSCLu7f+3SL
2xgHRruLhuExQ5dHDQ8j/8ChY73BMzVfe/eB8leRKdbSVkVFI6mPhUCJzoMsH4TH
KFEDOPIYC4wg9TyhjHIzhDRIbYowMny+UI57LlGpXc0nIplgAXls9pXjm9jy+602
h2MCZ3PNDYxVEgdxrhRuC/38VN/NVpoUFcPAfdfPnZl+/38TzMXbziguZGuAstdU
8XqY5CB+KfDlM1wtpnhdzWT+o5KUHiKwZ7N+ZDkghqKaNA2F2OwsrtiR5+X/R+Nq
H/MOWlKxfGJ9cO480oAHNhnYwLxafAOhmGJXkTzTginORxx32vkv3isXJT5P+tcI
WDQdbTCMwVYs9/GLMHCd+SEJsP2SXmBBG7tqs72i4wVQ7ftL1EBHbsSSOBIfOQho
3ZhDl3VmCEzu2bB/d6CfiNiRj557w9sXaJ98UOZsNbb0S0HA4RbfejbH5+ufjZn5
N/6c2nhqKZFK60+Tw/NtiE8RZdGCo2ZV/Qpvc64ZpmRs9G1FzgWVXbTRb4HOolu+
XMedPYsz57B8qPt5QnKbzu7/mUC4QP2pmBjp6aShO+BTCuRioBnB4Ez8pgRqMrMJ
tohSgq2Z4QM5KigoepEPIkEVI8BVMjrb34+QgeSqq4gTOi3HZzT/6vAeFLhkAYZg
CQ4ErUC+rygYIhYgRHJjDm8mreV97YDLqTctZESgtYCJpd/qb0+NQapjsvXqoEia
wosBgHixhrI0A5+xt8a3gK2RDVshgSNjdZRCa1BCPImDpfqvXmPQMDqAXUQ0TIIw
r9wIqKEjvJhlkQJYcalTHu0REV4eRmPT5ToIXd+6GQowHfAAJ8m16iyIfBXd3BZ+
0VOdyxYHk2UeD0IS8WRsOBQ7iDItBJLKayV7fALvi2C3LvsWdPrNwCzPYbYLXdXC
1DnQzjZekzMWdW309CaYCH5M0Y3ermRXB2lxrvhzspViqLoTwOfPe2k/u2lnYZaa
OeKiGOOqNLu7whES7U7WJyoiXQunS5/Qj/EZSinTYjRAlj1+HVPXIA4gb1/8VOww
9f8DgnVNKzOcO087WFhfV844Kjy/ZE3A4Tdy3Eta8EP3P1qdLXW6KyukcmvZtvpy
BlJgFcVfSc8tbP+cR3XSwPAIqAvmwx5KdFT/29UusdL7lW++uIkepCO2rrqFlqWF
QPnS1wec4Ziujkk/0vJZn8z4r8EctmcRoC+Us1Jq63ohvu57LBoZG41voFtIjnln
8pjdzaldAmc6b7RHxA48N+F1TP9yHA8s2us6Xcy44xskgvMOASvnbxsQIvCiKrtS
5F0h+STIse2BZT94a4OptADfEXWrPrjkUXJaV8I86AKyQMzOwRq65vnMS1eJ+Bkg
/edlZ/0VN06d4RZJUoipfZcljQLuwjKDSP8JxeLDDsc5ZjRHuh35rk8vOIJqYftf
Xj9gHDQ2lN8FEXV+1h76wW4ZUVAJHvcefA54loC/tISsps6bduzqazJqkLFjolVR
b4nOCtpJYMyo05OvrzdN5RYpsClClUZ+450CqBEyAOJzOe4HNHmta2k4jsi2tP8A
NnoDtOBzzcyk36C4OeQKvQP1FQ0WcZOYEzPQ8+5rfJ2hjKdebTFxHgrMCy3Xmd1C
wSiucuMdEVu4QVine8Q1Cu6p4nw/tpxFTWbj9xyT8pzcjK+glkDP+2++dhfJxRpO
7kWt2MgeJ/zTkAE+nBcTnsLchjzNi4jXETqr66AUnddb0lsl6MwNUiXdpM7qcFos
ntWBVDuBFmguRDwVgKtvNyfi/SY++6MyxGaBRrUm+DDLZbnvLoWpSJU/RoOkynFs
1DZkFT/tgsGRgeAdF2gZMZ/H9x7VLyR6EnAj+FuxU+crHz/m6lncqQskRItinUyz
MelRTQuSotPmpYEKUKTHAb+XlwEgtEQU7YrZjZnq1bUDSNf7NV0GrhHJ8wmSoE5a
DUGWaJwsJwKU51eu+CjF36emtTR7V0vax82uOfIbvdFgplCJziP/hiH0/Pfy1wI5
6WSHKam43UZfGfbEWzstai/fmD9mlecVfLOkO8I/OKO2LfTvA0bH9yIST/yjKDwu
YKXLOCGjFt1cWznqXEY+dg0ek0xtpXELvWJvoFKKAlK2dhM6TL/ciwpmswD/4mmf
1SoEyRlWDQ0poT54K2/7448jESgKEs6qN0YvIkxrkylRpUIl0tcqpxLGio94ZI9j
1BYT0ImG9cpxgREhyfZL4Jcg/YwbnKSm8OL62P5MuS5BCssSjJ2U5kj/s3XAWcPy
0mgAujs0liNA5eeWmRQHmfgTNFuTPWSKb0hjQ9Odq9sPd9QA9whafuDEIadcz5XO
/wD8SVe4Li/vnKo3np/fFunzqAtlrVwLOLEyYrWUMLYsYO0hlT1qMAq5bVBoj5yc
yI4ksxrWdXTfv36NOpgB1p7F2uxO9joHeIDBmyNyoqirw4hjGV0a2g6oPJUyK6yA
y+zwKIZTQL2TvKqXFEaNlqL8ZHynGZSLc4qhFsgR9Z1+qMrjprm1C8h1iYfPfAQ7
jynC4wF16G8EuR93pBN9Dsw869skD2Z12gP1YZuEG8jdpd+X//XTTA3ypPeyzuyD
1M0AvhUDPY6ItR0wrb4TpfNHzcnRCfbLXExnHujgl4a21L55LaWqjYWRVWq+MTgU
9/CGCsCMJMBABRoL6ZQw2Wen5NdufXHD1YSOPTgac+UsGXJlPwBIv1E6EnodwpQg
NXK6pBlOt22zE0UHHvHS+8TTrvZKgE50obL0jXgpAA5IqjaoRGCN27xsCuQfRSU3
FkliJn683ppQfUm3Gip26HSgzsEgzaaU7fTaZwPJt9ppgSK4Yet1azDbH2VBY1bk
X0E7O0XyHSaIjCA7KgMGcIMuAE09bBiQXz6ZELKt+P7/awrmPOCbXyCGwaUzbauZ
rsFn37U4rc8WNU1zNU7d97Z5uWH5cgE/QKiMIeVFP9QHryCPfq9CMHQoCy7SsrLz
VFuaQQxOdMow7+NEI9IxSqLofV47CCHZJL9SFP9WROnjA3JbKk2lrfAg8mCdIlUP
iP8/KS938hzZ4u1RLrRIFeGhcUXO7fEUqP6Kjz8rcpJIqg60wK24X+xWmrGgAg42
n8ywSzlVgqTD5FbpcOCzG5V2H5ovuHZ8SLLh1z8TBqiIj6U7KTtkPJRvmOD0tQKg
nGaDQY+BIG8EBEOW3y7B8LsAwmVDjchIGs1jIl6E++DugM8b8VMTZC+njj91fncr
gqcjnhGDVryJCdxENUWuDsF04OgTILM91/6bhF0UP42gqu2fZ2iBUZp5k7dDoTtI
N3+ecb+5Munvc07YaYse3rcgfalwwcqq8o6yt9Om+pFFsH3P84tjjrKTupXbzeEv
4AfhHCZH1e0JCAe98ADAh3OMo1b+QD1/N9/Gsdw6Z4sNJSO0zeWLLvnMIbN9TFoz
VaJirzp1kHJyeimwVmvjsGwPSoF1Wrh1IXX07fPx0wjDMIF4Qj8PtatV9u4aJXEH
Xqt+9qhYbLgscuR9V/9s4OPrLhaaj7OaFqYb1nJtD7mWSRf6CBM2eZmREdiKaR8V
1Vtf9FOCVx8itBjxyrE7+FLbez/xbwDVythWNvqkm32kmT5y0vfTCaL/oJaos1fi
T+aIAm3PcHF+mz9Yob7bRHYKVvDLjn0XRZb9foS2wbnbnUWHAAym5V1a5UlCmkQu
8CcAPzL/jlyyGrF5QzEDoUmLIVvYKHH0/ZzYP7HPlmzh+6NCWsllwMtbrA9W0re0
VnMOrLDi0JRjxgopCJR9zxG9KLze2w2rPdVFPRX2wibFbBapGW0U9TmL53HzsczB
70WKN3I15lQ6fv8TuC5r3gWErstWzbl8L5GYrKm/8gol1XV/KPJWG5Ykqwqv+CgT
qTPdjdDhiYFYaQs7IN+MlIqWwWj12oziOdLmhHJB3C8JZpnq3hIpehSFAdbq8nDe
YUOfv7M1N7VXEDktlXY9O8l4Hvfc8yxu4z+QLRAdgu04dmYmgpNx2P0su+bArARb
Pf4fJWLCJYM8T3xpZthDm/rSltu+aJr6W1K6ZWuQXeHO001cPpjQ61EpGS8OdDUA
TEUNwyUVhKF6BERFANZEY0DuEY3HUure5ZfVotWm9hAFfZBQRrROFMdtC2lbem4N
17dg+yUY4k/HJsZtVaicLYdCkrt/lamdhYfRVE0mE7tigsUwERNe1YmB0dH0R7rP
H08fIogVjq0pKY/AE2VYIs68Qu9+HrpxGVcuTauHyjiIuuEbyRfgtqvCTte9uvnC
8kro0wzKL/BF4ZZlU0BaV07GD04BbxhmDP7tOWTkUumzlalUNPSjXVHgAGgDF+bQ
PpELyVv3XHBDhrayiJkgIsweGdk+y87ddepGUW2znTVN0ZjQ5KPhk3lK687d9UwE
2QQxP63UTvwphTYmi0nx9UgU0R/UrNgwvdANNnjXyjnEBNk8dl6oUtcM+CANTI+q
sKeSuj6fy/kyWooA6OEW8l9FLeceNUVLjuMPfuralwCA4e/zCqQ0HJD8awcY+JTE
Ke0X+vtHitnucVthoNz/J2bnBWPYjofhIpAanr/lqkXIUboB9lHZCdYKxVFC/e9x
OYKyE4HMMw+O9YyGadbisbHglbZDe6sN/x95qDRHoZumJPf34GptaG1rWNDh2x2x
8h25M33tgNSJJk/L6372tPh82kESENx+4tt65xblw+74K2FSbQp1aQ9eXzW/iI0C
vmiCTMCO9xwEsPMOPvXfqDd2gbE6q5Pxb01X6/FWtvNWJMEZ5S6qbu1UL1mEbeEp
NzNxjLSY+EJ0B0VBVygh4HotfeYkxz8mgjJAW7pods/Bm57HYRIWSIH8axAYNTqX
J0LGkI4uTpGwp+gPpuyomVevHOmJX7gP86z8Xm5F2mD8Xku8xtKD6l1nfnnfyR6B
Cmmd9aNkzN9AJEB0m+9p/valxv4qz/6eniVvfYUBXEl+lXyq06avBJkSWYUDwjUG
0W6bd501O/5R1s6CEHeIDiKsb76poKMMg2ghbL1Y0aF0qADsalATH9XWP0BoHEqt
pW6cOxqG10C8uKqShiNDpoP8LrR/SF0+ucxlk2WR+Wz+8KbBuWBrJb+X1zCoZg8E
w/fcjCTJX42TYB+bJttTKf51gq/m3quKBFONbk/mhsZtL3Dj4iU+K9nJOWtCCJbr
0krpB/opv/HZo9uz4tUXRbhAXDGy+29tKS31UibuIJzNkrZtRGJKjYZCFrjB7LUN
yMsB5l8pyk0fjLMTyl9eVTqUpeT87Q7NcMkdQdq8foUOxui8u5DLfEvhl/X4Aaa1
jbNtK0xW3VZzYBGajWBTvRaLfnDywTE1JZD+PnZraks5Kh0wWu5zQLvHB2VUuIP8
f4XrpbCQd+Lkqz7XCzBVnxIwB9hEeguxiNLpYzjdVTRPImFSsaj+V8AjfrcoIYV7
/xU0p9FPSxakBkWgQW3hkSRd39/sllU/KD0TSA+4Zs3gwHgw1Hq5N3a6Qg/9IKpW
qmLqUFzCjehN9zynmI9ylI+PGh5gKS1Su2ALipYJmpVBQGPXXeq3nCUYHdctC0be
uSmH3adcaqGUDtcOMBePOqn0Nv+MecB5NkVWhiphpS4iIQCV4rF8dGnUJcnyteGq
UzFpyOaU8LZP5SgStlfzYx0PvbapWM2Fa4Kss9kHh9fmkFwCs2fBJLWGLzSoIiR0
JDifzLNJCSVb0+xoedm9duHZPZISS69dcV1SpUXDy8XXfGHBxoVcjqBhivQ0cJwW
VSPjv21gR3Mh/H4q5WaOw/csCQp6rd+sCpkjmAYZ9RUxDtZxwIaYdAgq1OzfkMOm
/kIXiePZY7naeTklunin/uO7ayAie1VehDL3RQNXGVoyk88sopp/w7lMGPUkft/d
6ZyHl0HXQe315mH0xkc2+RV7Ii0PIk7+CsHOchEpG644IorR8Lwq/w4D1q/4FtKo
Q97L3bU/tVc15gYDgwbRKQhBflH5eCdZxQiAw/OokJmPgo9rpazqHK9L8EFZVB4m
13Zwfe3q/6dVXAS9XPtWxpcSfmyctEJjh5kAitRrWIoxjP0mM/OpGJ7mcYvf0s7t
bIaKl2uqgDTetRphQUbWcQIbjxfyElFypZo9LGEySH8Px/BYGLtypdRucb8cwKna
nR67cLxu0qoaaDh3YhPs5pkz8s7gx6FG0xxItOMRZKBW8hxYRp+qDmEfGROna0v/
ZHfJRbETObowZqJse8eL9l25rNBo4aXJIgcwmuOouMGnMKn77aAcVVhJrw3eM1tN
9q8juAX/2gT8CTquTxe4Ulm+Q52n0EepSJnF1+8usHdZjNs61n7PpqGqh7IX7nwP
o4ymp5uDDbsIx0VQ/BRp075vu3LQ7jNix9SHSjqReU6XG+nhSHW4v4jY936ZcqGN
JN9SP/91whCmI1pj81k51KngnN0ur9KV9hwWOOHeUWv0sgBH9i8fDT1mqqCbFeC/
xVn+qcLk+MUI8uaVIu9d87+vn7DjbH/JIlnvwxG5tXwW9SYH26EGYEl/+pwEcRaE
pCvhRO91vTxq+dD5FwA9z7vp8TyBzKPVZ18H2VICHh2E3fMazE9g+EP+rM408ZVo
6kocbLuM9IexyMeuk8Pq4hR3HfhRGeMcZfA0EAZawUu/OE8yrNdBPlG3MrH1O1w/
jFvySf+p3K+1xcAVB+NTJYAFZqO6Bjc5ldZkjAf25m02hCHG0HuiSkth7k3tGlzL
P0gCow4IGvowXTilv1SFzMuiSJYIANo+8HW+1zMhtCWKS3alfzMKLeUZc+75iXkU
/w/bXa/iuFEMGnmnKLG4ewi8li2MX1pK2QZrNcD09oYQlwZKVkPlHBcxBM/5naPN
yohXIYKWEP1mnIa9k5Tgq2ePNrbSibrakbrdwrKOFilTNLZdYv1txf4azML1SVbo
6siDXw6XFF0MZdeIA+Fe1QB/4D1Ppr7lcoVEkNeBUFLEk7GjLW75vmdjOXf8Qh82
8utaznJQmkHMIyS/hCUGXMSUebB9F6dm2H9juPvTCVdAVnOn7EV0wNDgNPJlz6jA
2uxBCxXVduGlQCqeVHqi7SktoMOW/hChbZrXKtMRL8ej0aN9g/XtzZbRRUtPUfMG
3FDaxkbAkkxltk2tryW+tLMRO6HUKLNkBWJX2rC89+H6lItXTICfSBrz5R+UIygl
QK4GXF9Jd2+x8wQIhqHUlxiTumVRWjvgwJKNfQLBzRxD539HKRb48nfDozlvFBA2
HesU0RdzsGlKitOiXfbWQs2fAOHvW80YptHGBd7jii2LZeS2S3J4eYaEK1pgCBNm
s+jtFT5W/DVmX4B8ihspTb+gnS2cdAbRh5uzd6vICiw8kUYlTVMAsFsPVi4pq15n
6eKrgz4WxDET1jB2pObHUVUDjKUhHMf4jSX5NwqyELzodMkKCStXxTa7Nyuo2g3a
iTJxcn4sTU0VGPH1kgsS/Nf74re3DwXhQLb5S+Ecw8W9a/dlUpEc3IpuKmRKNIK3
0xPoLG8kEfiFuTYtQNIDGrjAzaxHP4Ie+JQqs707pjgsejqKJehwRD2K+AsDqPFR
F+60F5dMb0diRv4zowGRcTJbfMCYeLYfgetNBd7BSCeu2jv11yP+CozR+vZztpnJ
/IAO0TvDUdGZMY4neBKT5cbYsQy6FQF9w9TrbrYHwc74+y/YdFJD0CwbYs1nPuon
IfEZFxR4KiNL0ZOu0t3Mtz9gMbrR15RxrRsROyYArN1zWgcZFcuyIGsT9fvHCON8
nAQsN3rkYTks++LF9BJGJTmASrK5amwTT4f5TK+qlm8KDdRs5EtW5AbDyjya2Akm
GxM5A94lVtxIydPrRD4/NWbFVCT+lT1JpCAUT+XNeQ3WBeYCB1yDR3ym3YbmM+E3
zJphn7yKz4CpnM3ihtvEPP7c5ww4jHsoaF9QqiKtv//qjnGGh5hNNDxVocCIVCIK
yEkasHtaQKqt7SQzicy/xBRP0bTdbApzszJndiXibimcNxcoz2dYmjMoJ936ZqVk
q+m1MO/1aD4ExkOTBfj6o1W9XRFfusyWApk5CVUQymyNe9mDPR15yBkWXWtw1Bhf
ehthbMrGjhy7ExxCqlHob4nbQsrQVUeW8Wj4nyCWK9Q7KqaVltLJOpngoZjY8KNc
HP+jOEnLe3vgjpxWjLc/483AQM0Q0xBrJ3kewfMuphqr9auQYvPzBKgvyIbfQoq4
8uYCJjmFWGkVjgkCpawz4N3qCtwZkNkD+Go1A8JeBRI6xdx1vPDyBGrzHpOFAaIV
PPHJJ0yeVWL5jX2MeKjzWsdXQ9bmGsFfo2RcW2LYdyt0GRVcbxjOBzqMCNW1SPNY
HUOUJohOZndpdI80yLWb+oQI/iFz/W904eIfq67QwmP9sAPXFxHAVos8YEw85icT
1u00IqgkOKXu86w/ECUrUq6gWs1kshuIw+qmtPVjnX2tSveeSSRKVJXoJE+UpQki
Z+lQekk97iIxFprmOjauZrCBNv6EckjBaqFtXnw143ddstPkfGNf5dX6zkT0t86y
N2q2M7qB7T1vfaypGtTuBMS6Wi95L55NPSeVIP4PYBg0nBL1cYZNYfG0uEIB36Jh
WiicbTK2e1WvYo0ScwfsbOj9uDj4r1JqNBsK4HtfEO4ILnYu9OYkHg9vjKp/KQlI
1ICm16LUxvGPbhU9xFTKJO5Y3vlnMeK28o26ZatUdmYm5KtIkYrXbc9/3RXHCqya
K5aodfDSJIZN/8Ptwvvt0FGeAy97MZvKHgixYCXZ/+l3szVbSbu9DrKTdl3fUQtR
ATcLIUgPydpa61xGAnq0mk8gbnEV3RKgwnl/HjUEDUNKQm80KHk18lG9ah9fNRoW
lK33SfhQE8pxAfudx4JSkbpX1h0rED6NR2jNjitU4o9pmBNt4pe0B6B5BE3eR7b6
0X4gfY+OLbsOBLWNIrtDznJuGlT3GZp3/3P5bS3s5B/pGJ9ki+9dyLfhBKW8HL/o
HHb4ZLTSHEc5dko5VYIj+JJxFzrsQz1VNK5sHqna5OYGiz9eyhzQey0r3HFX1fgM
OygcGxsJn2Zq96EukHD0RFGA0Ng/BI+Wnb6TvBKX9GzpmVDq1wsDe4AAtKypcU4z
1LzLJt7oDoxFWK4Eg3APYhbj8D1PgZzdlGvcZO4sOzzOjd/itfjr+IbTvk4xlKvk
9s88pEzjfe7ckYhiuT6qKRRqzb3CGG6Rlx2T49XvojcJOWgSHglo2boSMpVQWyUc
iM8E/ZAHCdJVqlaiP5dsigXXQkyCPFwH7FMcWKFl+R50bOVCYWFg+NlDBDLAG8Xg
F5fJfFPSp3XcDkMpg/7+bpO6kXVusqPcq/vffIIT63+73M/hFsTICTr1fHFcfS/2
OscQevoL3Bg9dwmMFnRkerVyX/voFbw9nykKJ/XZvY12hhBH8WBV11hp6ve6Tx+m
at0PQ66JHNkuFGPZIJJfrzoyA9fiid0SleA35wlbB+ZJDIQJWmFUH7e3+FgVl/y4
hCpRQhJ6feZkZQIgUynKLjSLdya/lI6rpxA/Szvit6Gl6WP81Y4bE4DRxwrh1iH0
Bc32ge8Nunp1GKTgeIh25pQi8Yr31/d0Wx7TdY6LnMv9wF2AM/FVgesURFiYN07r
NiP2b9vz3oPRB1laj7IUDb3rjDVtur43pl9uIGKpjC9wYCVz90SBwLyRcLcdDWiH
gM4llSQLCQOgo11MAxNhVpQWMTIDGHCUBTSsNZAL3QWmnRhZzfgMpom1qQ5rc1a/
Y5t3w9gfTI6hs/CHugZknU3qCVItY8fLmEpXkcnQx7junbvAowhUkucR9dRMMvGF
832HjYVbYOV8c2WRfZ1SkWabno7lG3OOtrnB6razALgtlqvc4d9NvRn5K3LtHg33
FceWBCmqS40M4YF+EWBM0DSvhI+d9J+Bhid2d2aGMhFBKbV2dequF0mtSJNp5ZOW
Cn/m3zGZ7xyysP+212EIjcGth5ALPIez8L0d4MIhWk6htCNJy4zJs/aGekBgKpaK
FFoVVAAxmHN7qnHdbxF8XvCiUYlLlA/wG4iPk4n+/y7elIcGKVmg4kbsmfq48jK3
5s+IxW6BMGkruBXHXNbz1qOhjw2y4PaML3WxR6kKDx4z3nAdG4xvPCrHYGhKqJDl
AD66YhzdwG4WV4WidtacbYxVhK4TN1wWFibBhgAG+TneI8hhZ01CgYkTnitwHUA7
0uHO3DbvvluFGHvvrG9AKpp7JbNVt4ZJEShJEHrlioB7im18bZ97Mx8yQJfWsZje
1qbm1Kl3CbyhAdMQij/N+jOScQ/1Fqm+TslItbptrARoXNBMwo9pheVEU9rTpCG4
B129lg3sxWGPs+OwuLKjyDmj1bpEZAUeXxqlxFvz6nPwPN1rfvWK/iCs/wJAw0jy
to6Qsig5Nj0q7TYa+wWqloe4NrIgQsT6RMOn1yfTXc7CWX/G2jAkmcTaK1Kfxpmm
dBybm6gwfzaPzqBful8kYd9u2XQm90nMtWIH2pcKFpwNeVs8Ai+SSbB1oOXldiJA
lpl9PQAnV94T1cECg3FhrstTtx/AyAi0uMa6PZv6MgagQfMFV8mg1RR0v6eCBR4e
Di32C7ZYIFaRFXcBpZNhqIAvC3nvfhuCMNwFyptE/QXAm3vNFjVQZcRPj14XaFiK
wzFxp1Rmcg+HjCSiVq4JWMQZVMba6UqTzaofinu2kRk29uw0d23rkkF8YBeSahOb
KYQnGi78J5fe78ihJVSRuXBIGLiXRMJ1DUjIoiX97YYUcS/kBkmVdKpgIpjEsrVE
M3htmIm4T5keAMCXnk5UDSArvMJjhXuLmkcCyGWhsDxhQG6Swxz577NSRoKT0PAr
FcSrrjnu9CTKZdtaC/7FCmyxGb1V8P9HKb2sKsNElPBi7RHOok2FD6qKcsj+eAFD
gg+tFLsmzua1YS1AGa9Gyxk+4x0FMhsHAvNi4zNAsQUf/z+ZQ0Q0Oc3Af8xUa3lk
CU5ULW4905AuIK0HVXWLcogYxe0jIIXmJ2npEou8KamlmkyCQDKu2iRdAFuWSwUl
uMOAxBYTbN6E/7l3IXInWqFeBQi4CAXEn7Xts20wXpJbiSEYnFz2etdhcf4tPrSU
7dsbWLKkYGMgPbCSzgRf2BFqsyypVOMzMEv96bNy6/iTdF3IRN2qCLLMTBvATU5u
WZV2NJAHPmD1vUtM83dPMXJJy3vljbkVwgXk4iA5Q1Nblf/cAEkQ77TUD1ZZEUbY
cf5F23HicHqERr5rtCHVhfHhXGSqr2WvpJCHw9iJ+3vtpdoybC35gERXe1L0bJYf
JI5bgtv+FAgaoOq7V6lfy67gw7gKcAR8oD4MXWFd279KarbA22b0LuKgu6zPwwGJ
7137RKLXSCYVqBHbqlvLg4oFaDbM3hy/TF4r0wZfniavw1fHEm5YpnSCzE/WVMDg
ilbthvc5WhVvQLdh4z19iBt2U4RtFLVtxYrnczoYzKDqqXhaRrSbNL2BjCObtg7s
JKDztgrjiDafLWk5cX3JxO4q1v1CZtfh7qylMhnugoRsQvtLs+bnuEfjSQs70kpB
NLNfstijHwKKIbRbPXl0uYqvzbXGZWgPulgW0PtO+Nd5YxlfGhmbAdycENMl65bq
lJtYcziW3wcliGBszWRcAVfctnFMKsnoxPV6MQLG3cj6ysbMpO0jpPjtBMvxmC1L
3/FUAuN8x9KDPCsG2r8v4xlgSKtmUzEk78HkTvRGRG6fl/xjTgEWI+dgupntqFKP
1oC+brwPc8/Zm1qZSFRVN9d4JyA3a7pVP5B/Yc7cqQJG5ERLjzucT/aO1FFTzchH
zMUCa94N/z7cS7fPZuFrIhUejerSXG3Fy/BMcoQzykDxpJyhODrsRj+XVmjzc9sh
TQn7gCGNsltyLJqMe2z38HWx6dPb7A1SMH0JRb8vUmN+IGEp7fxPHLtUQXRmzvaI
Sx6zKw7cs/+Sd9mM/bRs2pCwmwBPDCRsVpYshV+8rGf/EbtFw8suTrA+Bz2yMnmw
2OAs0+yA49Ekn/UzGv89rA6J8FzUctCK2S3L33Xg49KJE3PBtJCfYr7F0HMSq5nH
G3hjItqHyGIOijDIcBbUn3vaCqbgUKLLS7BUr4UGTZRMzik5EVXYfgZv3FTkMKzR
xRhQ36DXmLgQC+s1S+SDAJu2BrCKV5F+WLsJin+8rk14Ly2wUu97FSqTIsI+oC6l
XHASiXqCldWacuAL7hJJpDF4fpo4BJ0VBjMn8jJfca5NDgbk9VyDe/Bu9P5OSFtk
aDfHAYjcTff5HZ1/PxgG0lZgFBPLdL3vX6bRGIqFQf321u8SjAHRlSKcHXU1ROia
koNgEoJdWVOssOEe0moT4s8tU3Au+EslVVujOc6Nu8eczx1MPQglT+TAaH8Qji8+
FBVJ5rNMk2j5fCtIfcc4XYWKukVvIjuRQvH05nLECvsldwseFap8pxo3RrAJsJtd
nkfWt1aFJeCzckg3XJyI1eQy7zO2WQ0LtIkcilKCv8g2AeDN3U65Sl8OdSl//J5q
tPqUxjjZQ53XXkcn4eCTfdMamnyTj0t8KZtCObt1CCxrFjpE6RxMzE2d2opeoZxx
mBFeWkIDwRW6JmZiZCWFqcvzQjpSO3oJbZtfPLoNENXOk+2a9hDpQC9vkGH2oaXN
CZPytbEPd2RDv2Qr+zuAJqA7I4l0gpsajo6D/qsty/vHGDbF4KyxTAxaLcMLeASD
2sd1NdjOHHpyDrKMuh/zpVjuvHlY6uCwKcBmoBAvxu5EwVCtdUebdL4RMWI5FttM
9ePQMQGCD9ohC0c6SrBVjq35PvxLqr5P8xKqWZF2cLBsbQ0ppOvmVFDqJUmRmAUJ
BjN90H+E3TUt0wj0uZNdhoa1Elj/sbjAeDHiI9jv6LiYKRhW3lKGfMN3uW/7hSyr
JBJ1U6oK7i8e3Pf4Pff/IqncpVTcT68SW5k78y+r2qPcA7DNdPTrFaRSsKyNjKfx
OKq18iAJ4l7+QwlleZ9Zz2i7JCxZAxySWEd0JNmAhcoXatFsBzi8GvmfDg41A93V
0d5AoLFfhuYLaX0pw6oKmm7ouEivb1dcrk+kvHu3MlH0dcXkTUCU6jMhKxy4F7qu
ox+Xf+gnXsxi5T4/tTbqUdN+itHVZjP+2Dw+Hl/4Gtoa/i6ywRmHMtTxsZGnx1aN
6yPMy1LFaEySADrbb9zkC86JBuDZIR4QlTN6bVXX9xSvbCmBaN2uA2iK2hL5OSXD
Lavl5iGj+Ux/xF7OtJ+kMJX1HpCS8hq3P8YN6l5NpnTFg1ztGa++k4A8VyFdDJOe
jEnCzH57FKkpl+H0l6mvbrj2S0pANOEp4VN/CRCFM24Aa7Vbh3NynWntthHfA16X
7XweTg2ZA+RHg3eCFuV/TfqVt3Zpxtk+wL9+lL9caDAUZ8zz1T5+DPl4gMyRy74F
PJ6kNLLYMggZkx1ae+9irxieC/3ZBjqHGvOHVYhA0fERmIWR/zQEG8OcPpO2/c7R
DpggCnhw56FPqPikzU/KLVngw6dX3qHfgAYUVrWC3S6m8JULhAGCqSceB+TYLuI7
lFnKN/puyiNJoNmPjtaVH3NGUubgHoxfZyuDwgXdVrdVz+ML7ziffLXoIm+ngQtF
AIMyCPWyYcaxNwUsWX9Q1Jj1wzVGcSTSZ1xEP2SNrDJnYIIy8FIOqpHYnEdRw0T2
1JjkXOjyar4B76aFmURQupjUFEe19smkMYP/KLoxtHY5f2PL1yWEFqrhXDVhO4Ay
rxw0GRFvRi46W6hdAs1sZadK7eWXIwyeiWdBThTBxpyA0aLV9+RR19z4hRBT6iiJ
AtNibf5K22mYxW4gw6uh3MVET2lY+ZLgN4RYM0xg6RuD4SaL0v8BQ4c1A+z56RnB
xjrU2dF2/Lzk4X23jIhzx+X5erivIJz2Ks8rl3Ine+397KuiOQpmzsvAtoIPjXkU
w6ACqmOgLudHDsWDAO+8+ImUJZXu+yIElLvXMB+YRatsq9VcxttfHs3S/ANklGPz
WU5jOQuMKjn3kVR/vUVmpuK7OfRWqzDnm6xbx9fGxCZ6RpUWI9wKDYttLQytvEpw
wQC+O6oc0E5aRnVHNKSTGNjYVJ1hF8sxrzaakv0ALrawqLU74PQRN1Ntohz7DLig
LhNRknNp9b/hUupXFEovdnZRTWVKMYxKrgE2p3+wnoWqvlLRVYaFKu8UJ9tuB9sw
wgyP5XHAggvHZXu6iCOlh/ZT1WU3JnyD/Sv4FM9DDM9xxhTNNBm/ncY0s5PFPA6H
XXvKXav2Sh+AwoB9cbqw0wSbxAPTop1NjmQDiwC5TMVy/PdZHVVHqQ/04QWuxKAz
b5CzVvnmfHT9kpy1YS6wjEc9yQR6uPR24n+s0wVBf/Vz0pbag5UV7kA/AergZjA6
W48mh/FKt/l1p1k94V8hqIdjn1bc+3dCHioQuYcZMgGfaIUuKCR4yypA7DsErXe7
t305LfmFXR8FzsbqCgtaurXaiO6soBiPOIjldUYLewGl8AsSND5tAgB0TuCTFZ7h
dtpsbcDQXdzYMuY2VESh4PucV2fTHA5QnEqBdQUP65xiS7JYYbPgw2v6kx7Akc+z
KCCDAmSKwfftjN6Oqv6v6S5znN39a0Hx+TNOAuh4LMRU8br7eefEwjjhPCnrhH6N
fMk0gmpoB0pSeNnHfecDRuTksHOlbMQ53kSglD5FEHcEEvHqREmbSGqhw/557uQ5
RTl2uSbpFy8MuM1WIyBU1HrKRKtstF3w9EnHxDG2OJF1wPW8TK2VL6YKTsIR67Nc
tcWaKtXExT8kaz0/hI8Spb64jvTTzBoD6HXSlfYRosjHQHVrhgB61cckjcxnSoHY
JveE1Yfo0xBBvptzGKoA2HMFl7g9gvPcD6QFCGF5wzZhtnFmcWFN/Xx1SOhMIBmi
zt9qEeDLhkIxr7HkITd79aRxJK97idV1LCNrmjWE9peU3mo2k1qH80RTUGkLO5Sr
RdEF1Ch+oeI+rTr5w5JcxHcb8Qv1b2renPS8TrZHO0LBz7O1zHSp+3rLOWbxfNso
PoEbz0ZBcB1kQnK7P+fe1YvODvK+huCg/wMDcmUSuBfPRj0WIoTIXA5lNnbRLlHG
A5LRPhckM/gQejBS6CrxJQ1aI5AMMMs717DsnyaKuaZr1CVzQfd+6OdjyLDb6+UO
MO7ftGdu6WNvCr4zeIO+WzOevQZ/+zGjidvSb10xS0018reAGRz2ksAIUq5gSoBH
oIkMtjnZbFqqvL9qKUFG8qNU7uv+nMVxHrlMpnUVg614iY1lvRg8K12gm+wfj+iA
I/9kulPCj+vkE/4krY2iYrETu0NykzZjMG6sMD+MmMygOl04tbeUpY2j0CEs8fNE
/kBkaqg9JDP6Mz/31KkZA2wGSb85bs57X5P/c71XsGNwBqn4ugeJxG2jPOGx2GFF
XAjbeQm+b7uruDCI9lJ2WIS9xNPne9KJvCGKaQvrT+SliNgVin3Spiof85giOrlX
xCzKUMFOJMLY337SWarGZb/ACqukfTkOLOC5RpSisq9o1JRj9Tp+mpT+I2NydqrX
UZxWyC53psKOXZNlKiJ17HQqGGWuJbDUQN6cscpUOo/IGXdvg4qdIoeZgxaRTedj
6t00udSF5BTh+H4LdU7lND/fSrP/jmF+7XPQFm6pHH5T+QOTzl6aQLFJ3t8+nGb5
hfeNi06p1EVbirxL8qVprGUPEI122TcnDIa3pKpSYoLsisF6EYjXGxA7N1A+V23A
2wFTzHSakTTkyDmILmc0PKWi9NG+lOXdQ5i9g+NXYqwelOUqICf4BbaLq2IaNxXU
x2gbQC85uPXB8zfxLp8RunSObR35/R5BnC249zVlyXwJZBszlhmJkHagadgbzqht
NOfINca41KgnoTDzjeAtkovIlaxwedijPdTj0yEzDQ+cucVXm86yfV+/esXpoMHn
PvEtumivic5ZFsp01wC/4ap2w5/8WIhfaHhsednsexzHMjeSSVgyPAA7mSBtHN0j
iGFWBBoHAIEFzszT1NOoBheKmv7179Xb7usTiUUhJiDrNzlWxLyJdx5AtxwzZzsw
hY6a6UHpmhsEy0eCWx0LzgZHMNHFuf8Uh3SNBQZWcwDrk78KPQyNTMLmUmvArUu0
GzRisAGxNnDAgQ5N/8iWQwiYF0uA5TBuPABq6gZNBkwWGqYoE+Z8lQUZlKA1a5xZ
emaKzlna7bzDU5iD+jup9ZIT45mIyrqVrHTLnEx2el7NC//VA/kt/3GMWU/SA/ks
NjCAJQvmLtn052CB+//ROS2zRX9q7HF6nToAQbsOvbprsvp8onpia9djY+GYdSSQ
+ohdd8KAduEeYy3PLBlrHptEsmP+kZO1AWhX6JeikCsXiGL6QqH9AlkhuRJEg0Xp
IArCBu8K6NpAT/fM9c5FzRZ9cMmju4nraK3ikcMnW/cm4xgQxS9eLMJMRmHeNNoh
8cx6/lyDOci2BuXeERdxSsl3LZUXf9JomXFVOWkJKbQ8pTpFnpuQwF/7hlYeIBtf
HceZ8dKKnmBNQupuWONrawuwXf956Y5VoPd1tjz2iklvEUiwbZvCaBzdD5DINp/P
5XC/+dUqWNTBL4iS4k2qMThlCbXUJ/qposR+imbYZhj4MrrBsJUIvZEDVOxQ2KVN
nYkflY82/mGe/bezLs6UIV6vYqkWpiZGdjdmBTAwpfSoPQMLITV35s3IOZnkXVjV
YeySBjS2ypLaJqWNHAeN7QXac2RAaz+VoNh7wywxxQ0O2ybfRI3AmMLTEv9qRM9b
oJMCVFZi/kEW7FGqO9VdF3aARWuljWec+/Lqcw95aqZXN5dgz7iMXu2ASOWgSjkW
UkiUbso2L7f4W6h9w//D6f1q8hPlTlFcUtpMfwrK55xq78v5XiBe1jvjyystEzO+
EegJwSpMVd/Ag/nf5eWJaHdcxf8GMaEpkF5IOIpyhkrjPG1bjTZEEwL0tUPWqLuS
setC2m0yZzctqpNjvWkVoghi3+iPY34ZISxQcVR9sAFuYTpBEuPodelO2tyhIQXw
Z5kgSFr5V3yu6yzteVRAJ3xhRKGQvHs93PXCMIWQW8NfED8vi2EiVgMofk3+i7X1
tc60ksuWA83ZNZnAKLVWOxokXGsHB4SNMmbAxMzI4fhBMje3IM/41DuOJZiR0VCF
Fkig7ysL53szipgiOXruWVVkHd0zioBcVgAfM3OOmwqOyWiJ/3NxXbtTWAEUebbv
+Ef6vGaFT5xfbTRVTEvuEccgfdx4C0JWlqAteOqTh4TDpdengP++VHUf91jEez7n
Keve6BcEDKjzlSPVg2VSSTrVRJJTwSESTd0ZhPvApz+2huAeUxMnnrBiGvu+IOtR
+tqwNBIlILRaX9sNxe4YfGRn+f0sIBT+N6vcyFBieaglTLDCAXGajiVtmBKuNfTM
//eWSvyx4mn0/Bkmppn1N/a+4RwuuzKCecCOQYBqLDTCpvHsn49fMsfTsA9DI93E
HkwH9OJIneD4nl8Fc3Nl6IfD8ng7/uNC2+URfJnezcTdgwxxrg1nMKNKlVf7DUgm
OjJG3WejIwZJGUIqmAdrTr13TMNwgP/7XLiuCzzTVmtsY+NWwfsh80H71ctOfP3T
L6dJTOrQ0nLeiHsAp1w0wE8n+ZVIO8Dr08NKoEGzkXe4XSA312T7fOoc24Vkpy+Q
ZCq6dDJaHQnurjuYEOw9QX7h4KrLdkvLqCtY7MYaEhd2tT+5liotLEFc76Khlbk9
l/B5hbSb2AuUPhhYolpfH6mHCtlxD9PRA8yr5PL0/wAeiaNxcS3O51Zuj+6zQak0
FnI8R9QFYe5bZ7rHkbotep6tQgmsHQ0O5saVWfxyQ97IyYTl9l+8Nj++MmGFRJ+s
rmZ/VUtkX1WrQr1fipWNoqpJrNEbwDYBbLuvjlLEhavNAIUFC+GMQeJKOE5Ri5y+
JJtETDnOJAV+K+I8ewrb54TaROZ0QBqZDbY2tlHKoQYHwBvQghJ0Psf2nXOcsw7U
6IzWdnLJE89p11LtT2iseG1mjT4YK2al+gKIVi3s4jncZwVQ9F3UqzEAqwdQ4CNm
51NVLqYJWW6c69rJnxmZH5HLrnq1S4jVZL3Dz3SUj6IM2r0i5p53ZygMsoLtk3FK
mACkBT/4od9l9lMnM9egp4ztLZirbxlcRzHXr2+j/l3KcEGBpZq1SpXvuqMT0mC5
v6JnUa5wnZu03y7qcNmsklTRVGXprAn29EDZeap6dmhEc2Z0bk6kvd+Nd/ReUa8v
VvqhgYSFHnqmgD/PZbWd8sbn9pZ6C2hpxptFF1Aok0ix6e59EosX5DQ+7olH6g4G
mT2/kuvd3Pi6aVVqYUVPw3ietQajLW/zb3prdhkr6r0qjXcDzgBmZamASbX1qUcQ
gKCUUfXYIcr4Rj7uErUv/zyjm7eDZHX5HyUVegW1u6oi0SRKUiazUk5uLXxZ7CF2
/nLkd5vpapOfrUsXLx4MBdh2EwXezBltGx9EbkR8AYM92vkVR8kO2ZYJfEVic/wB
biV3R0TNAR/0mwMxWf1ozSnbYsMhrmArUXRw0HYxsEJRcjMyCe5IZiwgEeKUw6Xx
rEg3h3iVz0PBvfCZs/Smmq8R+56BC2jjkMNmeuS7ObWqYzUEc9c8vyMjgKZKJG8M
zVsmcTeCbE9IX36bBpW3sA/lM3nZ3ezqQulULzRLFWAvy6sOx2KFiel9GLTYDQDB
zUp8jJlQz2loYK1xE2L7HOUunEEUOmRLHYk7ZZzVR8PNjMjlZQflCkdbNrGteVPL
Ahizq0jDM1qqw57WDvs8ENqJ8BWrrZvV3sAgJATPXFmzE/vI0zeuk+KW8zPs1pTJ
wsT1fJOPa2sqRoqmpD9Ex2IF0kkZ0NFe7aWouj1JcKXi9ZtgfdD0PhCdPnCaDnHN
l9LUcvWMD9o8zue4XVm1W+l4ZEn7Ki5jZwmK7n23QuJpdR1LgSh+YnN23FK3eBEN
j+JSTzNNCNXm+beqtmV4lC6y/xU7pu9CtxGW7+xVYOjPKEewEQrLt3H0dZnAARV5
IhJ7t0E5qrlpJfJXuxLAHoff8bNSd87nMRKOWymbNymitifq7avAsXLJwiRCIyiT
lmaFehmuPplmlDVZGkIa/o0+x1iH6kbBrCYtOjiiMrmf+JXCUh8xMuDbixMvZSM7
vJkY6HlXzK2pizB4xPC3cMGkFGYBXRnZB31HhZJJfLhzI/NkUlltafuBfbzrJLwc
2o6gADhTiUjevQ1tijRWJX9EE8ki/DxZrjdo05XmJyA7wVs8Ga+UmCwb4qYh68wY
gJZjP0PW802UBP83iYTW9T3Ro5Mh6Zv7u7D1HWyF88Z1MMiqkMGEwsXmQLJitWpp
4uLBIqcb8vsGN8afHTFm7E3mmwi8qOIWWAtuY2Enq0dc1NhTxRA2Zy8vIettEj3w
TdkJWiT8sjmXOFWF8u3V/hLuKQ75vYDpiD0pDGzXmS0cByYVhObTHi8lKNCo3MYi
5/5DDm/OPQbmg6c7SeDnSFhrl+szk0f0aBXsH7yKOPO06Wg90iyoaKrTcEbrKgUG
X1HRl/coDg20ugeU4MERpuw0jMQlJFpTNfJ/LxpcVLgMXyIMwMboWX3b1BcgvvCU
5sth/oz0RKiZD5QJhFEHCtkPk0QweXA+zXGYQ4P/mta6m4wHoCB26NT+oXfCPsqK
oZpbUOgW3XFLcqPjl+2sbWTc7sPrzSu8t5J/GWhFh1VoTlbVQ4QpcggJ5yCWC4E4
8knB75CQ/NK8fOap6Knybyyt/EFhC/Ynt69aTlN3MhnmcvNsUKga2+pd/m6BN/2G
YFrh/s1cZIf3JBYGwdwsmRPYE9t/xHlxmBfDyWk7qFtZCuoloTS0wj6CPff5qza2
MBhKbpveRZy+8pOK1CfM6tteYAcbW8ILfTO/dz+c2C8Jt5ksOpgUyPfBD6N+TMrC
iBJiHRIbKPn12n0SBFx63KRQZpZmN1yEYv0PmyUSyJhP1i5eDgpZtYYlKYFosEhB
Wr2hc6yRWVCKyaTATV2lDLTbl+eZFp+p+/4fLIajmlOJ1yaPvrN47SEGqTkWJOSY
rib53AUaWywqUWBt240ygy/HKIbOl+PreR+v2tfR9DsJTnSCBaA1EUzXitPhk/Mx
WYARFTa5pBU5vRwABP1Zey4DvWypwhjee19ArUYNUt/6dLFdr/WNc70VMVoFrdVB
Gz9ykdyAlJ48tnyQ8kq3sQhghrpZ7eJsAOtcNJHQI0WJ1Ukhwldn7ZH/A6JqGWcn
RInAU0B82EjaEDvBXRkcHhatOQRZcKO10hsR7E6ldgFwjrL7bD4u0f66Zwcr5LcN
arSKZsKRC63XfZEp4MFocxqJzx6FLBJn18C0lIPGW3c8B6nfjNbfJ4aiPmzUGZ9A
kIe8SY8GIgIqj7N6it0fEl0pmBINaUx2q75F55D7ztBeXZzPkHvsK9ZuL6iCfRyl
5KFHR3vlIN+JslecTdzlaDw0n+7Q5rUqeP+mymyFcDyLr3pGBGLh8SNKSY8t6EhB
ry1+/TCZXc8Lc+lORpePGzDthjndhG3JQrykvThFnznMMkoN8pBeHs377Y0e0L4y
kCxPusIBj0pKEPkz+sggMwB1kB6qepLvzW2Vx5BmaEbZQtX/+gwRaQb70ZZJa3fs
NPxSgP9Tx7nDsb2O3SrfOtvLwEFV0pM8UC5UNvFcJJcOhB2vqaa4Ar+PGuI0KwrT
1wKIZs0wY4U7IKZ1RUwe3xvEz3z2cn4YM95VllYgdiZ1PE9M2QltV8VuQljPvShX
BU96YJLQ5SS9HPjZHJx/mMiJeQaWzF6opwwDVodS8aMkGMPPSiVgdiI3+fOfxaQP
enJYWj5nRfNlC296YjkmaO7DZ9FySaK/EmyhLS5qcfYzjy5nclZQQ4bx/SRsJ4Sb
+SqJCf4zOE2O4DOyuWp/iOGyH+sKCtk9FAVP02Vphc+qRhzmBdS0w4sW4dbh/C8T
ZmrouLehSJHvNBu9N9qVDoNulzgYeb73L94+J/PB97ETGsVxnXOsOTqfLywLiRfl
WVT31QT+QXsxrr/29ggKn9fI4Ay6iWAdf1USOd60SRtRBLJvOp50o661wxu51uzH
IjLbdSQ+NlSQ3sKEUpXEYxRh/9CzZP6/3WPDizT+i772jwuLK2zCcyCajeo+p/HH
vAhm1kkPOuwb66oCVXsB5KSfDEg6LLsLk3YhbLzT18xZ4C8AMQberDbN0Qk2uSho
S4Gd4Robx/P8pN3feDsNH1Dref5XSx/SrmGjcowUm4b4IP8WpxB3Dmgy9BEqdQeM
8LhZiys1nwhmLqvxUby+MykcOHxfRP5FGRSJfFCAyA27ofryaAvMQECA65Gcj3n+
zUjie1UK6GtaNpyDM0p1KT8u96XQD5UfO6TFSqFPi1mTvNMWw+tpEH78500Asc0B
j7Gsc49qJnu4tA5ggoe+cNqtvolxQWaS3zeSeUOMBVTjOd/4hjdIM1Mt0DnljMGT
UxcHb8ojCqpafbq+PErJNxJrmtKbd0QiqiGVn9RsHj1nUnpfgm6w7DKZXoCiv8hM
XYpG8mSbfJfJiJWVNthV7aoE4pbA/GgXjmfUIyQDfIaPUaivmCZn7yuVFhrZBeyO
uy3sZVsF1DhH6NudG4CCWYIw6FEOQbKNR2drfiyYeQwaq7SQIIGJDqa7hgm0Qq4j
B6AbpMX9cIqqYWv9/+pYevqf0sgNP7QJ+uhfl47VhfSBspRWkWcNV3HWvGy6WHw4
tOpAe1vFrTTr/zEls4oCgl7TtGJ95kvc20g876h4I6OTZJgGb91Fo0W2thMNWy7I
einHd/exMiDsqi3VLA1xvr1JT+YQFtzVa5QMRpa2+A8JGsaGHAGr37/EoNoDJFvo
mkfT9EZu2lpXRW2280T2KrXxCO2aMc5V74dGM7dMw8ZRQrcN/WTh4ChoI85OL5yP
3xVuIABC8KUFItUyLqqGldRia0x2T3ue831x8G5n2mSWdtEHqf6i5fX30W95+xk8
AK8i2P4D8s4NjF/OxlDKOk0z7o50I3Bk/GVx89Ef/Ga9i+1Lit+uWUSSYOWdkcG3
QkFLLadqm4XYfsZZMixjiCjvrdJN0RRgOQ2se3mzbwVcd6MllsKmK/AnwZjx7btt
m4Kg5tQ9/9Fpcra0B56R/i/Yqi95R9TRNC7+mU6XWlpZKM+GGRyQLKj1qIIzGzyh
xjDFkoe1RpWEHcv0UCD18z9GIQ42MyzsfJIC18RKAIxhKd7v7VziEkzhuWcRntrx
bblms23U78v22JUHATCyFXs8CruCMjrqTR2cqDyfe4KsEoRmgLJOgnnUZkv+6OFN
dkobhBXPhf/fN0kxyV05eLvcVafRNPdkn02OVfzSjfhwTM1ksbGnYoJg4JAk6qI1
ZzuKe9QNzoFalCMS6Vnsy+ZAs3Qjy9oNjJbiL6QB19vcm+hjKrNvMkrMijBkZ2oW
GBwkHN4gQz1ovJCoXjTMNWUikPBr7NFv+1Ygm7xACwF8i0szHEt7Fq42Tq3fZG6I
Kqbgsgm56ABN7mRJVjAGL6Bx5nOsHlxPMHIMS0I/92WuG52fqyaE4EFrFyQt7Axn
TDh5YNM7DuvE+ls09xgUJhdDz99WtyR80wluAljn4g8SQ8UuNnRg+vRt5wjtP0Fi
hFZBa5ba7x/aRTElxwtEI7cV7tkzMUajTFQ1OdWL4KvNR5EEDl5vPa8sdZuRHATC
ak8xTWIhyeleCBO1TRBpO+39LVVdGTn4Q+v6B/kRH43hKLZy/GZUUWk7ep6nTRE4
h7GWht7yOc3pyIY6NtHuCRugnlnBeDu7E3TkgwWEpscLs309SJZtOGkHDh7o/7Qx
V8XMo4nqK3d9WcfKNoduVkm3PKaBr31RZGU1Y/fzc6S5PG4W6KFklqBw/U9/mfkA
1wO+TYsnlRcZ7QxyV8etxiQBzT/IjkXldWKhBQMtphk5qR1L7h+vk6iniRvY2uUF
6pvoZs85/EQoMrq8YLLp5kPMaX9J8GNEAXjOVPo+IaVNH/a+Ouws7YTGTdT4fBlo
BFwz5zzZE+S9S2hDiFmvaQ0hWujP2fGoVLD7yFKnFZOztXKKFtrvhieeSpyysceE
gWVxhTL49UuPRtKW8F8pfi+IW9+DiuBJ3+9QBtYqiIGogZ74jHXjy8Ta8nzd1foW
EeJsA7qtW7lP5HNKDjfXJdZj4z5nCsuxyg8b5g5pjYMVwsjowUOm7zn0v2TohpvG
bfphPd7P6ppTImX4c3A6odHTmzS6iWCZLDEqMAYj597/3ZKCtlmAR4+5VElG2Ybx
tM+X3krCYws0/HeB42iJ5+aKVOTboqz3n02/pVx3+7P7I1OgeniH5JmDyuxsT0xR
XrOLHjdnKVLAYjQ1auo2usLnw3vJLHQxNOMrcHOuOzwexj4soCrQTN13NXjsMH+g
U1tv+Xint/h94m07gOpBefqSijvKHyZGC9zuQYW6n1E3CryZPPal1c3DLeEp0lMN
1euK/kVMMyj8rOLEck0oAhutLTO1R1j8WRHI5L3yBFxzx5Hkmxu4lUdAkVnGxdi2
pgX7w9kkykuhCkMkJM7JC6MOWwOIz9+XuHxlFkCtu3DrY4phK38PYcK1sZRmvaX1
tkXtlsPXsmlTtOOwx8nk3+Stmtpp90gvZeqN7/M6zGSOg2qASRsATe1ndUFdfYbj
r5Dpg6bLtK6FE9UnPmLBaZ4AMd6QOPpyKljO5wStNauZvVbVgZY3rsqxrt8AnNx8
nt+H6zs0u62fFyf8IgeJ/4zYLeaaPPl37uQkr7Rhx/ZFLfED0fJGUJzP+7HzZb+8
TXwfYYJpMMYqTd6QHTw1GVBFemWqL2d2UPQRDtZ/Ogt4FHvII3IifnA6XQZ/TN6q
QA29yLX7nO6xMn2E4+fqW/OqWQzl+RsDsj41+1FXZY4aCgCTHBTaS3keVRaeYxiS
q1xIuwtu1k45w2fWxEH8zhc/z4bjgH+PO+Mk1DSOBw51d58ujxEDW0Bb/Jcb+cZ1
fyBO7P/aSU7sgsytzgGpuXM4UcSOv7+VXSLGCnkJC400Ufjp5BjpC/d17PYMQaHV
AWPxyhRH5SGOtbmx8IHSDdlWDrFTu4t81doupuJq8I95H9TJk5NcU+1KxuZrVfZT
r0dW0wRmeePRX1YMY3TROXIRBSncW5sqn3+AzROryQ70GpdfrYTuhio+ER0uRQy1
8/yIVvbTHztFe2JfHC5JL8B6YxSwUTeX+u9ZOV+4ECjuYDLNbL+r4KX7r9E61HQu
g4OCw9l6L2MPUAZtBS7CSeNXorNLYyzr3jcO70c3l2Xd5iQVA0Ki2FeYowB1bqt+
hhXDaKrt+WIVTgWhilo63uqgbZYXZgnUa3Ol8NIwbRkQQSrEWh+Tl8g/678Wa7wP
8qcqb3ZGfpCiAyt4/zMa8+hfHxV+ofczsv0sB4MriheW8jFN9cCOLhMNZrbc3ExP
J47UhG/Nh9LOTjhC6y+rxsdD8PmiWdZOh/tuK4n184pfy+7hfESyxfxpSFyP2UZG
5aTOMKt7BRnB6Cc5OV0si3/RtLmsbsktM7eXE0ueRs03tnRTftyzZgk38BVINwDg
+MBiNAka61VdZgRXnG46VSUf2ny1qyL/ISAThQYduwOiOvXzaCssOnulyCqnBsqp
+ZmJQ7BiZQ3HwZkYkTQn4BOFtohBfCjOjv/8i2mTmNeaSUwsMzXVMsBaBjJwwQkb
7VDDPAWnF/hz+a/BTqb7LXeIvtq6VrCoM8YPDSz9phO5GzhCyCuk1odngPsX0bEZ
WZS7SzUwvPGGwGse1drbYrvY/QTjb0O7BNcipq65jh8FbaEfvI64j9Av/UwnRhod
jOzbN3PmpYn2RlpfqHshSqBFsQY0q6I8Sju73xqEK/QwSdlpWVbEvdw8Z20/Ysd6
ZeNBloHw/enSxbHZx1vqgPHuCWHCTZ0OFEkaM1lyyrv+H0bCmvHwkCwKP7oE14Fb
PY0zly8cXHVCUB6byJK8ZmRvJ6YI8y6CCLz1nzcRWGHnLnHEnTxuBboX1bZvD9mi
18gvtGXpZ5LVUMuSS3qOuCFF664DEvGiQVoyAORDiQSJ/cZJ1hN6dYBzXKhq69lF
ix9rUHZdokWhsIAr7K+ys2/AEoqaU2vz8Sov9EzWAHtXhAGT7Ef1uQctuphtvu1e
p7bw/i6mALii8Ib96YHjmFhnnycQe8t9j2QjY9CsgLsp0Izp8OpGBWJyWUZo/zh0
3bQLywu0OQYZEOknCLjCteyd48WMcWg36F/GO0amAhF50UUERWZSEd9V1Vskt9hU
D4wld/pNxMfnLo2y7jy/4+nE3BmjTGBeAuOQCwmWwTE9Mxci4yDOsMKUTtC0BMvB
V1IrXR3lThexkwJVwtFBWK9FJ7gqoZwsNAVZmLM8TjGG+ZUach9lF86IetMp9UUb
+PJ9BR1aEVw5z1fBi6s2oKSci/8m+gIPLYIQ8ehhaa1O1UANgP3u6WMDVyRejIIg
MeApUGeUWSuhdv90S3w/fpe1AwzgAUZkQRvpcMBqI3hLPJh84zukcYMTa9u62rUO
1EDx2uLvxpBAmMgHgvLVSoVmRprtMSxGMkcSwaz2cAwJ8oGt1sUYcGImmp2u9sif
JKbY65MiTLssLxBA1i2bh9/WbRgKz3249QotJJYSRklztPi5IGgOWP7HbC0GmUxy
bNdn/iOm/wJrC/B+ORFsxvROzTm8EZZFMEbrLhoJjaHA2hFn6nYrHOx6hbHVo7oj
RleVGaCj9aL79lSjqssQZdq5vKIe/nc1hW6v+80VbAzc/Ekbys8+516vytl3o5r4
KW+CT8JZNwupYHFg57O4tBpFY23DEGwwUAgXSmM2dAp6U8UBeFz1uG5mZCiWDY2R
UNIwEXTBAYgLSvYkb7FCg20Zh0CzR4uCbuAmcJyOWVzlC9H5mooGpVy8tZq+qydb
NQgflpxzkeENDTzC6wFwxOEhupVNh7DbmqnIc9SIXDj/ORurlQ5k9+uHAo2rKtzt
BM+pVw6/lpB0jCH5PARDWwLpSg9YSkTxPgsZSuu3DMFAfvUCPQAQCRy20Tqzqjme
WcHl6x/rJ4RvppbBuHJlpGn2uEwFF5jzAt5c0T3ygaJYpAGF/lkdJpdnhRcbV/2q
B8vkUgglCIt5QOldsNBDtQOGa46eRxtT/Y3Jc6OlKQ4G6yeTfdLPOJdRj5qLScIF
b3OtOMwPglf7hXcsS3ucCgox/1J0mHQsloy+uBX+qBdzkQa9fHCs3InEhgf6l1r0
rfeXmdW+RJDL9SnI2iLXNmOzO+kAeFJT5tBnTUZw0J1YGHUpe7ZuHFldgx6szjVt
n7a2ZSn4xsUVodv4uVkQpDF2jPzWrIMgi00sdaqFNe5/hIHzFhoKCwu2Xhnb1crT
QR9nZkzcK9hzc73DaRusJdC2sBc/wPOVdtimPznfQY18B9Q2cqMC4rTsWpi2pehk
BKMi6Kd2v/2CC6Cb0ug2V7OCM9idNFaib3LFZmbySbTe2WRDVCBUvZv68Isr3UPN
WuTi8hCCUOBqTVkYdvrb8ZaTuUhjuo+6lB4i4lH73HJwlwqhmMP2SZiduah3daF0
ynlmHW7dFdSln3xHP6Kp7mpGZ26eucZ2hBnoGuZdY+PlvoVNIw8UyzqKRGI3E7g/
xIfXgMEGojYIceD9725J9PJw9iIRMF5CzEyvaYNTnTWdnuxM3WIYszOYnR0P8Ohu
YIA+FTTYehepgnXYkI4n7ePzoC5ar4P7hBwD6+D8Mk4gZTK/EABRYiSvBGfMNCg9
tCm5iKdklJnP4wz9aCFDJU2s/5Zy9hNr5JVCITVGYM0e1EsHEa6e+JHs3A2WNEde
Aq6CcEDuEdZuHJbiInhI5PZntwM863biF/eVhGTGLWq06MW/7EHDLaPCSu3FYUeU
8t2HBmKoH8vFrOilQMYebwxlTTv6wqvh18NOATa4fo9FQuayMa+CDW+JZNjRko3d
Fz7qwsKKYrFhK364K2r7l0rxXCNAWyXH6Fq41Ne72RiAHPla3ULqwAernPULFPsC
prvimmP0E5m46eVJBD2LWvxdl8zGCxMm7kN30uT4C/qo+s3cceosRXZ94gmlAUJg
EWu3lXI5joXNvZPEqOfFs3O29fn/MyEmFENVO3XwSyhpjOcvA+iSW+NLPZiCDiWQ
4HLKmClo8sOMCnDwpFJL7zo1s1zVQdwhkTyXb/SysE7KETJF1zp9xVAnm5+V0wBz
YEyi+6g2xL6Pi6m6UmpAsLT9ZjBn82Igx9dJ+llb8bq+i0kmlxV6mZThNPdZmjGh
Qd8zy43lEcKKn2qQSQTnLwiYY9+ZAYL24RXDGWDvxT/zGR4rd24jGJW3SLTt6Suc
fO3+PV6sYhT1nluaFUdEecMTZ8JKC5gKenoEagw9PysQgydP113uQL/Jc5Fmp+HU
HTg5g5ewleM38+IXqOUtPL2FCdr5zCM4QinbrlcfEAQ69BOuYuD4m7MrRpFeG6g1
ECuE1T/0xeo/gQyS25iuUqi1PJKhe+HfljmLKX7AxNTBeQnzqmp1KDoLDWxN9WFU
ZpvFVWlA6vfqpFWX3Ofm+GuTN92V4H4nhudb3d8nyR3GSpncsHm8M1vHGXsgVxEA
r4e+YFRQ/akXQBuwXlsQYLVIuvLAS3jiR4HM9IHo11klpY5ZaVnNq/71mSops0h7
iaYxuSUfeXJdslSpujWd7uZjxeFMbBABi7jrd1pu7mthdmJIhmdvnbxdLylKCGn3
1xSzO1A3Rw00Wg7aa+9k4+0WFIZckX4NEQRAcpDmjl7cNXbxwIibQ5VhGDGc4rbl
7abtBEWrIq4Wm2NulgZraBqiJ4XzivzmGxV68eso3hqYPo5UHD6PailbwPfCUp6B
FeAm7aMsD6OPejPtACDRlPfnO16WvQXjTLz99Prm8pKLKD54jWJtp2g8IggjEl6N
7nHZJLRtQbyDIzBUxcMFyjhq/1STZR8hpookHBFBE0ukd70TVICLOmfzxLk+QqZp
D5d4hkHTneBufLhLJlJ2B+k2KLckRdVfoXz0tKH6YN+SelxwizZUQoxyZojMMCFB
YX8549iCeGR+GfCH8hk5AN/BL4t5OLcu29H1TIxQAw/KONG6zwKnc0S4k6lSkL1O
6QQI2RPMkfLsAaBBro+R8i0c7rxLHyZLshTIDqnkjeijFs02zZQ1WRVZ2t0ElJ/b
FsjzfJgGTM/QhsIP1/f5Ey67oMoCiBlu4aqHS62rUgtwB5wpQKGY4j5B+hu7/Mgu
etC9iINgYRjedbYEa/YUZfaLpS6LzXU6VPw8jua3KcVzYc7L0Yf4QvgfdYH6hOhs
PfHijk6AyiI+FBpogW03kKM1Z1+/tS1i7w31zEHCtrdyb4yKg/yfl5hWi0Aa5o/5
ug1P5TTE3wf5v+fNogH0sithHeLh5b5Uh1HOhefDF286t5Ml51kkPbCPYGw1ZD9k
pJ+nbn82l+7DvdHa2dqRi6g1GUp3/XlE57PNUYN+ckDQMSzdDqvEY1+vQzE8eMPG
Y8FJaAXNL5xVJeHk7Vv4ndiv3EJQ1HW+Iiq+nkcN2cDVIS30xM9IKWpmn5t3hUzm
EbQCAmXnwmEEBKdGWhvc+DmiCqGZcc8GMd8z4JuUlKwZdqldtD8mpmEKhm80YbyJ
K9SNppDsRp62rUqj8zG8xz1/tQCfd6gyUsm+VbJzajES/bD7dvarJgTnGHzfeIyJ
89mOhPVPfOIQN3mHyJEwrdZNYg43t02j/zrLI+nMxHmvwBd5x940yAAWIn0aSMP2
TfXpasZHSiRQvcLS0TRitbP6HmwNugHhDbnHeg8LfIILi/CTV0gnSn+sXBM5cOXh
SPPdl6UkLcJr0ug+zjIjGIkzGX9D9MTh0T8Pk0XRbMEF50tRraRsj69pKMvt414O
lB21gvWoLTNmek0hefkreOHsHFNRxgEotq08Xv0WSmM4CT1sI3DJcyMqE7vdBQ7I
o+SLlXYAOlxXDBlr2zJl9d4PDq581oMkxqHfDGj3CSSorlCNIki+MAlfyd8Swl63
M1+blHrXh04b/y9Hnxf7p8Mzsd/pOXBow9YY4hu24H2sjhpmHxb7yNMo3HrycYpw
AhIIYWn6fsphRKV+SRagZ1XgDt0jPeMPVdJwDiVKnLsvsMHID6EkwGck17umCCas
8xKx89JBC9RJoQb8DMnu6RZC4bnNRWZ4aNZY30l3CXASc0V2qoQgUDsCOKsL+Ons
PAXmeaZ5ieakT5mLBV1EuIF+vK8OXCEt3OJ0CD67CHGsJk75EAu4VxhGotHv2QGI
vfBmsJTs4pyLpNwaF6yCsjERSB9SM9XjRtNMPbYzy9atiB1ViKnVGIADKOSR/S8D
0e0GPYEw/Xh8CU3DBnalJYFHnQBdLppBsxN21W6ZsT6MYf7BoQEo0doPNj2OKksI
BNUNunBPc6avToS08SC39n/yBfo+nXgm2e/xZThNieihy/ijb5k7wrmulTUTIk4L
K2Mih0lwOWPi0SqKaBK+6aV75rcGVBgUejgzWco35/8jLa3LYUzjkEuXUpYiHB+c
pJw9WyzyIdAhgsZmEcqrMTXSK+tEkW9gyki8XA3deDArRz2Nlmoh0vFhR8oFaEJw
O0ctH3e2v/3pM0iYiF7zwi3WF9lEA4N1UfIR4UajVS8SNZsVtENPzgbQJ8C4o0xV
FEM2tWcJZ0h6umGkzDnBl0TV+NYbiNlAVcl7O6w8VDbV//2EQO/WqkK8RpzoK+Gm
VXZucMz0GNkBGzVuKR2eNGyG45J4tVXH9sOhiH+y6SAacxWlMEOB6f0rwLbwish1
Fwu85mVobd818jRgEe/z2yy6Bk9LArJ7Q06yXUhlZcNmXXiUJmyXw4Ehzk+TtpTv
TUqwIvpFPubwhs22T+zXCMBHoFufWqil9nbbVLH4muVrxkJAoRa5qvI7wM+i7ign
OeKBHE1rg2Xckohgyuowxw7iC9zl0MVyeWTk7TvlKIzDEux9TSBdxru5J8tzJjx0
1IUPs6O6nVIGd6dFjAXGTczCcxBekW5fdtVC3dQQgftAEsAv/iTlUNNlIuURAPYC
BN1cu1BqB43iCmZhM/9Wyq7szTyGqtLHzXt9WvotcKN+3+wsdVBviw22l4bPUvd4
LlHNMgZI36AuiEZsjw9pY/XEZi0Fc8IPGIrnqk9WjEI6jzPFxG+FjktwSPUUwodt
jXyxiE1CSuViB2GS0j9uVxEfCFpUDHaNnGF/vOjfUD8ICc4KM84vqkgFkUYFflHn
QPt3+xeYstdKVGNPrqqrji9OI1t510fNMbK1vrngDlJ41BYlpCanedE/x3UX9P5w
pMGu8bHyZ8qAylR7TUEmM/eRJuApIGvpdxKmdClfi1eucZbkOkLx3LUApowCnjwo
WZd008A4V7LWhAixMqLAlgqKDMurg11DGhk7ngmhAtvjdzcbxyvWt55OJH0HV/Yd
gi98Hx5El0A59yaAC621nRCDeMh/M4XtP+oReA2R6BBvXQvl8lgXOR2jJ/B/wIqR
j3Wk57ilOIusoC7R67ZUYp9eXElI/TBG2h0FwU/JCzTmpylIwKTA64xbu2I+fpbf
N3IeVn5riLGaB/r2wBdQKPDqy2DbsO7iWMjHJbJTBL+verqLRRARJ3ahio1DS0CX
2iAI4Tvml+6Dmg8ZPCfDEKN53QQ4kXxD0vKx9qsGCmqQfzhUrXV1NA6EbNovMOp8
ydGgVi6KS35HuXvMmzouv3sxJ0bxbcTI7LBvoBz5InjcX5gGUeegp2v9/kWKbmNF
4J2Y2Pp6I8VTOfxGbDTBt9+kuoWJLp800pr/GyHd990smDOzALRV/fwYQvT/i65k
ma/lGIuJAA8RO6q6RemyQfkGnMZvbfX38i35KLl2zMgFRX5HNSPAvBE4ga5lP1Xa
dtDSrmm322ikfJ/ylkXdSvqU8ESC8+iEqUB/9Qoic2Gj9veGe0MUQVjV7961BQ9V
uNXoJFECWqZb6qybR8POTrAqMqVVIkGC0Buw+qpunyXKgnFLxxfHc4qmffUJMWfa
g9IW5Lg3uVwdGoXwm8hq6CNU2WJ0Lusrn7/dY2LYKs8i1646t6Lh44hCvt3nyBls
cDOjkzAv9Z96TFEH78hn4pWyyPS8VgqDu6jrBnB3LhhMT1NM3dJp5aLy7mJVQbsL
rN9u2AoPamQiHQsEo5EMo76jSvO6vNG2D9dXgd6SG+n/eRS0ddC1Y8wZtNiV/ltx
q0xvsEmsp5GRl45jm/bP3n9I01y98qKssNK/PhzvlygOwi8Hu509VwK9Suc4Fmhs
1idwCto198SDQdtdMPLF7Lj01Qg+0nM8e4MSWwUeb/9e4BPtri0z5XIxVXHIwoGG
Vi4LZS2fG+U6k8YSkMRBE+++WeAwDk9x9C2dBRVFms5+kyFIB8VU0WRxka3YU3rS
tKQmIWe8/pRdZATkjcmREgr8P/lfcR/QEuP6VmhXcUjr185hXnIGDkoLtVsD+F8i
G20o/UswV7QeIpUremFuxEshdW6w9cRENX0RPgRlSmPpgfRiTEXh5iv3eloNC1Of
XalIJDU7w8XRQCBljNp+q0Ln/08OLda89S9OMn4olxnlOK7qYs7t+/FmFUh2jBVP
8OulTTkIL+u1j7sBhZtk6Tdp/ui1A3EzdmWMuN5YXZBdHXFA0gVeKXsiv3iWfzRK
iyCLCiQnUwm4nzeqaM6vU0y5/+ywRDp4CHKiszULLMUGONUlHJEt/QdPXe8Q9QL1
NpgRTNh2DlLyIqHUDXiHQcedXRO/2s2DQOSFeKx6Z/XQ7C33yFWMcDOPEJ3NZGxn
hDQ1vXqtd69JjMERPkpHiKSapkHl/a1irLNqwMofDjMvmZGRScDdDilgAjb4sV7v
K2ZbQe94qH5wFOaTcjZC7RSh3fV3RBXjLSuX73iTJCJe15+n4xERlZutvm6lzCC5
a4u0gAAy0n8byXzyawTXQczEEEAUC2pJexEWMriVfbK8zWLXAfvbN6geFBrD+M1p
Kdg16ejwGkuI1ZTqkg+3/4D7n0kZ8nel6/+qdJUDpKLf3HwTpzSXIFxkjBioT9lO
/y2BO3KrFs5o3hpjXGL0XQeDfske3wlRG4H95bVRTGQUK7b7SHchTJng6nkowfcB
H42up7VB/NEF/AARq7lPGfTwfJTl0tGK0n73Vi8yuu9mB9Cz/YfAUwZHidq72UVJ
zFJb7S7i+mHeujJSXBtj/8ag6GuM58C0ek2Io9dUibg2WWLtj266DRPuyZ+S7LaB
QT1Ogf9iFOB98UxD5sq6rP7x4y2u/eDjEyJBbq7qArEhbXc6/7YGdYdyZ+7HL/Wc
coFzflc5a9HBjJDgKqZOoqzc8POXMLybWxwDivSDbyF0b3NrtIPj5ubLXpzQaUc5
aS1U4Z0z5BZ+76NGUvdzcbosbybXf+Mrj8HhXP+ob7eCdUam1/0cKAHUvTPjKfJ2
NpZxeCgyTqAh/KgGJ/LfjxC0jRV+YlJkeQD5Q5NuLHtjswGU2743glGzvKZ9Pc+/
Ar1eE0I5WI2+ImVsO4MQlBzOidRX7VFQlojSW0Vl19etm3MrjcGwrhP9FcMh9Hd0
OZLzTsaNPk+oUC7ifRecJvEDDCMc5vFuvcgmdAf6WdxtshgJW5hSVonrpgBPjr1k
//pragma protect end_data_block
//pragma protect digest_block
X+tWUYKDSvSQwlcpHm5Nf2KNUiQ=
//pragma protect end_digest_block
//pragma protect end_protected
/////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2021 Efinix Inc. All rights reserved.
// / / \
// / / .. / simple_dual_port_ram_fifo.v
// / / .' /
// __/ /.' / Description:
// __ \ / EFX FIFO
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
//
// *******************************
module `IP_MODULE_NAME(efx_fifo_top) # (
parameter FAMILY = "TRION", // New Param
parameter SYNC_CLK = 0,
parameter BYPASS_RESET_SYNC = 0, // New Param
parameter SYNC_STAGE = 2, // New Param
parameter MODE = "STANDARD",
parameter DEPTH = 512, // Reverted (Equivalent to WDATA_DEPTH)
parameter DATA_WIDTH = 32, // Reverted (Equivalent to WDATA_WIDTH)
parameter PIPELINE_REG = 1, // Reverted (By default is ON)
parameter OPTIONAL_FLAGS = 1, // Reverted
parameter OUTPUT_REG = 0,
parameter PROGRAMMABLE_FULL = "STATIC_DUAL", // Set to "NONE" if not require this feature
parameter PROG_FULL_ASSERT = 27,
parameter PROG_FULL_NEGATE = 23,
parameter PROGRAMMABLE_EMPTY = "STATIC_DUAL", // Set to "NONE" if not require this feature
parameter PROG_EMPTY_ASSERT = 5,
parameter PROG_EMPTY_NEGATE = 7,
parameter ALMOST_FLAG = OPTIONAL_FLAGS,
parameter HANDSHAKE_FLAG = OPTIONAL_FLAGS,
parameter ASYM_WIDTH_RATIO = 4,
parameter WADDR_WIDTH = depth2width(DEPTH),
parameter RDATA_WIDTH = rdwidthcompute(ASYM_WIDTH_RATIO,DATA_WIDTH),
parameter RD_DEPTH = rddepthcompute(DEPTH,DATA_WIDTH,RDATA_WIDTH),
parameter RADDR_WIDTH = depth2width(RD_DEPTH),
parameter ENDIANESS = 0,
parameter OVERFLOW_PROTECT = 1,
parameter UNDERFLOW_PROTECT = 1,
parameter RAM_STYLE = "block_ram"
)(
input wire a_rst_i,
input wire a_wr_rst_i,
input wire a_rd_rst_i,
input wire clk_i,
input wire wr_clk_i,
input wire rd_clk_i,
input wire wr_en_i,
input wire rd_en_i,
input wire [DATA_WIDTH-1:0] wdata,
output wire almost_full_o,
output wire prog_full_o,
output wire full_o,
output wire overflow_o,
output wire wr_ack_o,
output wire [WADDR_WIDTH :0] datacount_o,
output wire [WADDR_WIDTH :0] wr_datacount_o,
output wire empty_o,
output wire almost_empty_o,
output wire prog_empty_o,
output wire underflow_o,
output wire rd_valid_o,
output wire [RDATA_WIDTH-1:0] rdata,
output wire [RADDR_WIDTH :0] rd_datacount_o,
output wire rst_busy
);
localparam WR_DEPTH = DEPTH;
localparam WDATA_WIDTH = DATA_WIDTH;
localparam RAM_MUX_RATIO = (RDATA_WIDTH <= WDATA_WIDTH/32) ? 32 :
(RDATA_WIDTH <= WDATA_WIDTH/16) ? 16 :
(RDATA_WIDTH <= WDATA_WIDTH/8) ? 8 :
(RDATA_WIDTH <= WDATA_WIDTH/4) ? 4 :
(RDATA_WIDTH <= WDATA_WIDTH/2) ? 2 :
(RDATA_WIDTH <= WDATA_WIDTH) ? 1 :
(RDATA_WIDTH <= WDATA_WIDTH*2) ? 2 :
(RDATA_WIDTH <= WDATA_WIDTH*4) ? 4 :
(RDATA_WIDTH <= WDATA_WIDTH*8) ? 8 :
(RDATA_WIDTH <= WDATA_WIDTH*16) ? 16 : 32;
wire wr_rst_int;
wire rd_rst_int;
wire wr_en_int;
wire rd_en_int;
wire [WADDR_WIDTH-1:0] waddr;
wire [RADDR_WIDTH-1:0] raddr;
wire wr_clk_int;
wire rd_clk_int;
wire [WADDR_WIDTH :0] wr_datacount_int;
wire [RADDR_WIDTH :0] rd_datacount_int;
generate
if (ASYM_WIDTH_RATIO == 4) begin
if (SYNC_CLK) begin
assign wr_clk_int = clk_i;
assign rd_clk_int = clk_i;
assign datacount_o = wr_datacount_int;
assign wr_datacount_o = {(WADDR_WIDTH+1){1'b0}};
assign rd_datacount_o = {(RADDR_WIDTH+1){1'b0}};
end
else begin
assign wr_clk_int = wr_clk_i;
assign rd_clk_int = rd_clk_i;
assign datacount_o = {(WADDR_WIDTH+1){1'b0}};
assign wr_datacount_o = wr_datacount_int;
assign rd_datacount_o = rd_datacount_int;
end
end
else begin
assign datacount_o = {(WADDR_WIDTH+1){1'b0}};
assign wr_datacount_o = wr_datacount_int;
assign rd_datacount_o = rd_datacount_int;
if (SYNC_CLK) begin
assign wr_clk_int = clk_i;
assign rd_clk_int = clk_i;
end
else begin
assign wr_clk_int = wr_clk_i;
assign rd_clk_int = rd_clk_i;
end
end
if (!SYNC_CLK) begin
//(* async_reg = "true" *) reg [1:0] wr_rst;
//(* async_reg = "true" *) reg [1:0] rd_rst;
//
//always @ (posedge wr_clk_int or posedge a_rst_i) begin
// if (a_rst_i)
// wr_rst <= 2'b11;
// else
// wr_rst <= {wr_rst[0],1'b0};
//end
//
//always @ (posedge rd_clk_int or posedge a_rst_i) begin
// if (a_rst_i)
// rd_rst <= 2'b11;
// else
// rd_rst <= {rd_rst[0],1'b0};
//end
if (BYPASS_RESET_SYNC) begin
assign wr_rst_int = a_wr_rst_i;
assign rd_rst_int = a_rd_rst_i;
assign rst_busy = 1'b0;
end
else begin
`IP_MODULE_NAME(efx_resetsync) #(
.ACTIVE_LOW (0)
) efx_resetsync_wr_rst (
.clk (wr_clk_int),
.reset (a_rst_i),
.d_o (wr_rst_int)
);
`IP_MODULE_NAME(efx_resetsync) #(
.ACTIVE_LOW (0)
) efx_resetsync_rd_rst (
.clk (rd_clk_int),
.reset (a_rst_i),
.d_o (rd_rst_int)
);
assign rst_busy = wr_rst_int | rd_rst_int;
end
end
else begin
//(* async_reg = "true" *) reg [1:0] a_rst;
//
//always @ (posedge clk_i or posedge a_rst_i) begin
// if (a_rst_i)
// a_rst <= 2'b11;
// else
// a_rst <= {a_rst[0],1'b0};
//end
wire a_rst;
`IP_MODULE_NAME(efx_resetsync) #(
.ACTIVE_LOW (0)
) efx_resetsync_a_rst (
.clk (clk_i),
.reset (a_rst_i),
.d_o (a_rst)
);
if (BYPASS_RESET_SYNC) begin
assign wr_rst_int = a_rst_i;
assign rd_rst_int = a_rst_i;
assign rst_busy = 1'b0;
end
else begin
assign wr_rst_int = a_rst;
assign rd_rst_int = a_rst;
assign rst_busy = wr_rst_int | rd_rst_int;
end
end
endgenerate
`IP_MODULE_NAME(efx_fifo_ram) # (
.FAMILY (FAMILY),
.WR_DEPTH (WR_DEPTH),
.RD_DEPTH (RD_DEPTH),
.WDATA_WIDTH (WDATA_WIDTH),
.RDATA_WIDTH (RDATA_WIDTH),
.WADDR_WIDTH (WADDR_WIDTH),
.RADDR_WIDTH (RADDR_WIDTH),
.OUTPUT_REG (OUTPUT_REG),
.RAM_MUX_RATIO (RAM_MUX_RATIO),
.ENDIANESS (ENDIANESS),
.RAM_STYLE (RAM_STYLE)
) xefx_fifo_ram (
.wdata (wdata),
.waddr (waddr),
.raddr (raddr),
.we (wr_en_int),
.re (rd_en_int),
.wclk (wr_clk_int),
.rclk (rd_clk_int),
.rdata (rdata)
);
`IP_MODULE_NAME(efx_fifo_ctl) # (
.SYNC_CLK (SYNC_CLK),
.SYNC_STAGE (SYNC_STAGE),
.MODE (MODE),
.WR_DEPTH (WR_DEPTH),
.WADDR_WIDTH (WADDR_WIDTH),
.RADDR_WIDTH (RADDR_WIDTH),
.ASYM_WIDTH_RATIO (ASYM_WIDTH_RATIO),
.RAM_MUX_RATIO (RAM_MUX_RATIO),
.PIPELINE_REG (PIPELINE_REG),
.ALMOST_FLAG (ALMOST_FLAG),
.PROGRAMMABLE_FULL (PROGRAMMABLE_FULL),
.PROG_FULL_ASSERT (PROG_FULL_ASSERT),
.PROG_FULL_NEGATE (PROG_FULL_NEGATE),
.PROGRAMMABLE_EMPTY (PROGRAMMABLE_EMPTY),
.PROG_EMPTY_ASSERT (PROG_EMPTY_ASSERT),
.PROG_EMPTY_NEGATE (PROG_EMPTY_NEGATE),
.OUTPUT_REG (OUTPUT_REG),
.HANDSHAKE_FLAG (HANDSHAKE_FLAG),
.OVERFLOW_PROTECT (OVERFLOW_PROTECT),
.UNDERFLOW_PROTECT (UNDERFLOW_PROTECT)
) xefx_fifo_ctl (
.wr_rst (wr_rst_int),
.rd_rst (rd_rst_int),
.wclk (wr_clk_int),
.rclk (rd_clk_int),
.we (wr_en_i),
.re (rd_en_i),
.wr_full (full_o),
.wr_ack (wr_ack_o),
.rd_empty (empty_o),
.wr_almost_full (almost_full_o),
.rd_almost_empty (almost_empty_o),
.wr_prog_full (prog_full_o),
.rd_prog_empty (prog_empty_o),
.wr_en_int (wr_en_int),
.rd_en_int (rd_en_int),
.waddr (waddr),
.raddr (raddr),
.wr_datacount (wr_datacount_int),
.rd_datacount (rd_datacount_int),
.rd_vld (rd_valid_o),
.wr_overflow (overflow_o),
.rd_underflow (underflow_o)
);
function integer depth2width;
input [31:0] depth;
begin : fnDepth2Width
if (depth > 1) begin
depth = depth - 1;
for (depth2width=0; depth>0; depth2width = depth2width + 1)
depth = depth>>1;
end
else
depth2width = 0;
end
endfunction
function integer width2depth;
input [31:0] width;
begin : fnWidth2Depth
width2depth = width**2;
end
endfunction
function integer rdwidthcompute;
input [31:0] asym_option;
input [31:0] wr_width;
begin : RdWidthCompute
rdwidthcompute = (asym_option==0)? wr_width/16 :
(asym_option==1)? wr_width/8 :
(asym_option==2)? wr_width/4 :
(asym_option==3)? wr_width/2 :
(asym_option==4)? wr_width/1 :
(asym_option==5)? wr_width*2 :
(asym_option==6)? wr_width*4 :
(asym_option==7)? wr_width*8 :
(asym_option==8)? wr_width*16 : wr_width/1;
end
endfunction
function integer rddepthcompute;
input [31:0] wr_depth;
input [31:0] wr_width;
input [31:0] rd_width;
begin : RdDepthCompute
rddepthcompute = (wr_depth * wr_width) / rd_width;
end
endfunction
endmodule
/////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2021 Efinix Inc. All rights reserved.
// / / \
// / / .. / simple_dual_port_ram_fifo.v
// / / .' /
// __/ /.' / Description:
// __ \ / EFX FIFO
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
//
// *******************************
module `IP_MODULE_NAME(efx_fifo_ram) #(
parameter FAMILY = "TRION",
parameter WR_DEPTH = 512,
parameter RD_DEPTH = 512,
parameter WDATA_WIDTH = 8,
parameter RDATA_WIDTH = 8,
parameter WADDR_WIDTH = 9,
parameter RADDR_WIDTH = 9,
parameter OUTPUT_REG = 1,
parameter RAM_MUX_RATIO = 4,
parameter ENDIANESS = 0, //0: Big endian (default) 1: Little endian
parameter RAM_STYLE = "block_ram"
) (
input wire wclk,
input wire rclk,
input wire we,
input wire re,
input wire [(WDATA_WIDTH-1):0] wdata,
input wire [(WADDR_WIDTH-1):0] waddr,
input wire [(RADDR_WIDTH-1):0] raddr,
output wire [(RDATA_WIDTH-1):0] rdata
);
localparam MEM_DEPTH = (WR_DEPTH > RD_DEPTH) ? WR_DEPTH : RD_DEPTH;
localparam MEM_DATA_WIDTH = (WDATA_WIDTH > RDATA_WIDTH) ? RDATA_WIDTH : WDATA_WIDTH;
localparam LSB_WIDTH = (WADDR_WIDTH > RADDR_WIDTH) ? (WADDR_WIDTH - RADDR_WIDTH) : (RADDR_WIDTH - WADDR_WIDTH);
localparam RDATA_WDATA_RATIO = (RDATA_WIDTH <= WDATA_WIDTH/32) ? "ONE_THIRTYTWO" :
(RDATA_WIDTH <= WDATA_WIDTH/16) ? "ONE_SIXTEENTH" :
(RDATA_WIDTH <= WDATA_WIDTH/8) ? "ONE_EIGHTH" :
(RDATA_WIDTH <= WDATA_WIDTH/4) ? "ONE_FOURTH" :
(RDATA_WIDTH <= WDATA_WIDTH/2) ? "ONE_HALF" :
(RDATA_WIDTH <= WDATA_WIDTH) ? "ONE" :
(RDATA_WIDTH <= WDATA_WIDTH*2) ? "TWO_TIMES" :
(RDATA_WIDTH <= WDATA_WIDTH*4) ? "FOUR_TIMES" :
(RDATA_WIDTH <= WDATA_WIDTH*4) ? "EIGHT_TIMES" :
(RDATA_WIDTH <= WDATA_WIDTH*4) ? "SIXTEEN_TIMES" : "THIRTYTWO_TIMES";
(* syn_ramstyle = RAM_STYLE *) reg [MEM_DATA_WIDTH-1:0] ram[MEM_DEPTH-1:0];
reg [RDATA_WIDTH-1:0] r_rdata_1P;
reg [RDATA_WIDTH-1:0] r_rdata_2P;
wire re_int;
generate
if (FAMILY == "TRION") begin
if (RDATA_WDATA_RATIO == "ONE") begin
always @ (posedge wclk) begin
if (we)
ram[waddr] <= wdata;
end
always @ (posedge rclk) begin
if (re_int) begin
r_rdata_1P <= ram[raddr];
end
r_rdata_2P <= r_rdata_1P;
end
end
else if (RDATA_WDATA_RATIO == "ONE_THIRTYTWO" || RDATA_WDATA_RATIO == "ONE_SIXTEENTH" || RDATA_WDATA_RATIO == "ONE_EIGHTH" || RDATA_WDATA_RATIO == "ONE_FOURTH" || RDATA_WDATA_RATIO == "ONE_HALF" ) begin
if (ENDIANESS == 0) begin
integer i;
always @ (posedge wclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (we) begin
ram[{waddr,LSB_WIDTH'(RAM_MUX_RATIO-1-i)}] <= wdata[((WDATA_WIDTH/RAM_MUX_RATIO)*i) +: WDATA_WIDTH/RAM_MUX_RATIO];
end
end
end
always @ (posedge rclk) begin
if (re_int) begin
r_rdata_1P <= ram[raddr];
end
r_rdata_2P <= r_rdata_1P;
end
end
else begin //endianess == 1
integer i;
always @ (posedge wclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (we) begin
ram[{waddr,LSB_WIDTH'(i)}] <= wdata[((WDATA_WIDTH/RAM_MUX_RATIO)*i) +: WDATA_WIDTH/RAM_MUX_RATIO];
end
end
end
always @ (posedge rclk) begin
if (re_int) begin
r_rdata_1P <= ram[raddr];
end
r_rdata_2P <= r_rdata_1P;
end
end
end
else if (RDATA_WDATA_RATIO == "TWO_TIMES" || RDATA_WDATA_RATIO == "FOUR_TIMES" || RDATA_WDATA_RATIO == "EIGHT_TIMES" || RDATA_WDATA_RATIO == "SIXTEEN_TIMES" ||RDATA_WDATA_RATIO == "THIRTYTWO_TIMES" ) begin
//integer i;
if (ENDIANESS == 0) begin
always @ (posedge wclk) begin
if (we)
ram[waddr] <= wdata;
end
integer i;
always @ (posedge rclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (re_int) begin
r_rdata_1P[((RDATA_WIDTH/RAM_MUX_RATIO)*i) +: RDATA_WIDTH/RAM_MUX_RATIO] <= ram[{raddr,LSB_WIDTH'(RAM_MUX_RATIO-1-i)}];
end
r_rdata_2P <= r_rdata_1P;
end
end
end
else begin //endianess == 1
always @ (posedge wclk) begin
if (we)
ram[waddr] <= wdata;
end
integer i;
always @ (posedge rclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (re_int) begin
r_rdata_1P[((RDATA_WIDTH/RAM_MUX_RATIO)*i) +: RDATA_WIDTH/RAM_MUX_RATIO] <= ram[{raddr,LSB_WIDTH'(i)}];
end
r_rdata_2P <= r_rdata_1P;
end
end
end
end
if (OUTPUT_REG) begin
assign re_int = re;
assign rdata = r_rdata_2P;
end
else begin
assign re_int = re;
assign rdata = r_rdata_1P;
end
end
else begin
if (RDATA_WDATA_RATIO == "ONE") begin
always @ (posedge wclk) begin
if (we)
ram[waddr] <= wdata;
end
always @ (posedge rclk) begin
if (re_int) begin
r_rdata_1P <= ram[raddr];
r_rdata_2P <= r_rdata_1P;
end
end
end
else if (RDATA_WDATA_RATIO == "ONE_THIRTYTWO" || RDATA_WDATA_RATIO == "ONE_SIXTEENTH" || RDATA_WDATA_RATIO == "ONE_EIGHTH" || RDATA_WDATA_RATIO == "ONE_FOURTH" || RDATA_WDATA_RATIO == "ONE_HALF" ) begin
//integer i;
if (ENDIANESS == 0) begin
integer i;
always @ (posedge wclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (we) begin
ram[{waddr,LSB_WIDTH'(RAM_MUX_RATIO-1-i)}] <= wdata[((WDATA_WIDTH/RAM_MUX_RATIO)*i) +: WDATA_WIDTH/RAM_MUX_RATIO];
end
end
end
always @ (posedge rclk) begin
if (re_int) begin
r_rdata_1P <= ram[raddr];
r_rdata_2P <= r_rdata_1P;
end
end
end
else begin //endianess == 1
integer i;
always @ (posedge wclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (we) begin
ram[{waddr,LSB_WIDTH'(i)}] <= wdata[((WDATA_WIDTH/RAM_MUX_RATIO)*i) +: WDATA_WIDTH/RAM_MUX_RATIO];
end
end
end
always @ (posedge rclk) begin
if (re_int) begin
r_rdata_1P <= ram[raddr];
r_rdata_2P <= r_rdata_1P;
end
end
end
end
else if (RDATA_WDATA_RATIO == "TWO_TIMES" || RDATA_WDATA_RATIO == "FOUR_TIMES" || RDATA_WDATA_RATIO == "EIGHT_TIMES" || RDATA_WDATA_RATIO == "SIXTEEN_TIMES" || RDATA_WDATA_RATIO == "THIRTYTWO_TIMES" ) begin
//integer i;
if (ENDIANESS == 0) begin
always @ (posedge wclk) begin
if (we)
ram[waddr] <= wdata;
end
integer i;
always @ (posedge rclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (re_int) begin
r_rdata_1P[((RDATA_WIDTH/RAM_MUX_RATIO)*i) +: RDATA_WIDTH/RAM_MUX_RATIO] <= ram[{raddr,LSB_WIDTH'(RAM_MUX_RATIO-1-i)}];
r_rdata_2P <= r_rdata_1P;
end
end
end
end
else begin //endianess ==1
always @ (posedge wclk) begin
if (we)
ram[waddr] <= wdata;
end
integer i;
always @ (posedge rclk) begin
for (i=0; i<RAM_MUX_RATIO; i=i+1) begin
if (re_int) begin
r_rdata_1P[((RDATA_WIDTH/RAM_MUX_RATIO)*i) +: RDATA_WIDTH/RAM_MUX_RATIO] <= ram[{raddr,LSB_WIDTH'(i)}];
r_rdata_2P <= r_rdata_1P;
end
end
end
end
end
// NIC
//if (MODE == "STANDARD") begin
// if (OUTPUT_REG) begin
// reg re_r;
// always @ (posedge rclk) begin
// re_r <= re;
// end
// assign re_int = re | re_r;
// assign rdata = r_rdata_2P;
// end
// else begin
// assign re_int = re;
// assign rdata = r_rdata_1P;
// end
//end
//else begin
// assign re_int = re;
// assign rdata = r_rdata_1P;
//end
if (OUTPUT_REG) begin
reg re_r;
always @ (posedge rclk) begin
re_r <= re;
end
assign re_int = re | re_r;
assign rdata = r_rdata_2P;
end
else begin
assign re_int = re;
assign rdata = r_rdata_1P;
end
end
endgenerate
endmodule
////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2013-2021 Efinix Inc. All rights reserved.
//
// This document contains proprietary information which is
// protected by copyright. All rights are reserved. This notice
// refers to original work by Efinix, Inc. which may be derivitive
// of other work distributed under license of the authors. In the
// case of derivative work, nothing in this notice overrides the
// original author's license agreement. Where applicable, the
// original license agreement is included in it's original
// unmodified form immediately below this header.
//
// WARRANTY DISCLAIMER.
// THE DESIGN, CODE, OR INFORMATION ARE PROVIDED “AS IS” AND
// EFINIX MAKES NO WARRANTIES, EXPRESS OR IMPLIED WITH
// RESPECT THERETO, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES,
// INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY, NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR
// PURPOSE. SOME STATES DO NOT ALLOW EXCLUSIONS OF AN IMPLIED
// WARRANTY, SO THIS DISCLAIMER MAY NOT APPLY TO LICENSEE.
//
// LIMITATION OF LIABILITY.
// NOTWITHSTANDING ANYTHING TO THE CONTRARY, EXCEPT FOR BODILY
// INJURY, EFINIX SHALL NOT BE LIABLE WITH RESPECT TO ANY SUBJECT
// MATTER OF THIS AGREEMENT UNDER TORT, CONTRACT, STRICT LIABILITY
// OR ANY OTHER LEGAL OR EQUITABLE THEORY (I) FOR ANY INDIRECT,
// SPECIAL, INCIDENTAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES OF ANY
// CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF
// GOODWILL, DATA OR PROFIT, WORK STOPPAGE, OR COMPUTER FAILURE OR
// MALFUNCTION, OR IN ANY EVENT (II) FOR ANY AMOUNT IN EXCESS, IN
// THE AGGREGATE, OF THE FEE PAID BY LICENSEE TO EFINIX HEREUNDER
// (OR, IF THE FEE HAS BEEN WAIVED, $100), EVEN IF EFINIX SHALL HAVE
// BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO
// NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR
// CONSEQUENTIAL DAMAGES, SO THIS LIMITATION AND EXCLUSION MAY NOT
// APPLY TO LICENSEE.
//
////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
// / / \
// / / .. / gray2bin.v
// / / .' /
// __/ /.' / Description:
// __ \ / Gray to Binary Encoding Convertor
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
// 1.0 Initial rev
//
// *******************************
`resetall
`timescale 1ns/1ps
module `IP_MODULE_NAME(efx_fifo_gray2bin)
#(parameter WIDTH=5)
(// outputs
output wire [WIDTH-1:0] bin_o,
// input
input [WIDTH-1:0] gray_i);
//---------------------------------------------------------------------
// Recursive Module
// Description: reduction xor
generate
if (WIDTH > 1) begin
wire [1:0] bin_1;
assign bin_1 = {gray_i[WIDTH-1], gray_i[WIDTH-1]^gray_i[WIDTH-2]};
if (WIDTH == 2) begin
assign bin_o = bin_1;
end
else begin
assign bin_o[WIDTH-1] = bin_1[1];
`IP_MODULE_NAME(efx_fifo_gray2bin) #(.WIDTH(WIDTH-1)) u_gray2bin (.bin_o(bin_o[WIDTH-2:0]), .gray_i({bin_1[0], gray_i[WIDTH-3:0]}));
end
end
else /* if (WIDTH == 1) */
assign bin_o = gray_i;
endgenerate
endmodule
////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
//
// This document contains proprietary information which is
// protected by copyright. All rights are reserved. This notice
// refers to original work by Efinix, Inc. which may be derivitive
// of other work distributed under license of the authors. In the
// case of derivative work, nothing in this notice overrides the
// original author's license agreement. Where applicable, the
// original license agreement is included in it's original
// unmodified form immediately below this header.
//
// WARRANTY DISCLAIMER.
// THE DESIGN, CODE, OR INFORMATION ARE PROVIDED “AS IS” AND
// EFINIX MAKES NO WARRANTIES, EXPRESS OR IMPLIED WITH
// RESPECT THERETO, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES,
// INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY, NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR
// PURPOSE. SOME STATES DO NOT ALLOW EXCLUSIONS OF AN IMPLIED
// WARRANTY, SO THIS DISCLAIMER MAY NOT APPLY TO LICENSEE.
//
// LIMITATION OF LIABILITY.
// NOTWITHSTANDING ANYTHING TO THE CONTRARY, EXCEPT FOR BODILY
// INJURY, EFINIX SHALL NOT BE LIABLE WITH RESPECT TO ANY SUBJECT
// MATTER OF THIS AGREEMENT UNDER TORT, CONTRACT, STRICT LIABILITY
// OR ANY OTHER LEGAL OR EQUITABLE THEORY (I) FOR ANY INDIRECT,
// SPECIAL, INCIDENTAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES OF ANY
// CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF
// GOODWILL, DATA OR PROFIT, WORK STOPPAGE, OR COMPUTER FAILURE OR
// MALFUNCTION, OR IN ANY EVENT (II) FOR ANY AMOUNT IN EXCESS, IN
// THE AGGREGATE, OF THE FEE PAID BY LICENSEE TO EFINIX HEREUNDER
// (OR, IF THE FEE HAS BEEN WAIVED, $100), EVEN IF EFINIX SHALL HAVE
// BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO
// NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR
// CONSEQUENTIAL DAMAGES, SO THIS LIMITATION AND EXCLUSION MAY NOT
// APPLY TO LICENSEE.
//
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
// / / \
// / / .. / pipe_reg.v
// / / .' /
// __/ /.' / Description:
// __ \ / Parallel Pipelining Shift Register
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
// 1.0 Initial rev
//
// *******************************
module `IP_MODULE_NAME(efx_fifo_datasync) #(
parameter STAGE = 32,
parameter WIDTH = 4
) (
input wire clk_i,
input wire [WIDTH-1:0] d_i,
output wire [WIDTH-1:0] d_o
);
(* async_reg = "true" *) reg [WIDTH-1:0] pipe_reg [STAGE-1:0];
integer i;
always @(posedge clk_i) begin
for (i=STAGE-1; i>0; i = i - 1) begin
pipe_reg[i] <= pipe_reg[i-1];
end
pipe_reg[0] <= d_i;
end
assign d_o = pipe_reg[STAGE-1];
endmodule
////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
//
// This document contains proprietary information which is
// protected by copyright. All rights are reserved. This notice
// refers to original work by Efinix, Inc. which may be derivitive
// of other work distributed under license of the authors. In the
// case of derivative work, nothing in this notice overrides the
// original author's license agreement. Where applicable, the
// original license agreement is included in it's original
// unmodified form immediately below this header.
//
// WARRANTY DISCLAIMER.
// THE DESIGN, CODE, OR INFORMATION ARE PROVIDED “AS IS” AND
// EFINIX MAKES NO WARRANTIES, EXPRESS OR IMPLIED WITH
// RESPECT THERETO, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES,
// INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY, NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR
// PURPOSE. SOME STATES DO NOT ALLOW EXCLUSIONS OF AN IMPLIED
// WARRANTY, SO THIS DISCLAIMER MAY NOT APPLY TO LICENSEE.
//
// LIMITATION OF LIABILITY.
// NOTWITHSTANDING ANYTHING TO THE CONTRARY, EXCEPT FOR BODILY
// INJURY, EFINIX SHALL NOT BE LIABLE WITH RESPECT TO ANY SUBJECT
// MATTER OF THIS AGREEMENT UNDER TORT, CONTRACT, STRICT LIABILITY
// OR ANY OTHER LEGAL OR EQUITABLE THEORY (I) FOR ANY INDIRECT,
// SPECIAL, INCIDENTAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES OF ANY
// CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF
// GOODWILL, DATA OR PROFIT, WORK STOPPAGE, OR COMPUTER FAILURE OR
// MALFUNCTION, OR IN ANY EVENT (II) FOR ANY AMOUNT IN EXCESS, IN
// THE AGGREGATE, OF THE FEE PAID BY LICENSEE TO EFINIX HEREUNDER
// (OR, IF THE FEE HAS BEEN WAIVED, $100), EVEN IF EFINIX SHALL HAVE
// BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO
// NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR
// CONSEQUENTIAL DAMAGES, SO THIS LIMITATION AND EXCLUSION MAY NOT
// APPLY TO LICENSEE.
//
////////////////////////////////////////////////////////////////////////////////
// synopsys translate_off
`timescale 1 ns / 1 ps
// synopsys translate_on
module `IP_MODULE_NAME(efx_resetsync) #(
parameter ASYNC_STAGE = 2,
parameter ACTIVE_LOW = 1
) (
input wire clk,
input wire reset,
output wire d_o
);
generate
if (ACTIVE_LOW == 1) begin: active_low
`IP_MODULE_NAME(efx_asyncreg) #(
.WIDTH (1),
.ACTIVE_LOW (1),
.RST_VALUE (0)
) efx_resetsync_active_low (
.clk (clk),
.reset_n (reset),
.d_i (1'b1),
.d_o (d_o)
);
end
else begin: active_high
`IP_MODULE_NAME(efx_asyncreg) #(
.WIDTH (1),
.ACTIVE_LOW (0),
.RST_VALUE (1)
) efx_resetsync_active_high (
.clk (clk),
.reset_n (reset),
.d_i (1'b0),
.d_o (d_o)
);
end
endgenerate
endmodule
// synopsys translate_off
`timescale 1 ns / 1 ps
// synopsys translate_on
module `IP_MODULE_NAME(efx_asyncreg) #(
parameter ASYNC_STAGE = 2,
parameter WIDTH = 4,
parameter ACTIVE_LOW = 1, // 0 - Active high reset, 1 - Active low reset
parameter RST_VALUE = 0,
parameter OFF_ASSERTION = 0 // 1 = Turn off PULSE_WIDTH_CHK assertion for a particular instance
) (
input wire clk,
input wire reset_n,
input wire [WIDTH-1:0] d_i,
output wire [WIDTH-1:0] d_o
);
`pragma protect begin_protected
`pragma protect version = 1
`pragma protect author = "author-a" , author_info = "author-a-details"
`pragma protect encrypt_agent = "QuestaSim" , encrypt_agent_info = "2023.4"
`pragma protect key_keyowner = "Efinix Inc." , key_keyname = "EFX_K01"
`pragma protect key_method = "rsa"
`pragma protect encoding = ( enctype = "base64" , line_length = 64 , bytes = 256 )
`pragma protect key_block
IjzmeF2ACtI8q/MHPcSQakfCyuQSUgg747Z3U+BWZdCStFbqF/Rhg0VPl8JT+91V
o/8Ohsiw6GnpSIX69XazqGYmhEjb+W7W2ngBYentEXdSyzUYvEbr8i71cL04f1fE
El78uYgSvjFwoDyocXOVYk8JA0v7y6WnabkL02lAqASKGQK55nzfKeUVbJHKHjAY
kIT3Nf7JWK2NVVymI1Zs5QttwrNgKBSqoiPvmy4+16bTQMx4R205Bb4rT1MqSqIc
/5U5/Z1e1tZzOqoEyhfcMMKW0emdBIdByNvteK05ZATt11Uzj2M/Vn1r9KmYd0h1
uYJaS5tuGEuFInBHa7oO8g==
`pragma protect key_keyowner = "Cadence Design Systems." , key_keyname = "CDS_RSA_KEY_VER_2"
`pragma protect key_method = "rsa"
`pragma protect encoding = ( enctype = "base64" , line_length = 64 , bytes = 256 )
`pragma protect key_block
ABJo/BvEH9XbZrt+xPOQ2C7yeLcnebDlRELbHyCdXeeNkZRVZ9m0ie+1HufS/I+3
fC63lnVTenVdf9s4tm1RLd5VBkmFb37ikgaESy2aRKWsdLG6x2OyuODoMDRCjYUa
rxhnwLWh5E55yR3XVZgM2k7/NPP2cTL7iOSCjH4No38siNjs4Fapyc4FFq0TOsQq
PMqsZ5jgmM+ZT8cil0wMt5tpdEOwvchbe1GcZLIhcIFLD/Gb2XtP0Q0QkOlNzuiL
DNyobLTjDkV5si+/23Ng2E7tDq+SX+vJP4ciI63kXtsmQdn1ff2Y64ibNXJtpu/w
K3OoKmk3zFeArSsql8B4/Q==
`pragma protect key_keyowner = "Synopsys" , key_keyname = "SNPS-VCS-RSA-2"
`pragma protect key_method = "rsa"
`pragma protect encoding = ( enctype = "base64" , line_length = 64 , bytes = 128 )
`pragma protect key_block
RAoMYYsrw2j05cvQ8NR0lCh+Ia/OGVfdwZqq0pwIkgDzO3Z7ol96oQmQzFfIQY/M
GzEOFdYJTfjnxPvhSPxT1tpq2Fgx6PbC2FMWFtN6/TrG/s01ifIWIZ9Wrfo8Q01l
6XTAESHR1htrOOx6AiDHAQLOlBb0zgfZjayGJBRX7FI=
`pragma protect key_keyowner = "Aldec" , key_keyname = "ALDEC15_001"
`pragma protect key_method = "rsa"
`pragma protect encoding = ( enctype = "base64" , line_length = 64 , bytes = 256 )
`pragma protect key_block
YclPuIbYLW/ftZYybucr9ooblGFkJDcdUWf6kCJBGKpIRjItUB3LdSwcREekRWqf
RGiSRFoyrOTiScT06zZ4fkm+PEKj8O3RU1VMMzDjuEUqkAEELJHNOH71tCSC6MWk
1dop7MZy8BSXhzg3W3RXIA8IGSJRDibliv+SjkbUzg/WceDI176fJmUwGUji93Tw
Zu2vRjA/RTi3ZMzS/2Z9YE156hpipJ/Cu6ca8V3y5Kt6DX4fcCS09xESr6soT5Oz
eKRExN7wu8dvYMUuu1YgCVVR47BBDQi3wdZHqlq1PLaycnNOwBPLOAzA19Hefh/0
2HflB1HYKxojQCcZU7qUgQ==
`pragma protect key_keyowner = "Siemens" , key_keyname = "SIEMENS-VERIF-SIM-RSA-2"
`pragma protect key_method = "rsa"
`pragma protect encoding = ( enctype = "base64" , line_length = 64 , bytes = 256 )
`pragma protect key_block
fMvC6d2jTMqMqGFzPCPWt6pV9wRUCG4/taH3Nfn7RcekdiLyXQEQgm1SN+X+hkbx
Pu7552vaw2ez4j3zrTk2vRPnDAsxY8GidEnkJcULi8kiia9Xy/ePFLxOJHHigkiB
rU7uwrFblcYYBRwQjhMhJDowyR9HVAonxhOWVIlYagtABxLYlNdDEn+N4yPLVCsr
XUWy1E2L5GUFFNQffENN0iyUaKdWAKGIqgIZK1sB3tVOPVsULetSoyzRErWPNZQD
e5jbBBNZGyQQWgOJkOfy280ekoUUEZajqtB1jDvE3k8kbo4rzvr7yTkhSzLqjGod
B2Zpo2FQ//YDRSAaEa9ksQ==
`pragma protect key_keyowner = "Mentor Graphics Corporation" , key_keyname = "MGC-VERIF-SIM-RSA-2"
`pragma protect key_method = "rsa"
`pragma protect encoding = ( enctype = "base64" , line_length = 64 , bytes = 256 )
`pragma protect key_block
TcmE9lQROafuvxGWP3fMVxDoeaiMX6ALoT3detg/qWZ36+yPTc/t8N7/DtSx17Ze
vr6iBb+ge3aAzWAq2QHyVfgVV15dvW/HsOXXTh7UqExiO7Dxa6nHXuAhYMON6NP2
ihfIRSvdnrL2ufvg7A2rCHGAqnr6cVnRLfhNJxtA1lloQbJEtlf/CWNblDxEfyw2
06l3l8pp1rS0E4tMqagmOr+yhNSpcS9vQswFltqroh6kNIE64zKri96HKkRFLNlP
fpsN7plEpLS54SxIMmh8Op+w0a/jXVOxxD+FLepsZWfGiNksENgu2Xo6TvZIQUUN
ZoPzFCMjGk5ZmMyIlytNCw==
`pragma protect data_method = "aes256-cbc"
`pragma protect encoding = ( enctype = "base64" , line_length = 64 , bytes = 4288 )
`pragma protect data_block
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
Ei7EaFpheCmlTJyxUg8TdA==
`pragma protect end_protected
/////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2021 Efinix Inc. All rights reserved.
// / / \
// / / .. / simple_dual_port_ram_fifo.v
// / / .' /
// __/ /.' / Description:
// __ \ / EFX FIFO
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
//
// *******************************
module `IP_MODULE_NAME(efx_fifo_ctl) # (
parameter SYNC_CLK = 1,
parameter SYNC_STAGE = 2,
parameter MODE = "STANDARD",
parameter WR_DEPTH = 512,
parameter WADDR_WIDTH = 9,
parameter RADDR_WIDTH = 9,
parameter ASYM_WIDTH_RATIO = 4,
parameter RAM_MUX_RATIO = 1,
parameter PIPELINE_REG = 1,
parameter ALMOST_FLAG = 1,
parameter PROGRAMMABLE_FULL = "NONE",
parameter PROG_FULL_ASSERT = 0,
parameter PROG_FULL_NEGATE = 0,
parameter PROGRAMMABLE_EMPTY = "NONE",
parameter PROG_EMPTY_ASSERT = 0,
parameter PROG_EMPTY_NEGATE = 0,
parameter OUTPUT_REG = 0,
parameter HANDSHAKE_FLAG = 1,
parameter OVERFLOW_PROTECT = 0,
parameter UNDERFLOW_PROTECT = 0
)(
input wire wr_rst,
input wire rd_rst,
input wire wclk,
input wire rclk,
input wire we,
input wire re,
output wire wr_full,
output reg wr_ack,
output wire wr_almost_full,
output wire rd_empty,
output wire rd_almost_empty,
output wire wr_prog_full,
output wire rd_prog_empty,
output wire wr_en_int,
output wire rd_en_int,
output wire [WADDR_WIDTH-1:0] waddr,
output wire [RADDR_WIDTH-1:0] raddr,
output wire [WADDR_WIDTH:0] wr_datacount,
output wire [RADDR_WIDTH:0] rd_datacount,
output wire rd_vld,
output reg wr_overflow,
output reg rd_underflow
);
reg [WADDR_WIDTH:0] waddr_cntr;
reg [WADDR_WIDTH:0] waddr_cntr_r;
reg [RADDR_WIDTH:0] raddr_cntr;
reg rd_valid;
wire [WADDR_WIDTH:0] waddr_int;
wire [RADDR_WIDTH:0] raddr_int;
wire rd_empty_int;
wire [WADDR_WIDTH:0] wr_datacount_int;
wire [RADDR_WIDTH:0] rd_datacount_int;
assign waddr = waddr_cntr[WADDR_WIDTH-1:0];
// NIC
wire [RADDR_WIDTH:0] ram_raddr;
assign raddr = (MODE == "FWFT") ? ram_raddr[RADDR_WIDTH-1:0] : raddr_cntr[RADDR_WIDTH-1:0];
//assign raddr = raddr_cntr[RADDR_WIDTH-1:0];
//assign wr_en_int = we & ~wr_full;
assign wr_en_int = OVERFLOW_PROTECT ? we & ~wr_full : we;
assign wr_datacount = wr_datacount_int;
assign rd_datacount = ASYM_WIDTH_RATIO == 4 && SYNC_CLK ? wr_datacount_int : rd_datacount_int;
generate
if (MODE == "FWFT") begin
// NIC
//assign rd_en_int = (~rd_empty_int & rd_empty) | (re & ~rd_empty_int);
//assign rd_empty = rd_empty_fwft;
assign rd_en_int = 1'b1;
//assign rd_empty = rd_empty_int;
//always @ (posedge rclk or posedge rd_rst) begin
// if (rd_rst) begin
// init_set <= 1'b1;
// end
// else if (~init_set & rd_empty) begin
// init_set <= 1'b1;
// end
// else if (~rd_empty_int) begin
// init_set <= 1'b0;
// end
// else if (rd_empty) begin
// init_set <= 1'b1;
// end
//end
// NIC
//always @ (posedge rclk or posedge rd_rst) begin
// if (rd_rst) begin
// rd_empty_fwft <= 1'b1;
// end
// else if (rd_en_int) begin
// rd_empty_fwft <= 1'b0;
// end
// else if (re) begin
// rd_empty_fwft <= 1'b1;
// end
//end
//if (FAMILY == "TRION") begin
if (OUTPUT_REG) begin
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
rd_valid <= 1'b0;
end
else begin
rd_valid <= ~rd_empty;
end
end
assign rd_vld = rd_valid;
end
else begin
assign rd_vld = ~rd_empty;
end
assign rd_empty = rd_empty_int;
end
else begin
assign rd_en_int = UNDERFLOW_PROTECT ? re & ~rd_empty_int : re;
assign rd_empty = rd_empty_int;
if (OUTPUT_REG) begin
reg rd_valid_r;
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
rd_valid_r <= 'h0;
rd_valid <= 'h0;
end
else begin
{rd_valid,rd_valid_r} <= {rd_valid_r,rd_en_int};
end
end
assign rd_vld = rd_valid;
end
else begin
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
rd_valid <= 'h0;
end
else begin
rd_valid <= rd_en_int;
end
end
assign rd_vld = rd_valid;
end
end
if (ALMOST_FLAG) begin
assign wr_almost_full = wr_datacount >= WR_DEPTH-1;
assign rd_almost_empty = rd_datacount <= 'd1;
end
else begin
assign wr_almost_full = 1'b0;
assign rd_almost_empty = 1'b0;
end
if (PROGRAMMABLE_FULL == "STATIC_SINGLE") begin
reg wr_prog_full_int;
assign wr_prog_full = wr_datacount >= PROG_FULL_ASSERT;
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
wr_prog_full_int <= 1'b0;
end
else begin
wr_prog_full_int <= wr_prog_full;
end
end
end
else if (PROGRAMMABLE_FULL == "STATIC_DUAL") begin
reg wr_prog_full_int;
assign wr_prog_full = wr_prog_full_int ? wr_datacount >= PROG_FULL_NEGATE : wr_datacount >= PROG_FULL_ASSERT;
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
wr_prog_full_int <= 1'b0;
end
else begin
wr_prog_full_int <= wr_prog_full;
end
end
end
else begin
assign wr_prog_full = 1'b0;
end
if (PROGRAMMABLE_EMPTY == "STATIC_SINGLE") begin
reg rd_prog_empty_int;
assign rd_prog_empty = rd_datacount <= PROG_EMPTY_ASSERT;
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
rd_prog_empty_int <= 1'b1;
end
else begin
rd_prog_empty_int <= rd_prog_empty;
end
end
end
else if (PROGRAMMABLE_EMPTY == "STATIC_DUAL") begin
reg rd_prog_empty_int;
assign rd_prog_empty = rd_prog_empty_int ? (rd_datacount <= PROG_EMPTY_NEGATE) : (rd_datacount <= PROG_EMPTY_ASSERT);
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
rd_prog_empty_int <= 1'b1;
end
else begin
rd_prog_empty_int <= rd_prog_empty;
end
end
end
else begin
assign rd_prog_empty = 1'b0;
end
if (HANDSHAKE_FLAG) begin
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
wr_ack <= 1'b0;
end
else begin
// NIC
//wr_ack <= wr_en_int & ~wr_overflow;
wr_ack <= OVERFLOW_PROTECT ? wr_en_int & ~wr_overflow : wr_en_int;
end
end
end
if (OVERFLOW_PROTECT) begin
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
wr_overflow <= 1'b0;
end
else if (we && wr_full) begin
wr_overflow <= 1'b1;
end
else begin
wr_overflow <= 1'b0;
end
end
end
else if (HANDSHAKE_FLAG) begin
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
wr_overflow <= 1'b0;
end
else begin
wr_overflow <= we && wr_full ? 1'b1 : wr_overflow;
end
end
end
if (UNDERFLOW_PROTECT) begin
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
rd_underflow <= 1'b0;
end
else if (re && rd_empty) begin
rd_underflow <= 1'b1;
end
else begin
rd_underflow <= 1'b0;
end
end
end
else if (HANDSHAKE_FLAG) begin
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
rd_underflow <= 1'b0;
end
else begin
rd_underflow <= re && rd_empty ? 1'b1 : rd_underflow;
end
end
end
localparam RATIO_WIDTH = (RADDR_WIDTH >= WADDR_WIDTH)? RADDR_WIDTH - WADDR_WIDTH : WADDR_WIDTH - RADDR_WIDTH;
if (ASYM_WIDTH_RATIO < 4) begin
assign wr_full = (waddr_cntr[WADDR_WIDTH]^raddr_int[RADDR_WIDTH]) & (waddr_cntr[WADDR_WIDTH-1:0] == raddr_int[RADDR_WIDTH-1:RATIO_WIDTH]);
assign rd_empty_int = waddr_int[WADDR_WIDTH:0] == raddr_cntr[RADDR_WIDTH:RATIO_WIDTH];
assign wr_datacount_int = waddr_cntr - (raddr_int/RAM_MUX_RATIO);
assign rd_datacount_int = (waddr_int*RAM_MUX_RATIO)-raddr_cntr;
end
// NIC
else if (ASYM_WIDTH_RATIO == 4) begin
assign wr_full = (waddr_cntr[WADDR_WIDTH]^raddr_int[RADDR_WIDTH]) & (waddr_cntr[WADDR_WIDTH-1:0] == raddr_int[RADDR_WIDTH-1:0]);
assign rd_empty_int = waddr_int[WADDR_WIDTH:0] == raddr_cntr[RADDR_WIDTH:0];
assign wr_datacount_int = waddr_cntr - raddr_int;
assign rd_datacount_int = waddr_int - raddr_cntr;
end
else begin
assign wr_full = (waddr_cntr[WADDR_WIDTH]^raddr_int[RADDR_WIDTH]) & (waddr_cntr[WADDR_WIDTH-1:RATIO_WIDTH] == raddr_int[RADDR_WIDTH-1:0]);
// NIC
//assign rd_empty_int = (waddr_int- raddr_cntr*RAM_MUX_RATIO) < RAM_MUX_RATIO;
assign rd_empty_int = waddr_int[WADDR_WIDTH:RATIO_WIDTH] == raddr_cntr[RADDR_WIDTH:0];
assign wr_datacount_int = waddr_cntr - (raddr_int*RAM_MUX_RATIO);
assign rd_datacount_int = (waddr_int/RAM_MUX_RATIO)-raddr_cntr;
end
endgenerate
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
waddr_cntr <= 'h0;
end
else if (wr_en_int) begin
waddr_cntr <= waddr_cntr + 1'b1;
end
end
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
waddr_cntr_r <= 'h0;
end
else begin
waddr_cntr_r <= waddr_cntr;
end
end
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
raddr_cntr <= 'h0;
end
// NIC
//else if (rd_en_int) begin
else begin
//raddr_cntr <= raddr_cntr + 1'b1;
//raddr_cntr <= raddr_cntr + (re & ~rd_empty_int);
raddr_cntr <= ram_raddr;
end
end
// NIC
assign ram_raddr = raddr_cntr + (UNDERFLOW_PROTECT ? re & ~rd_empty_int : re);
generate
if (SYNC_CLK) begin : sync_clk
if (MODE == "FWFT") begin
assign waddr_int = waddr_cntr_r;
assign raddr_int = raddr_cntr;
end
else begin
assign waddr_int = waddr_cntr;
assign raddr_int = raddr_cntr;
end
end
else begin : async_clk
reg [RADDR_WIDTH:0] raddr_cntr_gry_r;
reg [WADDR_WIDTH:0] waddr_cntr_gry_r;
wire [RADDR_WIDTH:0] raddr_cntr_gry;
wire [RADDR_WIDTH:0] raddr_cntr_gry_sync;
wire [RADDR_WIDTH:0] raddr_cntr_sync_g2b;
wire [WADDR_WIDTH:0] waddr_cntr_gry;
wire [WADDR_WIDTH:0] waddr_cntr_gry_sync;
wire [WADDR_WIDTH:0] waddr_cntr_sync_g2b;
if (PIPELINE_REG) begin
reg [RADDR_WIDTH:0] raddr_cntr_sync_g2b_r;
reg [WADDR_WIDTH:0] waddr_cntr_sync_g2b_r;
assign waddr_int = waddr_cntr_sync_g2b_r;
assign raddr_int = raddr_cntr_sync_g2b_r;
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
raddr_cntr_sync_g2b_r <= 'h0;
end
else begin
raddr_cntr_sync_g2b_r <= raddr_cntr_sync_g2b;
end
end
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
waddr_cntr_sync_g2b_r <= 'h0;
end
else begin
waddr_cntr_sync_g2b_r <= waddr_cntr_sync_g2b;
end
end
end
else begin
assign waddr_int = waddr_cntr_sync_g2b;
assign raddr_int = raddr_cntr_sync_g2b;
end
always @ (posedge rclk or posedge rd_rst) begin
if (rd_rst) begin
raddr_cntr_gry_r <= 'h0;
end
else begin
raddr_cntr_gry_r <= raddr_cntr_gry;
end
end
`IP_MODULE_NAME(efx_fifo_bin2gray) # (.WIDTH(RADDR_WIDTH+1) ) xrd2wr_bin2gray (.bin_i(raddr_cntr), .gray_o(raddr_cntr_gry));
`IP_MODULE_NAME(efx_asyncreg) # (.ASYNC_STAGE(SYNC_STAGE), .WIDTH (RADDR_WIDTH+1), .ACTIVE_LOW(0), .OFF_ASSERTION (1)) xrd2wr_addr_sync (.clk(wclk), .reset_n(wr_rst), .d_i(raddr_cntr_gry_r), .d_o(raddr_cntr_gry_sync));
`IP_MODULE_NAME(efx_fifo_gray2bin) # (.WIDTH(RADDR_WIDTH+1) ) xrd2wr_gray2bin (.gray_i(raddr_cntr_gry_sync), .bin_o(raddr_cntr_sync_g2b));
always @ (posedge wclk or posedge wr_rst) begin
if (wr_rst) begin
waddr_cntr_gry_r <= 'h0;
end
else begin
waddr_cntr_gry_r <= waddr_cntr_gry;
end
end
`IP_MODULE_NAME(efx_fifo_bin2gray) # (.WIDTH(WADDR_WIDTH+1) ) wr2rd_bin2gray (.bin_i(waddr_cntr), .gray_o(waddr_cntr_gry));
`IP_MODULE_NAME(efx_asyncreg) # (.ASYNC_STAGE(SYNC_STAGE), .WIDTH (WADDR_WIDTH+1), .ACTIVE_LOW(0), .OFF_ASSERTION (1)) wr2rd_addr_sync (.clk(rclk), .reset_n(rd_rst), .d_i(waddr_cntr_gry_r), .d_o(waddr_cntr_gry_sync));
`IP_MODULE_NAME(efx_fifo_gray2bin) # (.WIDTH(WADDR_WIDTH+1) ) wr2rd_gray2bin (.gray_i(waddr_cntr_gry_sync), .bin_o(waddr_cntr_sync_g2b));
end
endgenerate
endmodule
////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
// / / \
// / / .. / bin2gray.v
// / / .' /
// __/ /.' / Description:
// __ \ / Binary to Gray Encoding Convertor
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
// 1.0 Initial rev
//
// *******************************
`resetall
`timescale 1ns/1ps
module `IP_MODULE_NAME(efx_fifo_bin2gray)
#(parameter WIDTH=5)
(// outputs
output wire [WIDTH-1:0] gray_o,
// input
input [WIDTH-1:0] bin_i
);
//---------------------------------------------------------------------
// Function : bit_xor
// Description: reduction xor
function bit_xor (
input [31:0] nex_bit,
input [31:0] curr_bit,
input [WIDTH-1:0] xor_in);
begin : fn_bit_xor
bit_xor = xor_in[nex_bit] ^ xor_in[curr_bit];
end
endfunction
// Convert Binary to Gray, bit by bit
generate
begin
genvar bit_idx;
for(bit_idx=0; bit_idx<WIDTH-1; bit_idx=bit_idx+1) begin : gBinBits
assign gray_o[bit_idx] = bit_xor(bit_idx+1, bit_idx, bin_i);
end
assign gray_o[WIDTH-1] = bin_i[WIDTH-1];
end
endgenerate
endmodule
////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
//
// This document contains proprietary information which is
// protected by copyright. All rights are reserved. This notice
// refers to original work by Efinix, Inc. which may be derivitive
// of other work distributed under license of the authors. In the
// case of derivative work, nothing in this notice overrides the
// original author's license agreement. Where applicable, the
// original license agreement is included in it's original
// unmodified form immediately below this header.
//
// WARRANTY DISCLAIMER.
// THE DESIGN, CODE, OR INFORMATION ARE PROVIDED “AS IS” AND
// EFINIX MAKES NO WARRANTIES, EXPRESS OR IMPLIED WITH
// RESPECT THERETO, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES,
// INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY, NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR
// PURPOSE. SOME STATES DO NOT ALLOW EXCLUSIONS OF AN IMPLIED
// WARRANTY, SO THIS DISCLAIMER MAY NOT APPLY TO LICENSEE.
//
// LIMITATION OF LIABILITY.
// NOTWITHSTANDING ANYTHING TO THE CONTRARY, EXCEPT FOR BODILY
// INJURY, EFINIX SHALL NOT BE LIABLE WITH RESPECT TO ANY SUBJECT
// MATTER OF THIS AGREEMENT UNDER TORT, CONTRACT, STRICT LIABILITY
// OR ANY OTHER LEGAL OR EQUITABLE THEORY (I) FOR ANY INDIRECT,
// SPECIAL, INCIDENTAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES OF ANY
// CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF
// GOODWILL, DATA OR PROFIT, WORK STOPPAGE, OR COMPUTER FAILURE OR
// MALFUNCTION, OR IN ANY EVENT (II) FOR ANY AMOUNT IN EXCESS, IN
// THE AGGREGATE, OF THE FEE PAID BY LICENSEE TO EFINIX HEREUNDER
// (OR, IF THE FEE HAS BEEN WAIVED, $100), EVEN IF EFINIX SHALL HAVE
// BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO
// NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR
// CONSEQUENTIAL DAMAGES, SO THIS LIMITATION AND EXCLUSION MAY NOT
// APPLY TO LICENSEE.
//
////////////////////////////////////////////////////////////////////////////////
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AccExdwXlzGguk8A5/EQLRHz5rryY1WQDwV6tuVPs5/Qxrh9gVqa2q4cF4IFnUFp
Dbbd3yNYKmh6qrpl0qXTbn9RPH/P+iNeLpi6t9M0Gq/qSduDwjoyJbsX1qGnatWW
CjK1gfimwERYxGKRPHDSOy7R+9JSnx4A6HuOple3G1mRVkD49PwNhxU2zpo5IY/v
xyvY349g1810u0d4ifYrne+cKPsjalFLLV6aMrNyqvh0uY4z3b5AXUuYlMPuEjvp
CHO1vsCf+9AOqbJ4a8jRjcKiAI16hNFxITHF1RzAxamdmQRamfVSp7pAL/iY6jYV
h3CT1FUJIyV6vX3pLvMMDQ==
//pragma protect end_key_block
//pragma protect digest_block
DEMb2F1lj6rEM07ieIbuGv0NXlk=
//pragma protect end_digest_block
//pragma protect data_block
+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
//pragma protect end_data_block
//pragma protect digest_block
ttN5oYHd8WkRTKPQ4gjy7ImfYSw=
//pragma protect end_digest_block
//pragma protect end_protected
module `IP_MODULE_NAME(mii_if) #(
parameter NO_PREAMBLE = 0
) (
//Globle Signals
input tx_mac_aclk,
output reg tx_mac_aclk_en,
input tx_reset,
output wire rx_mac_aclk,
output reg rx_mac_aclk_en,
input rx_reset,
//Configuration Signals
input [2:0] eth_speed,
//GMII Interface
output reg [7:0] gm_rx_d,
output reg gm_rx_dv,
output reg gm_rx_err,
input [7:0] gm_tx_d,
input gm_tx_en,
input gm_tx_err,
//MII Interface
input mii_txc,
output reg [3:0] mii_txd,
output reg mii_tx_dv,
output reg mii_tx_err,
input mii_rxc,
input [3:0] mii_rxd,
input mii_rx_dv,
input mii_rx_err
//Status and Error Signals
);
// Parameter Define
//localparam SPEED_100M_DIV = (TX_REFCLK == 125) ? 10 : 2;
//localparam SPEED_10M_DIV = SPEED_100M_DIV*10;
//localparam SPEED_CLK_DIV = (TX_REFCLK == 125) ? SPEED_100M_DIV/2 + 1 : 0 ;
// Register Define
reg [6:0] aclk_en_cnt;
reg [3:0] txd;
reg tx_en;
reg tx_er;
reg rx_dv_pre;
reg rx_dv_dl1;
reg [3:0] rxd_pre;
reg [3:0] rxd_dl1;
reg rx_odd_data_ptr;
reg [3:0] rxd;
reg rx_dv;
reg rx_er;
reg [3:0] gm_tx_d_h;
reg [7:0] gm_tx_d_r;
reg gm_tx_en_r;
reg gm_tx_err_r;
reg preamble_flg;
reg [1:0] cur_st;
reg [1:0] nxt_st;
reg add_preamble;
// Wire Define
wire add_preamble_w;
assign add_preamble_w = mii_rxd == 4'hd && mii_rx_dv && !mii_rx_err && cur_st == 2'b01 && preamble_flg;
/*----------------------------------------------------------------------------------*\
The main code
\*----------------------------------------------------------------------------------*/
/*----------------------- Tx Region ----------------------------*/
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_mac_aclk_en <= 1'b0;
else
tx_mac_aclk_en <= ~tx_mac_aclk_en;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
gm_tx_d_r <= 8'h0;
else if ((gm_tx_en == 1'b1) && (tx_mac_aclk_en == 1'b1))
gm_tx_d_r <= gm_tx_d;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
gm_tx_en_r <= 1'b0;
else if (tx_mac_aclk_en == 1'b1)
gm_tx_en_r <= gm_tx_en;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
gm_tx_err_r <= 1'b0;
else if (tx_mac_aclk_en == 1'b1)
gm_tx_err_r <= gm_tx_err;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
txd <= 4'h0;
else if (gm_tx_en_r == 1'b1) begin
if (tx_mac_aclk_en == 1'b0)
txd <= gm_tx_d_r[3:0];
else
txd <= gm_tx_d_r[7:4];
end
else;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_en <= 1'b0;
else
tx_en <= gm_tx_en_r;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_er <= 1'b0;
else
tx_er <= gm_tx_err_r;
end
always @ (posedge mii_txc or posedge tx_reset) begin
if (tx_reset == 1'b1) begin
mii_tx_dv <= 1'b0;
mii_txd <= 4'h0;
mii_tx_err <= 1'b0;
end
else begin
mii_tx_dv <= tx_en;
mii_txd <= txd[3:0];
mii_tx_err <= tx_er;
end
end
/*----------------------- Rx Region ----------------------------*/
always @ (posedge mii_rxc or posedge rx_reset) begin
if (rx_reset == 1'b1) begin
rxd <= 4'h0;
rx_dv <= 1'b0;
rx_er <= 1'b0;
end
else if (add_preamble_w && NO_PREAMBLE != 1) begin
rxd <= 4'h5;
rx_dv <= 1'b1;
rx_er <= rx_er;
end
else if (add_preamble && NO_PREAMBLE != 1) begin
rxd <= rxd_pre;
rx_dv <= rx_dv_pre;
rx_er <= rx_er;
end
else begin
rxd <= mii_rxd;
rx_dv <= mii_rx_dv;
rx_er <= mii_rx_err;
end
end
assign rx_mac_aclk = mii_rxc;
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1) begin
rxd_pre <= 4'h0;
rx_dv_pre <= 1'b0;
end
else if (add_preamble_w || add_preamble) begin
rxd_pre <= mii_rxd;
rx_dv_pre <= mii_rx_dv;
end
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
add_preamble <= 1'b0;
else if (add_preamble_w)
add_preamble <= 1'b1;
else if (!mii_rx_dv)
add_preamble <= 1'b0;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_mac_aclk_en <= 1'b0;
else
rx_mac_aclk_en <= ~rx_mac_aclk_en;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1) begin
cur_st <= 2'b00;
end
else begin
cur_st <= nxt_st;
end
end
always @ (*) begin
case (cur_st)
2'b00: begin
if (mii_rxd == 4'h5 && mii_rx_dv && !mii_rx_err)
nxt_st = 2'b01;
else
nxt_st = 2'b00;
end
2'b01: begin
if (mii_rxd == 4'hd && mii_rx_dv && !mii_rx_err)
nxt_st = 2'b10;
else if (mii_rxd == 4'h5 && mii_rx_dv && !mii_rx_err)
nxt_st = 2'b01;
else
nxt_st = 2'b00;
end
2'b10: begin
if (mii_rx_dv)
nxt_st = 2'b10;
else
nxt_st = 2'b00;
end
default: nxt_st = 2'b00;
endcase
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1) begin
preamble_flg <= 1'b0;
end
else if (mii_rxd == 4'h5 && mii_rx_dv && !mii_rx_err && cur_st == 2'b01) begin
preamble_flg <= ~preamble_flg;
end
else begin
preamble_flg <= 1'b0;
end
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1) begin
rx_dv_dl1 <= 1'b0;
rxd_dl1 <= 4'h0;
end
else begin
rx_dv_dl1 <= rx_dv;
rxd_dl1 <= rxd;
end
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
gm_rx_dv <= 1'b0;
else
gm_rx_dv <= rx_dv_dl1;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_odd_data_ptr <= 1'b0;
else if (rx_dv == 1'b0)
rx_odd_data_ptr <= 1'b0;
else
rx_odd_data_ptr <= ~rx_odd_data_ptr;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
gm_rx_d <= 8'h0;
else if ((rx_dv == 1'b1) && (rx_odd_data_ptr == 1'b1))
gm_rx_d <= {rxd[3:0], rxd_dl1[3:0]};
else;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
gm_rx_err <= 1'b0;
else begin
if (rx_er == 1'b1) gm_rx_err <= 1'b1;
else if (rx_mac_aclk_en == 1'b1) gm_rx_err <= 1'b0;
end
end
endmodule
/////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
// / / \
// / / .. /
// / / .' /
// __/ /.' /
// __ \ /
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
// 1.0 Initial rev
//
// *******************************
module `IP_MODULE_NAME(rgmii_if)#(
parameter RGMII_SYNC_EN = 1
) (
//Globle Signals
input tx_mac_aclk,
output reg tx_mac_aclk_en,
input tx_reset,
output wire rx_mac_aclk,
output reg rx_mac_aclk_en,
input rx_reset,
//Configuration Signals
input [2:0] eth_speed,
input rgmii_rxc_edge,//0:DDIO Rising Edge; 1:DDIO Falling Edge;
input rgmii_txc_dly,//0:rgmii tx clock delay disable; 1:rgmii tx clock delay enable;
//GMII Interface
output reg [7:0] gm_rx_d,
output reg gm_rx_dv,
output reg gm_rx_err,
input [7:0] gm_tx_d,
input gm_tx_en,
input gm_tx_err,
//RGMII Interface
output wire [3:0] rgmii_txd_HI,
output wire [3:0] rgmii_txd_LO,
output wire rgmii_tx_ctl_HI,
output wire rgmii_tx_ctl_LO,
output wire rgmii_txc_HI,//if rgmii_txc_dly set 0, used clk_125m clock. if rgmii_txc_dly set 1, used clk_125m_90deg clock.
output wire rgmii_txc_LO,
input [3:0] rgmii_rxd_HI,
input [3:0] rgmii_rxd_LO,
input rgmii_rx_ctl_HI,
input rgmii_rx_ctl_LO,
input rgmii_rxc
//Status and Error Signals
);
// Parameter Define
// Register Define
reg [6:0] aclk_en_cnt;
reg [7:0] txd;
reg tx_en;
reg tx_er;
reg [1:0] txc;
reg rx_dv_dl1;
reg [7:0] rxd_dl1;
reg rx_odd_data_ptr;
// Wire Define
wire rx_dv;
wire [7:0] rxd;
wire rx_er;
/*----------------------------------------------------------------------------------*\
The main code
\*----------------------------------------------------------------------------------*/
/*----------------------- Tx Region ----------------------------*/
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
aclk_en_cnt <= 7'd0;
else if ((eth_speed == 3'h4) ||
((eth_speed == 3'h2) && (aclk_en_cnt == 7'd9)) ||
((eth_speed == 3'h1) && (aclk_en_cnt == 7'd99)))
aclk_en_cnt <= 7'd0;
else
aclk_en_cnt <= aclk_en_cnt + 1'b1;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_mac_aclk_en <= 1'b0;
else if (aclk_en_cnt == 7'd0)
tx_mac_aclk_en <= 1'b1;
else
tx_mac_aclk_en <= 1'b0;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
txd[7:4] <= 4'h0;
else if((gm_tx_en == 1'b1) && (tx_mac_aclk_en == 1'b1))
txd[7:4] <= gm_tx_d[7:4];
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
txd[3:0] <= 4'h0;
else if ((gm_tx_en == 1'b1) && (tx_mac_aclk_en == 1'b1))
txd[3:0] <= gm_tx_d[3:0];
else if (((eth_speed == 3'h2) && (aclk_en_cnt == 7'd6)) ||
((eth_speed == 3'h1) && (aclk_en_cnt == 7'd51)))
txd[3:0] <= txd[7:4];
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_en <= 1'b0;
else if (tx_mac_aclk_en == 1'b1)
tx_en <= gm_tx_en;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_er <= 1'b0;
else if (tx_mac_aclk_en == 1'b1)
tx_er <= gm_tx_err;
end
/*
always @(posedge tx_mac_aclk or posedge tx_reset)
begin
if(tx_reset == 1'b1)
txc <= 2'b0;
else
case(eth_speed)
3'h4 :
txc <= 2'b01;
3'h2 :
case(rgmii_txc_dly)
1'b0 ://rgmii tx clock delay disable.
if((aclk_en_cnt == 7'd0) || (aclk_en_cnt == 7'd5))
txc <= 2'b11;
else if((aclk_en_cnt == 7'd3) || (aclk_en_cnt == 7'd8))
txc <= 2'b00;
1'b1 ://rgmii tx clock delay enable.
if((aclk_en_cnt == 7'd2) || (aclk_en_cnt == 7'd7))
txc <= 2'b11;
else if((aclk_en_cnt == 7'd0) || (aclk_en_cnt == 7'd5))
txc <= 2'b00;
endcase
3'h1 :
case(rgmii_txc_dly)
1'b0 ://rgmii tx clock delay disable.
if((aclk_en_cnt == 7'd0) || (aclk_en_cnt == 7'd50))
txc <= 2'b11;
else if((aclk_en_cnt == 7'd25) || (aclk_en_cnt == 7'd75))
txc <= 2'b00;
1'b1 ://rgmii tx clock delay enable.
if((aclk_en_cnt == 7'd13) || (aclk_en_cnt == 7'd63))
txc <= 2'b11;
else if((aclk_en_cnt == 7'd38) || (aclk_en_cnt == 7'd88))
txc <= 2'b00;
endcase
default :
txc <= 2'b0;
endcase
end
*/
reg [1:0] txc_100m_r;
reg [1:0] txc_10m_r;
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
txc_100m_r <= 2'b0;
else begin
case(rgmii_txc_dly)
1'b0 : //rgmii tx clock delay disable.
if ((aclk_en_cnt == 7'd0) || (aclk_en_cnt == 7'd5))
txc_100m_r <= 2'b11;
else if ((aclk_en_cnt == 7'd3) || (aclk_en_cnt == 7'd8))
txc_100m_r <= 2'b00;
1'b1 ://rgmii tx clock delay enable.
if ((aclk_en_cnt == 7'd2) || (aclk_en_cnt == 7'd7))
txc_100m_r <= 2'b11;
else if ((aclk_en_cnt == 7'd0) || (aclk_en_cnt == 7'd5))
txc_100m_r <= 2'b00;
endcase
end
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
txc_10m_r <= 2'b0;
else begin
case(rgmii_txc_dly)
1'b0 ://rgmii tx clock delay disable.
if((aclk_en_cnt == 7'd0) || (aclk_en_cnt == 7'd50))
txc_10m_r <= 2'b11;
else if((aclk_en_cnt == 7'd25) || (aclk_en_cnt == 7'd75))
txc_10m_r <= 2'b00;
1'b1 ://rgmii tx clock delay enable.
if((aclk_en_cnt == 7'd13) || (aclk_en_cnt == 7'd63))
txc_10m_r <= 2'b11;
else if((aclk_en_cnt == 7'd38) || (aclk_en_cnt == 7'd88))
txc_10m_r <= 2'b00;
endcase
end
end
always @(posedge tx_mac_aclk or posedge tx_reset)
begin
if(tx_reset == 1'b1)
txc <= 2'b0;
else
case(eth_speed)
3'h4 :
txc <= 2'b01;
3'h2 :
txc <= txc_100m_r;
3'h1 :
txc <= txc_10m_r;
default :
txc <= 2'b0;
endcase
end
/*----------------------- Rx Region ----------------------------*/
assign rx_mac_aclk = rgmii_rxc;
always @(posedge rx_mac_aclk or posedge rx_reset)
begin
if(rx_reset == 1'b1)
rx_mac_aclk_en <= 1'b0;
else if(eth_speed[2] == 1'b1)
rx_mac_aclk_en <= 1'b1;
else
rx_mac_aclk_en <= ~rx_mac_aclk_en;
end
always @(posedge rx_mac_aclk or posedge rx_reset)
begin
if(rx_reset == 1'b1)
begin
rx_dv_dl1 <= 1'b0;
rxd_dl1 <= 8'h0;
end
else
begin
rx_dv_dl1 <= rx_dv;
rxd_dl1 <= rxd;
end
end
always @(posedge rx_mac_aclk or posedge rx_reset)
begin
if(rx_reset == 1'b1)
gm_rx_dv <= 1'b0;
else
gm_rx_dv <= rx_dv_dl1;
end
always @(posedge rx_mac_aclk or posedge rx_reset)
begin
if(rx_reset == 1'b1)
rx_odd_data_ptr <= 1'b0;
else if(rx_dv == 1'b0)
rx_odd_data_ptr <= 1'b0;
else
rx_odd_data_ptr <= ~rx_odd_data_ptr;
end
always @(posedge rx_mac_aclk or posedge rx_reset)
begin
if(rx_reset == 1'b1)
gm_rx_d <= 8'h0;
else
begin
if((eth_speed[2] == 1'b1) && (rx_dv_dl1 == 1'b1))
gm_rx_d <= rxd_dl1;
else if((rx_dv == 1'b1) && (rx_odd_data_ptr == 1'b1))
gm_rx_d <= {rxd[3:0],rxd_dl1[3:0]};
end
end
always @(posedge rx_mac_aclk or posedge rx_reset)
begin
if(rx_reset == 1'b1)
gm_rx_err <= 1'b0;
else
begin
if(rx_er == 1'b1)
gm_rx_err <= 1'b1;
else if(rx_mac_aclk_en == 1'b1)
gm_rx_err <= 1'b0;
end
end
/*----------------------- PHY Interface ----------------------------*/
`IP_MODULE_NAME(rgmii) #(
.RGMII_SYNC_EN (RGMII_SYNC_EN )
)
u_rgmii
(
//Globle Signals
.tx_mac_aclk (tx_mac_aclk ),
.tx_reset (tx_reset ),
.rx_reset (rx_reset ),
//Configuration Signals
.eth_speed (eth_speed ),
.rgmii_rxc_edge (rgmii_rxc_edge ),
//Phy Interface
.txd (txd ),
.tx_en (tx_en ),
.tx_er (tx_er ),
.txc (txc ),
.rxd (rxd ),
.rx_dv (rx_dv ),
.rx_er (rx_er ),
//RGMII Interface
.rgmii_txd_HI (rgmii_txd_HI ),
.rgmii_txd_LO (rgmii_txd_LO ),
.rgmii_tx_ctl_HI (rgmii_tx_ctl_HI ),
.rgmii_tx_ctl_LO (rgmii_tx_ctl_LO ),
.rgmii_txc_HI (rgmii_txc_HI ),
.rgmii_txc_LO (rgmii_txc_LO ),
.rgmii_rxd_HI (rgmii_rxd_HI ),
.rgmii_rxd_LO (rgmii_rxd_LO ),
.rgmii_rx_ctl_HI (rgmii_rx_ctl_HI ),
.rgmii_rx_ctl_LO (rgmii_rx_ctl_LO ),
.rgmii_rxc (rgmii_rxc )
);
endmodule
/////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
// / / \
// / / .. /
// / / .' /
// __/ /.' /
// __ \ /
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
// 1.0 Initial rev
//
// *******************************
module `IP_MODULE_NAME(rgmii_sync)
(
//Globle Signals
input rgmii_rxc,
input rx_reset,
input [2:0] eth_speed,
//RGMII Rx Interface Input
input [3:0] rgmii_rxd_HI_i,
input [3:0] rgmii_rxd_LO_i,
input rgmii_rx_ctl_HI_i,
input rgmii_rx_ctl_LO_i,
//RGMII Rx Interface Output
output reg [3:0] rgmii_rxd_HI_o,
output reg [3:0] rgmii_rxd_LO_o,
output reg rgmii_rx_ctl_HI_o,
output reg rgmii_rx_ctl_LO_o
);
// Parameter Define
parameter State_idle = 2'd0;
parameter State_preamble = 2'd1;
parameter State_data_dl1 = 2'd2;
parameter State_data_dl2 = 2'd3;
// Register Define
reg [1:0] cur_state;
reg [1:0] next_state;
reg preamble_odd;
reg [3:0] rx_d_dl1;
reg rx_dv_dl1;
reg [3:0] rx_d_dl2;
reg rx_dv_dl2;
// Wire Define
/*----------------------------------------------------------------------------------*\
The main code
\*----------------------------------------------------------------------------------*/
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset) begin
rx_d_dl1 <= 4'h0;
rx_dv_dl1 <= 1'b0;
rx_d_dl2 <= 4'h0;
rx_dv_dl2 <= 1'b0;
end
else begin
rx_d_dl1 <= rgmii_rxd_LO_i;
rx_dv_dl1 <= rgmii_rx_ctl_HI_i;
rx_d_dl2 <= rx_d_dl1;
rx_dv_dl2 <= rx_dv_dl1;
end
end
/*----------------------- FSM Region ----------------------------*/
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset) cur_state <= State_idle;
else cur_state <= next_state;
end
always @ (*) begin
case (cur_state)
State_idle :
if ((rx_dv_dl1 == 1'b1) && (rx_d_dl1 == 4'h5))
next_state = State_preamble;
else
next_state = State_idle;
State_preamble :
if (rx_dv_dl1 == 1'b0)
next_state = State_idle;
else if ((rx_d_dl1 == 4'hd) && (preamble_odd == 1'b0))
next_state = State_data_dl1;
else if ((rx_d_dl1 == 4'hd) && (preamble_odd == 1'b1))
next_state = State_data_dl2;
else if (rx_d_dl1 != 4'h5)
next_state = State_idle;
else
next_state = State_preamble;
State_data_dl1 :
if (rx_dv_dl1 == 1'b0)
next_state = State_idle;
else
next_state = State_data_dl1;
State_data_dl2 :
if (rx_dv_dl2 == 1'b0)
next_state = State_idle;
else
next_state = State_data_dl2;
default :
next_state = State_idle;
endcase
end
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset)
preamble_odd <= 1'b0;
else if (cur_state == State_preamble)
preamble_odd <= ~preamble_odd;
else
preamble_odd <= 1'b0;
end
/*----------------------- Sync Output Region ----------------------------*/
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset)
rgmii_rxd_LO_o <= 4'h0;
else if (eth_speed[2] == 1'b1)
rgmii_rxd_LO_o <= rgmii_rxd_LO_i;
else if ((cur_state == State_preamble) && (rx_d_dl1 == 4'hd) && (preamble_odd == 1'b1))
rgmii_rxd_LO_o <= 4'h5;
else if (cur_state == State_data_dl2)
rgmii_rxd_LO_o <= rx_d_dl2;
else
rgmii_rxd_LO_o <= rx_d_dl1;
end
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset)
rgmii_rxd_HI_o <= 4'h0;
else if (eth_speed[2] == 1'b1)
rgmii_rxd_HI_o <= rgmii_rxd_HI_i;
else
rgmii_rxd_HI_o <= 4'h0;
end
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset)
rgmii_rx_ctl_HI_o <= 1'b0;
else if (eth_speed[2] == 1'b1)
rgmii_rx_ctl_HI_o <= rgmii_rx_ctl_HI_i;
else if ((cur_state == State_preamble) && (rx_d_dl1 == 4'hd) && (preamble_odd == 1'b1))
rgmii_rx_ctl_HI_o <= 1'b1;
else if (cur_state == State_data_dl2)
rgmii_rx_ctl_HI_o <= rx_dv_dl2;
else
rgmii_rx_ctl_HI_o <= rx_dv_dl1;
end
always @(posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset)
rgmii_rx_ctl_LO_o <= 1'b0;
else if (eth_speed[2] == 1'b1)
rgmii_rx_ctl_LO_o <= rgmii_rx_ctl_LO_i;
else if ((cur_state == State_preamble) && (rx_d_dl1 == 4'hd) && (preamble_odd == 1'b1))
rgmii_rx_ctl_LO_o <= 1'b1;
else if (cur_state == State_data_dl2)
rgmii_rx_ctl_LO_o <= rx_dv_dl2;
else
rgmii_rx_ctl_LO_o <= rx_dv_dl1;
end
endmodule
/////////////////////////////////////////////////////////////////////////////
// _____
// / _______ Copyright (C) 2013-2020 Efinix Inc. All rights reserved.
// / / \
// / / .. /
// / / .' /
// __/ /.' /
// __ \ /
// /_/ /\ \_____/ /
// ____/ \_______/
//
// *******************************
// Revisions:
// 1.0 Initial rev
//
// *******************************
module `IP_MODULE_NAME(rgmii) #(
parameter RGMII_SYNC_EN = 1
) (
//Globle Signals
input tx_mac_aclk,
input tx_reset,
input rx_reset,
//Configuration Signals
input [2:0] eth_speed,
input rgmii_rxc_edge, //0:DDIO Rising Edge; 1:DDIO Falling Edge;
//Phy Interface
input [7:0] txd,
input tx_en,
input tx_er,
input [1:0] txc, //if rgmii_txc_dly set 0, used clk_125m clock. if rgmii_txc_dly set 1, used clk_125m_90deg clock.
output reg [7:0] rxd,
output reg rx_dv,
output reg rx_er,
//RGMII Interface
output reg [3:0] rgmii_txd_HI,
output reg [3:0] rgmii_txd_LO,
output reg rgmii_tx_ctl_HI,
output reg rgmii_tx_ctl_LO,
output reg rgmii_txc_HI,
output reg rgmii_txc_LO,
input [3:0] rgmii_rxd_HI,
input [3:0] rgmii_rxd_LO,
input rgmii_rx_ctl_HI,
input rgmii_rx_ctl_LO,
input rgmii_rxc
//Status and Error Signals
);
// Parameter Define
// Register Define
reg [3:0] rgmii_rxd_HI_d1;
reg rgmii_rx_ctl_HI_d1;
reg [3:0] rgmii_txd_HI_r;
reg [3:0] rgmii_txd_LO_r;
reg rgmii_tx_ctl_HI_r;
reg rgmii_tx_ctl_LO_r;
reg rgmii_txc_HI_r;
reg rgmii_txc_LO_r;
// Wire Define
wire tx_en_to_ddr;
wire rgmii_tx_ctl_int;
wire [3:0] txd_falling;
/*----------------------------------------------------------------------------------*\
The main code
\*----------------------------------------------------------------------------------*/
/*----------------------- RGMII Tx Region ----------------------------*/
assign tx_en_to_ddr = (eth_speed[2] == 1'b1) ? tx_en : tx_en && (!tx_er);
assign rgmii_tx_ctl_int = tx_en ^ tx_er;
assign txd_falling = (eth_speed[2] == 1'b1) ? txd[7:4] : txd[3:0];
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset) begin
rgmii_txc_HI_r <= 1'b0;
rgmii_txc_LO_r <= 1'b0;
rgmii_tx_ctl_HI_r <= 1'b0;
rgmii_tx_ctl_LO_r <= 1'b0;
rgmii_txd_HI_r <= 4'b0;
rgmii_txd_LO_r <= 4'b0;
end
else begin
rgmii_txc_HI_r <= txc[0];
rgmii_txc_LO_r <= txc[1];
rgmii_tx_ctl_HI_r <= tx_en_to_ddr;
rgmii_tx_ctl_LO_r <= rgmii_tx_ctl_int;
rgmii_txd_HI_r <= txd[3:0];
rgmii_txd_LO_r <= txd_falling;
end
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset) begin
rgmii_txc_HI <= 1'b0;
rgmii_txc_LO <= 1'b0;
rgmii_tx_ctl_HI <= 1'b0;
rgmii_tx_ctl_LO <= 1'b0;
rgmii_txd_HI <= 4'b0;
rgmii_txd_LO <= 4'b0;
end
else begin
rgmii_txc_HI <= rgmii_txc_HI_r;
rgmii_txc_LO <= rgmii_txc_LO_r;
rgmii_tx_ctl_HI <= rgmii_tx_ctl_HI_r;
rgmii_tx_ctl_LO <= rgmii_tx_ctl_LO_r;
rgmii_txd_HI <= rgmii_txd_HI_r;
rgmii_txd_LO <= rgmii_txd_LO_r;
end
end
/*----------------------- RGMII Rx Region ----------------------------*/
//rgmii_rxd & rgmii_rx_ctl
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset) begin
rgmii_rxd_HI_d1 <= 4'h0;
rgmii_rx_ctl_HI_d1 <= 1'b0;
end
else begin
rgmii_rxd_HI_d1 <= rgmii_rxd_HI;
rgmii_rx_ctl_HI_d1 <= rgmii_rx_ctl_HI;
end
end
generate
if (RGMII_SYNC_EN == 0) begin
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset) begin
rxd[7:4] <= 4'h0;
rxd[3:0] <= 4'h0;
rx_dv <= 1'b0;
rx_er <= 1'b0;
end
else if (eth_speed[2] == 1'b1) begin //1000M
if (rgmii_rxc_edge == 1'b0) begin //0:DDIO Rising Edge
rxd[7:4] <= rgmii_rxd_LO;
rxd[3:0] <= rgmii_rxd_HI_d1;
rx_dv <= rgmii_rx_ctl_HI_d1;
rx_er <= rgmii_rx_ctl_HI_d1^rgmii_rx_ctl_LO;
end
else begin//1:DDIO Falling Edge
rxd[7:4] <= rgmii_rxd_HI;
rxd[3:0] <= rgmii_rxd_LO;
rx_dv <= rgmii_rx_ctl_LO;
rx_er <= rgmii_rx_ctl_LO^rgmii_rx_ctl_HI;
end
end
else begin //100M or 10M
rxd[7:4] <= 4'b0;
rxd[3:0] <= rgmii_rxd_LO;
rx_dv <= rgmii_rx_ctl_LO;
rx_er <= rgmii_rx_ctl_LO^rgmii_rx_ctl_HI_d1;
end
end
end
else begin
reg [3:0] rgmii_rxd_HI_i;
reg [3:0] rgmii_rxd_LO_i;
reg rgmii_rx_ctl_HI_i;
reg rgmii_rx_ctl_LO_i;
wire [3:0] rgmii_rxd_HI_sync;
wire [3:0] rgmii_rxd_LO_sync;
wire rgmii_rx_ctl_HI_sync;
wire rgmii_rx_ctl_LO_sync;
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset) begin
rgmii_rxd_HI_i <= 4'h0;
rgmii_rxd_LO_i <= 4'h0;
rgmii_rx_ctl_HI_i <= 1'b0;
rgmii_rx_ctl_LO_i <= 1'b0;
end
else if (eth_speed[2] == 1'b1) begin //1000M
if (rgmii_rxc_edge == 1'b0) begin //0:DDIO Rising Edge
rgmii_rxd_HI_i <= rgmii_rxd_LO;
rgmii_rxd_LO_i <= rgmii_rxd_HI_d1;
rgmii_rx_ctl_HI_i <= rgmii_rx_ctl_HI_d1;
rgmii_rx_ctl_LO_i <= rgmii_rx_ctl_LO;
end
else begin //1:DDIO Falling Edge
rgmii_rxd_HI_i <= rgmii_rxd_HI;
rgmii_rxd_LO_i <= rgmii_rxd_LO;
rgmii_rx_ctl_HI_i <= rgmii_rx_ctl_HI;
rgmii_rx_ctl_LO_i <= rgmii_rx_ctl_LO;
end
end
else begin//100M or 10M
rgmii_rxd_HI_i <= rgmii_rxd_HI_d1;
rgmii_rxd_LO_i <= rgmii_rxd_LO;
rgmii_rx_ctl_HI_i <= rgmii_rx_ctl_LO;
rgmii_rx_ctl_LO_i <= rgmii_rx_ctl_HI_d1;
end
end
always @ (posedge rgmii_rxc or posedge rx_reset) begin
if (rx_reset) begin
rxd[7:4] <= 4'h0;
rxd[3:0] <= 4'h0;
rx_dv <= 1'b0;
rx_er <= 1'b0;
end
else begin
rxd[7:4] <= rgmii_rxd_HI_sync;
rxd[3:0] <= rgmii_rxd_LO_sync;
rx_dv <= rgmii_rx_ctl_HI_sync;
rx_er <= rgmii_rx_ctl_HI_sync^rgmii_rx_ctl_LO_sync;
end
end
/*----------------------- RGMII Rx Sync Module -----------------------*/
`IP_MODULE_NAME(rgmii_sync) u_rgmii_sync
(
//Globle Signals
.rgmii_rxc (rgmii_rxc ),
.rx_reset (rx_reset ),
.eth_speed (eth_speed ),
//RGMII Rx Interface Input
.rgmii_rxd_HI_i (rgmii_rxd_HI_i ),
.rgmii_rxd_LO_i (rgmii_rxd_LO_i ),
.rgmii_rx_ctl_HI_i (rgmii_rx_ctl_HI_i ),
.rgmii_rx_ctl_LO_i (rgmii_rx_ctl_LO_i ),
//RGMII Rx Interface Output
.rgmii_rxd_HI_o (rgmii_rxd_HI_sync ),
.rgmii_rxd_LO_o (rgmii_rxd_LO_sync ),
.rgmii_rx_ctl_HI_o (rgmii_rx_ctl_HI_sync ),
.rgmii_rx_ctl_LO_o (rgmii_rx_ctl_LO_sync )
);
end
endgenerate
endmodule
module `IP_MODULE_NAME(rmii_if)
(
//Globle Signals
input tx_mac_aclk,
output reg tx_mac_aclk_en,
input tx_reset,
output wire rx_mac_aclk,
output reg rx_mac_aclk_en,
input rx_reset,
//Configuration Signals
input [2:0] eth_speed,
//GMII Interface
output reg [7:0] gm_rx_d,
output reg gm_rx_dv,
output reg gm_rx_err,
input [7:0] gm_tx_d,
input gm_tx_en,
input gm_tx_err,
//RGMII Interface
input rmii_clk_ref,
output reg [1:0] rmii_txd,
output reg rmii_tx_en,
input [1:0] rmii_rxd,
input rmii_crs_dv,
input rmii_rx_err
//Status and Error Signals
);
// Parameter Define
// Register Define
reg [6:0] aclk_en_cnt;
reg [6:0] rx_aclk_en_cnt;
reg [1:0] txd;
reg tx_en;
reg tx_er;
reg rx_err_dl1;
reg rx_dv_dl1;
reg [7:0] rxd_dl1;
reg [6:0] rx_odd_data_ptr;
reg [1:0] rxd;
reg rx_dv;
reg rx_er;
reg [7:0] gm_tx_d_temp;
reg tx_en_temp;
reg [6:0] txbit_cnt;
reg rx_dv_compensate;
reg rx_err_compensate;
reg rx_err_latch;
reg [7:0] rx_d_compensate;
reg [6:0] rx_compensate_cnt;
// Wire Define
/*----------------------------------------------------------------------------------*\
The main code
\*----------------------------------------------------------------------------------*/
/*----------------------- Tx Region ----------------------------*/
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
aclk_en_cnt <= 7'd0;
else if (((eth_speed == 3'h2) && (aclk_en_cnt == 7'd3)) ||
((eth_speed == 3'h1) && (aclk_en_cnt == 7'd39)))
aclk_en_cnt <= 7'd0;
else
aclk_en_cnt <= aclk_en_cnt + 1'b1;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_mac_aclk_en <= 1'b0;
else if (aclk_en_cnt == 7'd0)
tx_mac_aclk_en <= 1'b1;
else
tx_mac_aclk_en <= 1'b0;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
gm_tx_d_temp <= 8'h0;
else if ((gm_tx_en == 1'b1) && (tx_mac_aclk_en == 1'b1))
gm_tx_d_temp <= gm_tx_d;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_en_temp <= 1'b0;
else if(tx_mac_aclk_en == 1'b1)
tx_en_temp <= gm_tx_en;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
txbit_cnt <= 7'd0;
else if (((eth_speed == 3'h2) && (txbit_cnt == 7'd3)) ||
((eth_speed == 3'h1) && (txbit_cnt == 7'd39)))
txbit_cnt <= 7'd0;
else if (tx_en_temp == 1'b1)
txbit_cnt <= txbit_cnt + 1'b1;
else
txbit_cnt <= 7'd0;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
txd <= 2'h0;
else if (eth_speed == 3'h2) begin
case(txbit_cnt[1:0])
2'b00: txd <= gm_tx_d_temp[1:0];
2'b01: txd <= gm_tx_d_temp[3:2];
2'b10: txd <= gm_tx_d_temp[5:4];
2'b11: txd <= gm_tx_d_temp[7:6];
default;
endcase
end
else if (eth_speed == 3'h1) begin
case(txbit_cnt[5:0])
6'd00: txd <= gm_tx_d_temp[1:0];
6'd10: txd <= gm_tx_d_temp[3:2];
6'd20: txd <= gm_tx_d_temp[5:4];
6'd30: txd <= gm_tx_d_temp[7:6];
default;
endcase
end
else;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_en <= 1'b0;
else
tx_en <= tx_en_temp;
end
always @ (posedge tx_mac_aclk or posedge tx_reset) begin
if (tx_reset == 1'b1)
tx_er <= 1'b0;
else if (tx_mac_aclk_en == 1'b1)
tx_er <= gm_tx_err;
end
always @ (posedge rmii_clk_ref or posedge tx_reset) begin
if (tx_reset == 1'b1) begin
rmii_tx_en <= 1'b0;
rmii_txd <= 2'b0;
end
else begin
rmii_tx_en <= tx_en;
rmii_txd <= txd[1:0];
end
end
/*----------------------- Rx Region ----------------------------*/
always @(posedge rmii_clk_ref or posedge rx_reset) begin
if (rx_reset == 1'b1) begin
rxd <= 2'b00;
rx_dv <= 1'b0;
rx_er <= 1'b0;
end
else begin
rxd <= rmii_rxd;
rx_dv <= rmii_crs_dv;
rx_er <= rmii_rx_err;
end
end
assign rx_mac_aclk = rmii_clk_ref;
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_aclk_en_cnt <= 7'd0;
else if (((eth_speed == 3'h2) && (rx_aclk_en_cnt == 7'd3)) ||
((eth_speed == 3'h1) && (rx_aclk_en_cnt == 7'd39)))
rx_aclk_en_cnt <= 7'd0;
else
rx_aclk_en_cnt <= rx_aclk_en_cnt + 1'b1;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_mac_aclk_en <= 1'b0;
else if (rx_aclk_en_cnt == 7'd0)
rx_mac_aclk_en <= 1'b1;
else
rx_mac_aclk_en <= 1'b0;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_odd_data_ptr <= 7'd0;
else if (((eth_speed == 3'h2) && (rx_odd_data_ptr == 7'd3)) ||
((eth_speed == 3'h1) && (rx_odd_data_ptr == 7'd39)) || (rx_dv == 1'b0))
rx_odd_data_ptr <= 7'd0;
else
rx_odd_data_ptr <= rx_odd_data_ptr + 1'b1;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_dv_dl1 <= 1'b0;
else
rx_dv_dl1 <= rx_dv;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_err_dl1 <= 1'b0;
else
rx_err_dl1 <= rx_er;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rxd_dl1 <= 8'h0;
else if (eth_speed == 3'h2) begin
case (rx_odd_data_ptr[1:0])
2'b00: rxd_dl1[1:0] <= rxd;
2'b01: rxd_dl1[3:2] <= rxd;
2'b10: rxd_dl1[5:4] <= rxd;
2'b11: rxd_dl1[7:6] <= rxd;
default;
endcase
end
else if (eth_speed == 3'h1) begin
case (rx_odd_data_ptr[5:0])
6'd00: rxd_dl1[1:0] <= rxd;
6'd10: rxd_dl1[3:2] <= rxd;
6'd20: rxd_dl1[5:4] <= rxd;
6'd30: rxd_dl1[7:6] <= rxd;
default;
endcase
end
else;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_compensate_cnt <= 7'b0;
else if (rx_dv_dl1 == 1'b1)
rx_compensate_cnt <= 7'b0;
else if (((eth_speed == 3'h2) && (rx_compensate_cnt == 7'd3)) ||
((eth_speed == 3'h1) && (rx_compensate_cnt == 7'd39)))
rx_compensate_cnt <= rx_compensate_cnt;
else
rx_compensate_cnt <= rx_compensate_cnt + 1;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_dv_compensate <= 1'b0;
else if (((eth_speed == 3'h2) && (rx_compensate_cnt == 7'd3)) ||
((eth_speed == 3'h1) && (rx_compensate_cnt == 7'd39)))
rx_dv_compensate <= 1'b0;
else if ((rx_dv_dl1 == 1'b1) && rx_odd_data_ptr == 7'd0)
rx_dv_compensate <= 1'b1;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_err_latch <= 1'b0;
else begin
if (rx_dv & rx_er) rx_err_latch <= 1'b1;
else if (rx_odd_data_ptr == 7'd0) rx_err_latch <= 1'b0;
else rx_err_latch <= rx_err_latch;
end
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_err_compensate <= 1'b0;
else if (((eth_speed == 3'h2) && (rx_compensate_cnt == 7'd3)) ||
((eth_speed == 3'h1) && (rx_compensate_cnt == 7'd39)))
rx_err_compensate <= 1'b0;
else if (rx_odd_data_ptr == 7'd0)
rx_err_compensate <= rx_err_latch;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
rx_d_compensate <= 8'h0;
else if ((rx_dv_dl1 == 1'b1) && rx_odd_data_ptr == 7'd0)
rx_d_compensate <= rxd_dl1;
else;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
gm_rx_dv <= 1'b0;
else if (rx_mac_aclk_en == 1'b1)
gm_rx_dv <= rx_dv_compensate;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
gm_rx_d <= 8'h0;
else if (rx_mac_aclk_en == 1'b1)
gm_rx_d <= rx_d_compensate;
else;
end
always @ (posedge rx_mac_aclk or posedge rx_reset) begin
if (rx_reset == 1'b1)
gm_rx_err <= 1'b0;
else if (rx_mac_aclk_en == 1'b1)
gm_rx_err <= rx_err_compensate;
end
endmodule
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AdUnj7Bs+hmJ5SGqEqyFUEEMiDRgSp0S2f/VGAUk5v91ubVm2vgtcT4UvOY8OQGq
A+wc8em2skYny3gLEXZmGWWY5M3IOrXXN3garTjgT/5aryDdctZKanGzUfDwK74W
DPdg+zD4MmzgiuU8eKz1ef52GhS+oY1Cc96fkAEweAh/3tvGasLmKHSIQ7ZCsxHI
uSU8DESy32ZzWcXDfpldgfIys4YE/sMJnzZ7g6U0deho5UWElUrJD9K61IXoClnb
PnZtzkA2AnB6RQkVnqyZ/M9paBgFFjA2jqUqJ26dmPzviIlJsf0wlEL8iXwtLh4z
t69l8BOBmXaHLSfmBmAxJw==
//pragma protect end_key_block
//pragma protect digest_block
ePVsN48yGEZh+oJ/8GPEgNrTsQ4=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
4fgubcVSsGbsihJUaEnAoP/WOus=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
ArtFgEcTFuExxn3GR8FXMf8nwl3zKw461a9BondW1J0YUuXertNKCWOunZwIrdrk
kw2YzU9ydjX7blOfOkioZGvDDlgewjLov5Mm5pDGPknUvpOwcW4MZWQrEGy2pLBs
Qohfcymv50b6J4D/31pvxZTePhhccJCdoYSiWn+42UBae/oWJFGidjQmzNFBRaQy
YWiNMTyxxSK6A/fDoVY76cti8cxvT7LsA7n9t7wikAJZ4AjX9A0pT3o0a7/tfAKv
Y5rtMNAzAxGpKz3kT1HsEbG0900ME4mG3SE3k1voeJSSuBlO8Ien/845CEmfKiFt
0QXWlFyuoeA/Oh3YqqX89A==
//pragma protect end_key_block
//pragma protect digest_block
Y7TScLLhiz6ikFqRuivjMbSX+G0=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
xciDfX1Ldbg0C13jX2WprHhS4gs=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AAYwB7coa78/Yuf59VHBW69gLAzRgVmYBXzd6y0lnt3wufZEqvvibKUEmexmwZhs
WPN2aFehFn4jrA23RfpbbUayQa4o1NImVXWBuQPUg1pxveC9IjVzjfODknUQo/7x
wGLGnttzN1H4YcBsgEVHV9C2+FrlVjMt/AXKBX7tyWt/uj/BHegmN05w3eF68ezW
KSSi0+4o8poOVevk+3u6jl/LU5pljIB3wfgTFuQRlyza1iKh3Oi2+amQ4FcEy20S
7rcZo4VsZPsvfejsl2CjAS7ULz8zAWmQ2pHcnujD/AZPRg/QyIlVgfJLnazN4yZq
FVUrqm7EADxShs4MTf6x4Q==
//pragma protect end_key_block
//pragma protect digest_block
ptYnyNqudo4cULGlJXYZ099X40A=
//pragma protect end_digest_block
//pragma protect data_block
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
L7KSnGASAUgTPLwhD/HvLg==
//pragma protect end_data_block
//pragma protect digest_block
8VZnDhHtC+Uqr3bipiiwbVqxO1U=
//pragma protect end_digest_block
//pragma protect end_protected
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
ArZ7vcjjhCv7sCCIwq7Ak8HMUBXa14nxVhK7jXnk/2XpoXqO2IiXlWkfEelaa7VP
515V+5Xso72FipIBiEzqDg/rUT3GGR8W50dw9gd4++WdSDldeLL+7MJTKyoOxSh+
/LP/zH6/9NXeiTZkzqu0zYmFLPdu7FBJoWGWMG8nWby7KOIGMmrawCjWk2/eRtua
kaxTPPfenziW/83T0yjS/AUBh32iSi11xKZrwkTJ5VaDP9ibyW7I0BGQGSLfgjuI
0N1K7Ux2+jHd180YXAO+aQhx1kQiRuBeSasWhNatvSgPxivWJ+BP3Zk/JkifaIoR
Kg+XWdo3A3YzSGCCDBSbag==
//pragma protect end_key_block
//pragma protect digest_block
7HkkPzjj4KfGbdQvpN+onYkUc3Y=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
ufjESfjEyhxiHPCliZDKmztoS0g=
//pragma protect end_digest_block
//pragma protect end_protected
module `IP_MODULE_NAME(efx_mac1gbe) #(
parameter FAMILY = "TRION",
parameter VERSION = 32'h20,
parameter RXFIFO_EN = 1,
parameter RXFIFO_DTH = 2048,
parameter TXFIFO_EN = 1,
parameter TXFIFO_DTH = 2048,
parameter PHY_INTF_MODE = 0,
parameter LOOPBACK_EN = 1'b0,
parameter GMII_DW = PHY_INTF_MODE == 4 ? 16 : 8,
parameter AXIS_DW = 8,
parameter APBIF = 0,
parameter NO_PREAMBLE = 0,
parameter INTER_PACKET_GAP = 6'd12,
parameter MTU_FRAME_LENGTH = 16'd1518,
parameter MAC_SOURCE_ADDRESS = 48'h0,
parameter ENABLE_BROADCAST_FILTERING = 1'b1,
parameter RGMII_RXC_EDGE = 1'b1,
parameter RGMII_TXC_DLY = 1'b1,
parameter PKT_CNT_MAX = 256,
parameter SIP600 = 0
) (
input tx_mac_aclk,
output rx_mac_aclk,
input mac_reset,
input proto_reset,
input tx_axis_clk,
input [AXIS_DW-1:0] tx_axis_mac_tdata,
input tx_axis_mac_tvalid,
input tx_axis_mac_tlast,
input [AXIS_DW/8-1:0] tx_axis_mac_tstrb,
input tx_axis_mac_tuser,
output tx_axis_mac_tready,
input rx_axis_clk,
output [AXIS_DW-1:0] rx_axis_mac_tdata,
output rx_axis_mac_tvalid,
output rx_axis_mac_tlast,
output [AXIS_DW/8-1:0] rx_axis_mac_tstrb,
output rx_axis_mac_tuser,
input rx_axis_mac_tready,
input gm_rx_c,
input [GMII_DW-1:0] gm_rx_d,
input [GMII_DW/8-1:0] gm_rx_dv,
input [GMII_DW/8-1:0] gm_rx_err,
output gm_tx_c,
output [GMII_DW-1:0] gm_tx_d,
output [GMII_DW/8-1:0] gm_tx_en,
output [GMII_DW/8-1:0] gm_tx_err,
output [3:0] rgmii_txd_HI,
output [3:0] rgmii_txd_LO,
output rgmii_tx_ctl_HI,
output rgmii_tx_ctl_LO,
output rgmii_txc_HI,
output rgmii_txc_LO,
input [3:0] rgmii_rxd_HI,
input [3:0] rgmii_rxd_LO,
input rgmii_rx_ctl_HI,
input rgmii_rx_ctl_LO,
input rgmii_rxc,
input mii_txc,
output [3:0] mii_txd,
output mii_tx_dv,
output mii_tx_err,
input mii_rxc,
input [3:0] mii_rxd,
input mii_rx_dv,
input mii_rx_err,
input rmii_clk_ref,
output [1:0] rmii_txd,
output rmii_tx_en,
input [1:0] rmii_rxd,
input rmii_crs_dv,
input rmii_rx_err,
input [9:0] s_paddr,
input [31:0] s_pwdata,
input s_pwrite,
input s_penable,
input s_psel,
output [31:0] s_prdata,
output s_pready,
output s_perr,
input s_axi_aclk,
input [9:0] s_axi_awaddr,
input s_axi_awvalid,
output s_axi_awready,
input [31:0] s_axi_wdata,
input s_axi_wvalid,
output s_axi_wready,
output [1:0] s_axi_bresp,
output s_axi_bvalid,
input s_axi_bready,
input [9:0] s_axi_araddr,
input s_axi_arvalid,
output s_axi_arready,
output [1:0] s_axi_rresp,
output [31:0] s_axi_rdata,
output s_axi_rvalid,
input s_axi_rready,
`ifdef ONCHIP_PHY
input logic init_clk,
input logic init_rst_n,
input logic PMA_CMN_READY,
input logic PMA_XCVR_PLLCLK_EN_ACK,
input logic [3:0] PMA_XCVR_POWER_STATE_ACK,
input logic PMA_RX_SIGNAL_DETECT,
output logic PMA_XCVR_PLLCLK_EN,
output logic [3:0] PMA_XCVR_POWER_STATE_REQ,
output logic phy_init_done,
`else
output Mdo,
output MdoEn,
input Mdi,
output Mdc,
`endif
output [2:0] eth_speed
);
`ifdef ONCHIP_PHY
//pragma protect begin_protected
//pragma protect encrypt_agent="NCPROTECT"
//pragma protect encrypt_agent_info="Encrypted using API"
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=prv(CDS_RSA_KEY_VER_2)
//pragma protect key_method=RSA
//pragma protect key_block
AMyoRL5/w7aGJMUAFjWdggMiBKf1mhnyB4tTNrQUAOHCO5ZmDsFpb964w4qkWZVN
XTiRjcc3GwM/Fmz7oO2RrXaSAbzLZGKR7DnzUuMenl8JrAwGEamBMGjpSL3aMEyl
mCUirfX0tqLb1/uPom1p3lHA+w9re3Qyn6vY/PUBq0IAP0rEKqYSnRPr21y2lJVr
GlwFuPkDG3BEkA5XQ32m2c6FOY1oVdGXaZA0+O0dQ9EHL0US5NFI3VmHggusoT7Z
/TQxNlOAsBkna47aYA7voZoUel9oAm+GvOo4Vs/5V6t6TNw9SkHr16nMswnNfzzb
xGTO/3F/v5LdwzL2hgvz5A==
//pragma protect end_key_block
//pragma protect digest_block
GPFPDOqRYTtfroZsY3lH14yzT1E=
//pragma protect end_digest_block
//pragma protect data_block
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
//pragma protect end_data_block
//pragma protect digest_block
gfSy+yjCs0cH8hBJH8nmuez3sig=
//pragma protect end_digest_block
//pragma protect end_protected
// Module: efx_pulse_sync
// Description:
// Safely transfers a single-cycle pulse from a source clock domain to a
// destination clock domain using a toggle-based synchronization scheme.
//
// ==========================================================================
module `IP_MODULE_NAME(efx_pulse_sync) #(
parameter ACTIVE_LOW = 1, // 0 - Active high reset, 1 - Active low reset
parameter OFF_ASSERTION = 0
) (
input src_clk, // Source clock (e.g., tx_axis_clk)
input src_reset, // Reset for source domain
input pulse_in, // Single-cycle pulse in src_clk domain
input dst_clk, // Destination clock (e.g., tx_clk)
input dst_reset, // Reset for destination domain
output pulse_out // Single-cycle pulse in dst_clk domain
);
// Toggle generation in source clock domain
reg toggle_src;
// Synchronizer flops in destination clock domain
wire toggle_sync;
reg toggle_sync_r;
generate
if (ACTIVE_LOW == 1) begin
always @ (posedge src_clk or negedge src_reset) begin
if (!src_reset)
toggle_src <= 1'b0;
else if (pulse_in)
toggle_src <= ~toggle_src;
else
toggle_src <= toggle_src;
end
`IP_MODULE_NAME(efx_asyncreg) #(
.WIDTH (1),
.OFF_ASSERTION (OFF_ASSERTION)
) efx_asyncreg_toggle_src (
.clk (dst_clk),
.reset_n (dst_reset),
.d_i (toggle_src),
.d_o (toggle_sync)
);
always @ (posedge dst_clk or negedge dst_reset) begin
if (!dst_reset) begin
toggle_sync_r <= 1'b0;
end
else begin
toggle_sync_r <= toggle_sync; // Delay for edge detect
end
end
end
else begin
always @ (posedge src_clk or posedge src_reset) begin
if (src_reset)
toggle_src <= 1'b0;
else if (pulse_in)
toggle_src <= ~toggle_src;
else
toggle_src <= toggle_src;
end
`IP_MODULE_NAME(efx_asyncreg) #(
.WIDTH (1),
.ACTIVE_HIGH (0),
.OFF_ASSERTION (OFF_ASSERTION)
) efx_asyncreg_toggle_src (
.clk (dst_clk),
.reset_n (dst_reset),
.d_i (toggle_src),
.d_o (toggle_sync)
);
always @ (posedge dst_clk or posedge dst_reset) begin
if (!dst_reset) begin
toggle_sync_r <= 1'b0;
end
else begin
toggle_sync_r <= toggle_sync; // Delay for edge detect
end
end
end
endgenerate
// Generate one-cycle pulse in destination domain
assign pulse_out = toggle_sync ^ toggle_sync_r;
endmodule
module `IP_MODULE_NAME(efx_data_pipeline) #(
parameter HBP = 1,
parameter DATA_WIDTH = 256,
parameter MUX_IN = 1
)(
input upstream_valid_i,
output upstream_ready_o,
input [DATA_WIDTH-1:0] upstream_data_i,
output downstream_valid_o,
input downstream_ready_i,
output [DATA_WIDTH-1:0] downstream_data_o,
input clk,
input resetn
);
//pragma protect begin_protected
//pragma protect key_keyowner=Cadence Design Systems.
//pragma protect key_keyname=CDS_KEY
//pragma protect key_method=RC5
//pragma protect key_block
KjlM4WkOO2w2bQEZgp8zfO7oizuHRj0nKnd2HyaTF0mbfmP85E9tcE8RSpnLFQQY
Fx/LQ03PTxfV8SEFCk0j5a/YIXbL+yC7EvSHJ8LQ/Hh5tLpaDgWah36rsTcE2fet
whq92/ag/nAdDF1Vy4sbDr5FINmqPPikptUUvL1vDUmBcBOK5GHbSA==
//pragma protect end_key_block
//pragma protect digest_block
MnZuDl/T4JMKytmOinMcApLLkiI=
//pragma protect end_digest_block
//pragma protect data_block
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
K4vhL/IlI8Mj/z0kKlnD9A==
//pragma protect end_data_block
//pragma protect digest_block
/ZU5wr/v9FLKg6OANYaVJInQw6o=
//pragma protect end_digest_block
//pragma protect end_protected
`undef IP_UUID
`undef IP_NAME_CONCAT
`undef IP_MODULE_NAME