mirror of
https://github.com/DrasLorus/HLS_Byte_Serializer.git
synced 2024-11-24 12:33:17 +01:00
Initial commit (no README yet)
This commit is contained in:
commit
0dd5ec3785
18 changed files with 2277 additions and 0 deletions
165
.clang-format
Normal file
165
.clang-format
Normal file
|
@ -0,0 +1,165 @@
|
||||||
|
---
|
||||||
|
Language: Cpp
|
||||||
|
AccessModifierOffset: -4
|
||||||
|
AlignAfterOpenBracket: Align
|
||||||
|
AlignConsecutiveMacros: Consecutive
|
||||||
|
AlignConsecutiveAssignments: Consecutive
|
||||||
|
AlignConsecutiveBitFields: Consecutive
|
||||||
|
AlignConsecutiveDeclarations: Consecutive
|
||||||
|
AlignEscapedNewlines: Right
|
||||||
|
AlignOperands: AlignAfterOperator
|
||||||
|
AlignTrailingComments: true
|
||||||
|
AllowAllArgumentsOnNextLine: true
|
||||||
|
AllowAllConstructorInitializersOnNextLine: false
|
||||||
|
AllowAllParametersOfDeclarationOnNextLine: true
|
||||||
|
AllowShortEnumsOnASingleLine: true
|
||||||
|
AllowShortBlocksOnASingleLine: Never
|
||||||
|
AllowShortCaseLabelsOnASingleLine: false
|
||||||
|
AllowShortFunctionsOnASingleLine: All
|
||||||
|
AllowShortLambdasOnASingleLine: All
|
||||||
|
AllowShortIfStatementsOnASingleLine: Never
|
||||||
|
AllowShortLoopsOnASingleLine: false
|
||||||
|
AlwaysBreakAfterDefinitionReturnType: None
|
||||||
|
AlwaysBreakAfterReturnType: None
|
||||||
|
AlwaysBreakBeforeMultilineStrings: false
|
||||||
|
AlwaysBreakTemplateDeclarations: MultiLine
|
||||||
|
AttributeMacros:
|
||||||
|
- __capability
|
||||||
|
BinPackArguments: true
|
||||||
|
BinPackParameters: true
|
||||||
|
BraceWrapping:
|
||||||
|
AfterCaseLabel: false
|
||||||
|
AfterClass: false
|
||||||
|
AfterControlStatement: Never
|
||||||
|
AfterEnum: false
|
||||||
|
AfterFunction: false
|
||||||
|
AfterNamespace: false
|
||||||
|
AfterObjCDeclaration: false
|
||||||
|
AfterStruct: false
|
||||||
|
AfterUnion: false
|
||||||
|
AfterExternBlock: false
|
||||||
|
BeforeCatch: false
|
||||||
|
BeforeElse: false
|
||||||
|
BeforeLambdaBody: false
|
||||||
|
BeforeWhile: false
|
||||||
|
IndentBraces: false
|
||||||
|
SplitEmptyFunction: true
|
||||||
|
SplitEmptyRecord: true
|
||||||
|
SplitEmptyNamespace: true
|
||||||
|
BreakBeforeBinaryOperators: true
|
||||||
|
BreakBeforeConceptDeclarations: true
|
||||||
|
BreakBeforeBraces: Attach
|
||||||
|
BreakBeforeInheritanceComma: false
|
||||||
|
BreakInheritanceList: BeforeColon
|
||||||
|
BreakBeforeTernaryOperators: true
|
||||||
|
BreakConstructorInitializersBeforeComma: false
|
||||||
|
BreakConstructorInitializers: BeforeColon
|
||||||
|
BreakAfterJavaFieldAnnotations: true
|
||||||
|
BreakStringLiterals: true
|
||||||
|
ColumnLimit: 0
|
||||||
|
CommentPragmas: '^ IWYU pragma:'
|
||||||
|
CompactNamespaces: false
|
||||||
|
ConstructorInitializerAllOnOneLineOrOnePerLine: true
|
||||||
|
ConstructorInitializerIndentWidth: 4
|
||||||
|
ContinuationIndentWidth: 4
|
||||||
|
Cpp11BracedListStyle: true
|
||||||
|
DeriveLineEnding: true
|
||||||
|
DerivePointerAlignment: false
|
||||||
|
DisableFormat: false
|
||||||
|
EmptyLineBeforeAccessModifier: LogicalBlock
|
||||||
|
ExperimentalAutoDetectBinPacking: false
|
||||||
|
FixNamespaceComments: true
|
||||||
|
ForEachMacros:
|
||||||
|
- foreach
|
||||||
|
- Q_FOREACH
|
||||||
|
- BOOST_FOREACH
|
||||||
|
StatementAttributeLikeMacros:
|
||||||
|
- Q_EMIT
|
||||||
|
IncludeBlocks: Preserve
|
||||||
|
IncludeCategories:
|
||||||
|
- Regex: '^"(llvm|llvm-c|clang|clang-c)/'
|
||||||
|
Priority: 2
|
||||||
|
SortPriority: 0
|
||||||
|
CaseSensitive: false
|
||||||
|
- Regex: '^(<|"(gtest|gmock|isl|json)/)'
|
||||||
|
Priority: 3
|
||||||
|
SortPriority: 0
|
||||||
|
CaseSensitive: false
|
||||||
|
- Regex: '.*'
|
||||||
|
Priority: 1
|
||||||
|
SortPriority: 0
|
||||||
|
CaseSensitive: false
|
||||||
|
IncludeIsMainRegex: '(Test)?$'
|
||||||
|
IncludeIsMainSourceRegex: ''
|
||||||
|
IndentCaseLabels: true
|
||||||
|
IndentCaseBlocks: false
|
||||||
|
IndentGotoLabels: true
|
||||||
|
IndentPPDirectives: None
|
||||||
|
IndentExternBlock: AfterExternBlock
|
||||||
|
IndentRequires: false
|
||||||
|
IndentWidth: 4
|
||||||
|
IndentWrappedFunctionNames: false
|
||||||
|
InsertTrailingCommas: None
|
||||||
|
JavaScriptQuotes: Leave
|
||||||
|
JavaScriptWrapImports: true
|
||||||
|
KeepEmptyLinesAtTheStartOfBlocks: true
|
||||||
|
MacroBlockBegin: ''
|
||||||
|
MacroBlockEnd: ''
|
||||||
|
MaxEmptyLinesToKeep: 1
|
||||||
|
NamespaceIndentation: None
|
||||||
|
ObjCBinPackProtocolList: Auto
|
||||||
|
ObjCBlockIndentWidth: 2
|
||||||
|
ObjCBreakBeforeNestedBlockParam: true
|
||||||
|
ObjCSpaceAfterProperty: false
|
||||||
|
ObjCSpaceBeforeProtocolList: true
|
||||||
|
PenaltyBreakAssignment: 2
|
||||||
|
PenaltyBreakBeforeFirstCallParameter: 19
|
||||||
|
PenaltyBreakComment: 300
|
||||||
|
PenaltyBreakFirstLessLess: 120
|
||||||
|
PenaltyBreakString: 1000
|
||||||
|
PenaltyBreakTemplateDeclaration: 10
|
||||||
|
PenaltyExcessCharacter: 1000000
|
||||||
|
PenaltyReturnTypeOnItsOwnLine: 60
|
||||||
|
PenaltyIndentedWhitespace: 0
|
||||||
|
PointerAlignment: Middle
|
||||||
|
ReflowComments: true
|
||||||
|
SortIncludes: true
|
||||||
|
SortJavaStaticImport: Before
|
||||||
|
SortUsingDeclarations: true
|
||||||
|
SpaceAfterCStyleCast: true
|
||||||
|
SpaceAfterLogicalNot: false
|
||||||
|
SpaceAfterTemplateKeyword: true
|
||||||
|
SpaceBeforeAssignmentOperators: true
|
||||||
|
SpaceBeforeCaseColon: false
|
||||||
|
SpaceBeforeCpp11BracedList: true
|
||||||
|
SpaceBeforeCtorInitializerColon: true
|
||||||
|
SpaceBeforeInheritanceColon: true
|
||||||
|
SpaceBeforeParens: ControlStatements
|
||||||
|
SpaceAroundPointerQualifiers: Default
|
||||||
|
SpaceBeforeRangeBasedForLoopColon: true
|
||||||
|
SpaceInEmptyBlock: false
|
||||||
|
SpaceInEmptyParentheses: false
|
||||||
|
SpacesBeforeTrailingComments: 1
|
||||||
|
SpacesInAngles: false
|
||||||
|
SpacesInConditionalStatement: false
|
||||||
|
SpacesInContainerLiterals: true
|
||||||
|
SpacesInCStyleCastParentheses: false
|
||||||
|
SpacesInParentheses: false
|
||||||
|
SpacesInSquareBrackets: false
|
||||||
|
SpaceBeforeSquareBrackets: false
|
||||||
|
BitFieldColonSpacing: Both
|
||||||
|
Standard: c++14
|
||||||
|
StatementMacros:
|
||||||
|
- Q_UNUSED
|
||||||
|
- QT_REQUIRE_VERSION
|
||||||
|
TabWidth: 4
|
||||||
|
UseCRLF: false
|
||||||
|
UseTab: Never
|
||||||
|
WhitespaceSensitiveMacros:
|
||||||
|
- STRINGIZE
|
||||||
|
- PP_STRINGIZE
|
||||||
|
- BOOST_PP_STRINGIZE
|
||||||
|
- NS_SWIFT_NAME
|
||||||
|
- CF_SWIFT_NAME
|
||||||
|
...
|
||||||
|
|
22
.gitignore
vendored
Normal file
22
.gitignore
vendored
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
# Binary directories
|
||||||
|
.cache/
|
||||||
|
bin/
|
||||||
|
lib/
|
||||||
|
build/
|
||||||
|
ip/
|
||||||
|
*_*_*_to_bytes_ip/
|
||||||
|
*_*_*_from_bytes_ip/
|
||||||
|
|
||||||
|
# Command Database
|
||||||
|
compile_commands.json
|
||||||
|
|
||||||
|
hls_files/*
|
||||||
|
|
||||||
|
!hls_files/generated
|
||||||
|
hls_files/generated/*
|
||||||
|
!hls_files/generated/.empty
|
||||||
|
|
||||||
|
!hls_files/templates
|
||||||
|
hls_files/templates/*.tcl
|
||||||
|
|
||||||
|
sources/top_converters/*.?pp
|
304
CMakeLists.txt
Normal file
304
CMakeLists.txt
Normal file
|
@ -0,0 +1,304 @@
|
||||||
|
#
|
||||||
|
# Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS Contributor(s) :
|
||||||
|
# Camille Monière (2022)
|
||||||
|
#
|
||||||
|
# camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
#
|
||||||
|
# This software is a computer program whose purpose is to simulate and implement C-type to bytes
|
||||||
|
# FPGA IPs.
|
||||||
|
#
|
||||||
|
# This software is governed by the CeCILL-B license under French law and abiding by the rules of
|
||||||
|
# distribution of free software. You can use, modify and/ or redistribute the software under the
|
||||||
|
# terms of the CeCILL-B license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
# "http://www.cecill.info".
|
||||||
|
#
|
||||||
|
# As a counterpart to the access to the source code and rights to copy, modify and redistribute
|
||||||
|
# granted by the license, users are provided only with a limited warranty and the software's
|
||||||
|
# author, the holder of the economic rights, and the successive licensors have only limited
|
||||||
|
# liability.
|
||||||
|
#
|
||||||
|
# In this respect, the user's attention is drawn to the risks associated with loading, using,
|
||||||
|
# modifying and/or developing or reproducing the software by the user in light of its specific
|
||||||
|
# status of free software, that may mean that it is complicated to manipulate, and that also
|
||||||
|
# therefore means that it is reserved for developers and experienced professionals having
|
||||||
|
# in-depth computer knowledge. Users are therefore encouraged to load and test the software's
|
||||||
|
# suitability as regards their requirements in conditions enabling the security of their systems
|
||||||
|
# and/or data to be ensured and, more generally, to use and operate it in the same conditions as
|
||||||
|
# regards security.
|
||||||
|
#
|
||||||
|
# The fact that you are presently reading this means that you have had knowledge of the CeCILL-B
|
||||||
|
# license and that you accept its terms.
|
||||||
|
#
|
||||||
|
|
||||||
|
cmake_minimum_required (VERSION 3.18.0 FATAL_ERROR)
|
||||||
|
# setting this is required
|
||||||
|
|
||||||
|
project (
|
||||||
|
UartWrapperHLS
|
||||||
|
LANGUAGES CXX
|
||||||
|
VERSION 0.1
|
||||||
|
)
|
||||||
|
|
||||||
|
set (CMAKE_CXX_STANDARD 11)
|
||||||
|
set (CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
set (CMAKE_CXX_EXTENSIONS OFF)
|
||||||
|
|
||||||
|
set (CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/../lib)
|
||||||
|
set (CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/../lib)
|
||||||
|
set (CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/../bin)
|
||||||
|
|
||||||
|
# ##################################################################################################
|
||||||
|
# Options
|
||||||
|
# ##################################################################################################
|
||||||
|
|
||||||
|
option (EXPORT_COMMANDS "export compile commands, for use with clangd for example." ON)
|
||||||
|
|
||||||
|
option (XILINX_COSIM "use TCL Vivado/Vitis HLS script to co-simulate the design." OFF)
|
||||||
|
if (XILINX_COSIM)
|
||||||
|
option (XILINX_IP "use TCL Vivado/Vitis HLS script to generate an IP." OFF)
|
||||||
|
if (XILINX_IP)
|
||||||
|
option (XILINX_IMPL "use TCL Vivado/Vitis HLS script to run design implementation." OFF)
|
||||||
|
endif ()
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
option (ENABLE_TESTING "use CTest as a test suite." ON)
|
||||||
|
|
||||||
|
option (PEDANTIC "use -Wall and -pedantic." ON)
|
||||||
|
|
||||||
|
# ##################################################################################################
|
||||||
|
# Parameters
|
||||||
|
# ##################################################################################################
|
||||||
|
|
||||||
|
set (
|
||||||
|
PRM_TYPE
|
||||||
|
"uint32_t"
|
||||||
|
CACHE STRING "Type to convert to/from."
|
||||||
|
)
|
||||||
|
set (TYPE ${PRM_TYPE})
|
||||||
|
|
||||||
|
set (
|
||||||
|
PRM_STRMLEN
|
||||||
|
"1"
|
||||||
|
CACHE STRING "Size of the TYPE stream."
|
||||||
|
)
|
||||||
|
set (STRMLEN ${PRM_STRMLEN})
|
||||||
|
|
||||||
|
set (
|
||||||
|
PRM_ENDIAN
|
||||||
|
"LE"
|
||||||
|
CACHE STRING "Byte stream endianess."
|
||||||
|
)
|
||||||
|
set (ENDIAN ${PRM_ENDIAN})
|
||||||
|
|
||||||
|
# ##################################################################################################
|
||||||
|
|
||||||
|
if (PEDANTIC)
|
||||||
|
add_compile_options (-Wall -pedantic)
|
||||||
|
endif ()
|
||||||
|
add_compile_options (-Wno-unused-label -Wno-unknown-pragmas)
|
||||||
|
|
||||||
|
if (EXPORT_COMMANDS)
|
||||||
|
set (CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
set (
|
||||||
|
XILINX_HOME
|
||||||
|
/opt/Xilinx
|
||||||
|
CACHE PATH "path to Xilinx root folder."
|
||||||
|
)
|
||||||
|
set (
|
||||||
|
XILINX_VER
|
||||||
|
"2019.1"
|
||||||
|
CACHE STRING "Xilinx software version to use."
|
||||||
|
)
|
||||||
|
|
||||||
|
if (XILINX_VER VERSION_GREATER_EQUAL "2020.1")
|
||||||
|
set (
|
||||||
|
AP_INCLUDE_DIR
|
||||||
|
${XILINX_HOME}/Vitis_HLS/${XILINX_VER}/include
|
||||||
|
CACHE INTERNAL "Path to Xilinx includes" FORCE
|
||||||
|
)
|
||||||
|
find_program (
|
||||||
|
XILINX_HLS vitis_hls HINTS ${XILINX_HOME}/Vitis_HLS/${XILINX_VER}/bin NO_CACHE REQUIRED
|
||||||
|
)
|
||||||
|
else ()
|
||||||
|
set (
|
||||||
|
AP_INCLUDE_DIR
|
||||||
|
${XILINX_HOME}/Vivado/${XILINX_VER}/include
|
||||||
|
CACHE INTERNAL "Path to Xilinx includes" FORCE
|
||||||
|
)
|
||||||
|
find_program (
|
||||||
|
XILINX_HLS vivado_hls HINTS ${XILINX_HOME}/Vivado/${XILINX_VER}/bin NO_CACHE REQUIRED
|
||||||
|
)
|
||||||
|
endif ()
|
||||||
|
message (STATUS "AP headers must lie under ${AP_INCLUDE_DIR}")
|
||||||
|
|
||||||
|
if ((NOT EXISTS ${AP_INCLUDE_DIR}/ap_int.h) OR (NOT EXISTS ${AP_INCLUDE_DIR}/ap_fixed.h))
|
||||||
|
message (FATAL_ERROR "Arbitrary precision headers not found in ${AP_INCLUDE_DIR}.\n"
|
||||||
|
"Please provide a suitable path to the headers."
|
||||||
|
)
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
# ##################################################################################################
|
||||||
|
|
||||||
|
add_library (
|
||||||
|
hls_uart_converters sources/CConverter/CConverterToBytes.cpp
|
||||||
|
sources/CConverter/CConverterFromBytes.cpp
|
||||||
|
)
|
||||||
|
target_include_directories (hls_uart_converters PUBLIC sources)
|
||||||
|
target_include_directories (hls_uart_converters SYSTEM PUBLIC ${AP_INCLUDE_DIR})
|
||||||
|
|
||||||
|
# ##################################################################################################
|
||||||
|
# TO BYTES ######################################################################################
|
||||||
|
# ##################################################################################################
|
||||||
|
|
||||||
|
set (CFGIN_TO_TOP_CPP "sources/top_converters/type_strmlen_endian_to_bytes.cpp.in")
|
||||||
|
set (CFGOUT_TO_TOP_CPP
|
||||||
|
"${CMAKE_SOURCE_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes.cpp"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_TO_TOP_CPP} ${CFGOUT_TO_TOP_CPP} @ONLY)
|
||||||
|
|
||||||
|
set (CFGIN_TO_TOP_HPP "sources/top_converters/type_strmlen_endian_to_bytes.hpp.in")
|
||||||
|
set (CFGOUT_TO_TOP_HPP
|
||||||
|
"${CMAKE_SOURCE_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes.hpp"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_TO_TOP_HPP} ${CFGOUT_TO_TOP_HPP} @ONLY)
|
||||||
|
|
||||||
|
set (CFGIN_TO_TB_CPP "sources/top_converters/type_strmlen_endian_to_bytes_tb.cpp.in")
|
||||||
|
set (CFGOUT_TO_TB_CPP
|
||||||
|
"${CMAKE_SOURCE_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes_tb.cpp"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_TO_TB_CPP} ${CFGOUT_TO_TB_CPP} @ONLY)
|
||||||
|
|
||||||
|
set (CFGIN_TO_TCL "hls_files/templates/script_type_strmlen_endian_to_bytes.tcl.in")
|
||||||
|
set (CFGOUT_TO_TCL
|
||||||
|
"${CMAKE_SOURCE_DIR}/hls_files/generated/script_${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes.tcl"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_TO_TCL} ${CFGOUT_TO_TCL} @ONLY)
|
||||||
|
|
||||||
|
add_executable (
|
||||||
|
hls_uart_${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes_tb ${CFGOUT_TO_TOP_CPP} ${CFGOUT_TO_TB_CPP}
|
||||||
|
)
|
||||||
|
target_link_libraries (hls_uart_${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes_tb hls_uart_converters)
|
||||||
|
|
||||||
|
# ##################################################################################################
|
||||||
|
# FROM BYTES ######################################################################################
|
||||||
|
# ##################################################################################################
|
||||||
|
|
||||||
|
set (CFGIN_FROM_TOP_CPP "sources/top_converters/type_strmlen_endian_from_bytes.cpp.in")
|
||||||
|
set (CFGOUT_FROM_TOP_CPP
|
||||||
|
"${CMAKE_SOURCE_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes.cpp"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_FROM_TOP_CPP} ${CFGOUT_FROM_TOP_CPP} @ONLY)
|
||||||
|
|
||||||
|
set (CFGIN_FROM_TOP_HPP "sources/top_converters/type_strmlen_endian_from_bytes.hpp.in")
|
||||||
|
set (CFGOUT_FROM_TOP_HPP
|
||||||
|
"${CMAKE_SOURCE_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes.hpp"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_FROM_TOP_HPP} ${CFGOUT_FROM_TOP_HPP} @ONLY)
|
||||||
|
|
||||||
|
set (CFGIN_FROM_TB_CPP "sources/top_converters/type_strmlen_endian_from_bytes_tb.cpp.in")
|
||||||
|
set (CFGOUT_FROM_TB_CPP
|
||||||
|
"${CMAKE_SOURCE_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes_tb.cpp"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_FROM_TB_CPP} ${CFGOUT_FROM_TB_CPP} @ONLY)
|
||||||
|
|
||||||
|
set (CFGIN_FROM_TCL "hls_files/templates/script_type_strmlen_endian_from_bytes.tcl.in")
|
||||||
|
set (CFGOUT_FROM_TCL
|
||||||
|
"${CMAKE_SOURCE_DIR}/hls_files/generated/script_${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes.tcl"
|
||||||
|
)
|
||||||
|
configure_file (${CFGIN_FROM_TCL} ${CFGOUT_FROM_TCL} @ONLY)
|
||||||
|
|
||||||
|
add_executable (
|
||||||
|
hls_uart_${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes_tb ${CFGOUT_FROM_TOP_CPP} ${CFGOUT_FROM_TB_CPP}
|
||||||
|
)
|
||||||
|
target_link_libraries (hls_uart_${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes_tb hls_uart_converters)
|
||||||
|
|
||||||
|
if (ENABLE_TESTING)
|
||||||
|
include (CTest)
|
||||||
|
|
||||||
|
# find_file (INPUT_DAT_TB input.dat HINTS data NO_CACHE REQUIRED)
|
||||||
|
if (CMAKE_VERSION VERSION_LESS 3.19.0)
|
||||||
|
set (TEST_NAME_TO
|
||||||
|
"\"Xilinx C-Simulation Testbench ${CMAKE_PROJECT_NAME} ${TYPE} ${STRMLEN} ${ENDIAN} TO\""
|
||||||
|
)
|
||||||
|
else ()
|
||||||
|
cmake_policy (SET CMP0110 NEW)
|
||||||
|
set (TEST_NAME_TO
|
||||||
|
"Xilinx C-Simulation Testbench ${CMAKE_PROJECT_NAME} ${TYPE} ${STRMLEN} ${ENDIAN} TO"
|
||||||
|
)
|
||||||
|
endif ()
|
||||||
|
add_test (NAME ${TEST_NAME_TO} COMMAND hls_uart_${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes_tb)
|
||||||
|
|
||||||
|
if (CMAKE_VERSION VERSION_LESS 3.19.0)
|
||||||
|
set (TEST_NAME_FROM
|
||||||
|
"\"Xilinx C-Simulation Testbench ${CMAKE_PROJECT_NAME} ${TYPE} ${STRMLEN} ${ENDIAN} FROM\""
|
||||||
|
)
|
||||||
|
else ()
|
||||||
|
cmake_policy (SET CMP0110 NEW)
|
||||||
|
set (TEST_NAME_FROM
|
||||||
|
"Xilinx C-Simulation Testbench ${CMAKE_PROJECT_NAME} ${TYPE} ${STRMLEN} ${ENDIAN} FROM"
|
||||||
|
)
|
||||||
|
endif ()
|
||||||
|
add_test (NAME ${TEST_NAME_FROM} COMMAND hls_uart_${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes_tb)
|
||||||
|
|
||||||
|
if (XILINX_COSIM)
|
||||||
|
set (
|
||||||
|
XILINX_TESTLINES
|
||||||
|
"1000"
|
||||||
|
CACHE STRING "Number of co-simulation passes"
|
||||||
|
)
|
||||||
|
|
||||||
|
if (XILINX_IP)
|
||||||
|
set (
|
||||||
|
EXPORT_IP
|
||||||
|
"1"
|
||||||
|
CACHE INTERNAL "EXPORT_IP"
|
||||||
|
)
|
||||||
|
if (XILINX_IMPL)
|
||||||
|
set (
|
||||||
|
RUN_IMPL
|
||||||
|
"1"
|
||||||
|
CACHE INTERNAL "RUN_IMPL"
|
||||||
|
)
|
||||||
|
endif ()
|
||||||
|
endif ()
|
||||||
|
add_custom_target (
|
||||||
|
run_hls_to
|
||||||
|
COMMAND ${XILINX_HLS} ${CFGOUT_TO_TCL} ${XILINX_TESTLINES} ${EXPORT_IP} ${RUN_IMPL}
|
||||||
|
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/hls_files
|
||||||
|
USES_TERMINAL
|
||||||
|
)
|
||||||
|
|
||||||
|
add_custom_target (
|
||||||
|
run_hls_from
|
||||||
|
COMMAND ${XILINX_HLS} ${CFGOUT_FROM_TCL} ${XILINX_TESTLINES} ${EXPORT_IP} ${RUN_IMPL}
|
||||||
|
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/hls_files
|
||||||
|
USES_TERMINAL
|
||||||
|
)
|
||||||
|
|
||||||
|
if (CMAKE_VERSION VERSION_LESS 3.19.0)
|
||||||
|
set (TCL_TEST_NAME "\"Xilinx HLS TCL Flow TO\"")
|
||||||
|
else ()
|
||||||
|
cmake_policy (SET CMP0110 NEW)
|
||||||
|
set (TCL_TEST_NAME "Xilinx HLS TCL Flow TO")
|
||||||
|
endif ()
|
||||||
|
add_test (
|
||||||
|
NAME ${TCL_TEST_NAME}
|
||||||
|
COMMAND ${XILINX_HLS} ${CFGOUT_TO_TCL} ${XILINX_TESTLINES} 0 0
|
||||||
|
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/hls_files
|
||||||
|
)
|
||||||
|
|
||||||
|
if (CMAKE_VERSION VERSION_LESS 3.19.0)
|
||||||
|
set (TCL_TEST_NAME "\"Xilinx HLS TCL Flow FROM\"")
|
||||||
|
else ()
|
||||||
|
cmake_policy (SET CMP0110 NEW)
|
||||||
|
set (TCL_TEST_NAME "Xilinx HLS TCL Flow FROM")
|
||||||
|
endif ()
|
||||||
|
add_test (
|
||||||
|
NAME ${TCL_TEST_NAME}
|
||||||
|
COMMAND ${XILINX_HLS} ${CFGOUT_FROM_TCL} ${XILINX_TESTLINES} 0 0
|
||||||
|
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/hls_files
|
||||||
|
)
|
||||||
|
endif ()
|
||||||
|
endif ()
|
515
LICENSE
Normal file
515
LICENSE
Normal file
|
@ -0,0 +1,515 @@
|
||||||
|
|
||||||
|
CeCILL-B FREE SOFTWARE LICENSE AGREEMENT
|
||||||
|
|
||||||
|
|
||||||
|
Notice
|
||||||
|
|
||||||
|
This Agreement is a Free Software license agreement that is the result
|
||||||
|
of discussions between its authors in order to ensure compliance with
|
||||||
|
the two main principles guiding its drafting:
|
||||||
|
|
||||||
|
* firstly, compliance with the principles governing the distribution
|
||||||
|
of Free Software: access to source code, broad rights granted to
|
||||||
|
users,
|
||||||
|
* secondly, the election of a governing law, French law, with which
|
||||||
|
it is conformant, both as regards the law of torts and
|
||||||
|
intellectual property law, and the protection that it offers to
|
||||||
|
both authors and holders of the economic rights over software.
|
||||||
|
|
||||||
|
The authors of the CeCILL-B (for Ce[a] C[nrs] I[nria] L[ogiciel] L[ibre])
|
||||||
|
license are:
|
||||||
|
|
||||||
|
Commissariat à l'Energie Atomique - CEA, a public scientific, technical
|
||||||
|
and industrial research establishment, having its principal place of
|
||||||
|
business at 25 rue Leblanc, immeuble Le Ponant D, 75015 Paris, France.
|
||||||
|
|
||||||
|
Centre National de la Recherche Scientifique - CNRS, a public scientific
|
||||||
|
and technological establishment, having its principal place of business
|
||||||
|
at 3 rue Michel-Ange, 75794 Paris cedex 16, France.
|
||||||
|
|
||||||
|
Institut National de Recherche en Informatique et en Automatique -
|
||||||
|
INRIA, a public scientific and technological establishment, having its
|
||||||
|
principal place of business at Domaine de Voluceau, Rocquencourt, BP
|
||||||
|
105, 78153 Le Chesnay cedex, France.
|
||||||
|
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
This Agreement is an open source software license intended to give users
|
||||||
|
significant freedom to modify and redistribute the software licensed
|
||||||
|
hereunder.
|
||||||
|
|
||||||
|
The exercising of this freedom is conditional upon a strong obligation
|
||||||
|
of giving credits for everybody that distributes a software
|
||||||
|
incorporating a software ruled by the current license so as all
|
||||||
|
contributions to be properly identified and acknowledged.
|
||||||
|
|
||||||
|
In consideration of access to the source code and the rights to copy,
|
||||||
|
modify and redistribute granted by the license, users are provided only
|
||||||
|
with a limited warranty and the software's author, the holder of the
|
||||||
|
economic rights, and the successive licensors only have limited liability.
|
||||||
|
|
||||||
|
In this respect, the risks associated with loading, using, modifying
|
||||||
|
and/or developing or reproducing the software by the user are brought to
|
||||||
|
the user's attention, given its Free Software status, which may make it
|
||||||
|
complicated to use, with the result that its use is reserved for
|
||||||
|
developers and experienced professionals having in-depth computer
|
||||||
|
knowledge. Users are therefore encouraged to load and test the
|
||||||
|
suitability of the software as regards their requirements in conditions
|
||||||
|
enabling the security of their systems and/or data to be ensured and,
|
||||||
|
more generally, to use and operate it in the same conditions of
|
||||||
|
security. This Agreement may be freely reproduced and published,
|
||||||
|
provided it is not altered, and that no provisions are either added or
|
||||||
|
removed herefrom.
|
||||||
|
|
||||||
|
This Agreement may apply to any or all software for which the holder of
|
||||||
|
the economic rights decides to submit the use thereof to its provisions.
|
||||||
|
|
||||||
|
|
||||||
|
Article 1 - DEFINITIONS
|
||||||
|
|
||||||
|
For the purpose of this Agreement, when the following expressions
|
||||||
|
commence with a capital letter, they shall have the following meaning:
|
||||||
|
|
||||||
|
Agreement: means this license agreement, and its possible subsequent
|
||||||
|
versions and annexes.
|
||||||
|
|
||||||
|
Software: means the software in its Object Code and/or Source Code form
|
||||||
|
and, where applicable, its documentation, "as is" when the Licensee
|
||||||
|
accepts the Agreement.
|
||||||
|
|
||||||
|
Initial Software: means the Software in its Source Code and possibly its
|
||||||
|
Object Code form and, where applicable, its documentation, "as is" when
|
||||||
|
it is first distributed under the terms and conditions of the Agreement.
|
||||||
|
|
||||||
|
Modified Software: means the Software modified by at least one
|
||||||
|
Contribution.
|
||||||
|
|
||||||
|
Source Code: means all the Software's instructions and program lines to
|
||||||
|
which access is required so as to modify the Software.
|
||||||
|
|
||||||
|
Object Code: means the binary files originating from the compilation of
|
||||||
|
the Source Code.
|
||||||
|
|
||||||
|
Holder: means the holder(s) of the economic rights over the Initial
|
||||||
|
Software.
|
||||||
|
|
||||||
|
Licensee: means the Software user(s) having accepted the Agreement.
|
||||||
|
|
||||||
|
Contributor: means a Licensee having made at least one Contribution.
|
||||||
|
|
||||||
|
Licensor: means the Holder, or any other individual or legal entity, who
|
||||||
|
distributes the Software under the Agreement.
|
||||||
|
|
||||||
|
Contribution: means any or all modifications, corrections, translations,
|
||||||
|
adaptations and/or new functions integrated into the Software by any or
|
||||||
|
all Contributors, as well as any or all Internal Modules.
|
||||||
|
|
||||||
|
Module: means a set of sources files including their documentation that
|
||||||
|
enables supplementary functions or services in addition to those offered
|
||||||
|
by the Software.
|
||||||
|
|
||||||
|
External Module: means any or all Modules, not derived from the
|
||||||
|
Software, so that this Module and the Software run in separate address
|
||||||
|
spaces, with one calling the other when they are run.
|
||||||
|
|
||||||
|
Internal Module: means any or all Module, connected to the Software so
|
||||||
|
that they both execute in the same address space.
|
||||||
|
|
||||||
|
Parties: mean both the Licensee and the Licensor.
|
||||||
|
|
||||||
|
These expressions may be used both in singular and plural form.
|
||||||
|
|
||||||
|
|
||||||
|
Article 2 - PURPOSE
|
||||||
|
|
||||||
|
The purpose of the Agreement is the grant by the Licensor to the
|
||||||
|
Licensee of a non-exclusive, transferable and worldwide license for the
|
||||||
|
Software as set forth in Article 5 hereinafter for the whole term of the
|
||||||
|
protection granted by the rights over said Software.
|
||||||
|
|
||||||
|
|
||||||
|
Article 3 - ACCEPTANCE
|
||||||
|
|
||||||
|
3.1 The Licensee shall be deemed as having accepted the terms and
|
||||||
|
conditions of this Agreement upon the occurrence of the first of the
|
||||||
|
following events:
|
||||||
|
|
||||||
|
* (i) loading the Software by any or all means, notably, by
|
||||||
|
downloading from a remote server, or by loading from a physical
|
||||||
|
medium;
|
||||||
|
* (ii) the first time the Licensee exercises any of the rights
|
||||||
|
granted hereunder.
|
||||||
|
|
||||||
|
3.2 One copy of the Agreement, containing a notice relating to the
|
||||||
|
characteristics of the Software, to the limited warranty, and to the
|
||||||
|
fact that its use is restricted to experienced users has been provided
|
||||||
|
to the Licensee prior to its acceptance as set forth in Article 3.1
|
||||||
|
hereinabove, and the Licensee hereby acknowledges that it has read and
|
||||||
|
understood it.
|
||||||
|
|
||||||
|
|
||||||
|
Article 4 - EFFECTIVE DATE AND TERM
|
||||||
|
|
||||||
|
|
||||||
|
4.1 EFFECTIVE DATE
|
||||||
|
|
||||||
|
The Agreement shall become effective on the date when it is accepted by
|
||||||
|
the Licensee as set forth in Article 3.1.
|
||||||
|
|
||||||
|
|
||||||
|
4.2 TERM
|
||||||
|
|
||||||
|
The Agreement shall remain in force for the entire legal term of
|
||||||
|
protection of the economic rights over the Software.
|
||||||
|
|
||||||
|
|
||||||
|
Article 5 - SCOPE OF RIGHTS GRANTED
|
||||||
|
|
||||||
|
The Licensor hereby grants to the Licensee, who accepts, the following
|
||||||
|
rights over the Software for any or all use, and for the term of the
|
||||||
|
Agreement, on the basis of the terms and conditions set forth hereinafter.
|
||||||
|
|
||||||
|
Besides, if the Licensor owns or comes to own one or more patents
|
||||||
|
protecting all or part of the functions of the Software or of its
|
||||||
|
components, the Licensor undertakes not to enforce the rights granted by
|
||||||
|
these patents against successive Licensees using, exploiting or
|
||||||
|
modifying the Software. If these patents are transferred, the Licensor
|
||||||
|
undertakes to have the transferees subscribe to the obligations set
|
||||||
|
forth in this paragraph.
|
||||||
|
|
||||||
|
|
||||||
|
5.1 RIGHT OF USE
|
||||||
|
|
||||||
|
The Licensee is authorized to use the Software, without any limitation
|
||||||
|
as to its fields of application, with it being hereinafter specified
|
||||||
|
that this comprises:
|
||||||
|
|
||||||
|
1. permanent or temporary reproduction of all or part of the Software
|
||||||
|
by any or all means and in any or all form.
|
||||||
|
|
||||||
|
2. loading, displaying, running, or storing the Software on any or
|
||||||
|
all medium.
|
||||||
|
|
||||||
|
3. entitlement to observe, study or test its operation so as to
|
||||||
|
determine the ideas and principles behind any or all constituent
|
||||||
|
elements of said Software. This shall apply when the Licensee
|
||||||
|
carries out any or all loading, displaying, running, transmission
|
||||||
|
or storage operation as regards the Software, that it is entitled
|
||||||
|
to carry out hereunder.
|
||||||
|
|
||||||
|
|
||||||
|
5.2 ENTITLEMENT TO MAKE CONTRIBUTIONS
|
||||||
|
|
||||||
|
The right to make Contributions includes the right to translate, adapt,
|
||||||
|
arrange, or make any or all modifications to the Software, and the right
|
||||||
|
to reproduce the resulting software.
|
||||||
|
|
||||||
|
The Licensee is authorized to make any or all Contributions to the
|
||||||
|
Software provided that it includes an explicit notice that it is the
|
||||||
|
author of said Contribution and indicates the date of the creation thereof.
|
||||||
|
|
||||||
|
|
||||||
|
5.3 RIGHT OF DISTRIBUTION
|
||||||
|
|
||||||
|
In particular, the right of distribution includes the right to publish,
|
||||||
|
transmit and communicate the Software to the general public on any or
|
||||||
|
all medium, and by any or all means, and the right to market, either in
|
||||||
|
consideration of a fee, or free of charge, one or more copies of the
|
||||||
|
Software by any means.
|
||||||
|
|
||||||
|
The Licensee is further authorized to distribute copies of the modified
|
||||||
|
or unmodified Software to third parties according to the terms and
|
||||||
|
conditions set forth hereinafter.
|
||||||
|
|
||||||
|
|
||||||
|
5.3.1 DISTRIBUTION OF SOFTWARE WITHOUT MODIFICATION
|
||||||
|
|
||||||
|
The Licensee is authorized to distribute true copies of the Software in
|
||||||
|
Source Code or Object Code form, provided that said distribution
|
||||||
|
complies with all the provisions of the Agreement and is accompanied by:
|
||||||
|
|
||||||
|
1. a copy of the Agreement,
|
||||||
|
|
||||||
|
2. a notice relating to the limitation of both the Licensor's
|
||||||
|
warranty and liability as set forth in Articles 8 and 9,
|
||||||
|
|
||||||
|
and that, in the event that only the Object Code of the Software is
|
||||||
|
redistributed, the Licensee allows effective access to the full Source
|
||||||
|
Code of the Software at a minimum during the entire period of its
|
||||||
|
distribution of the Software, it being understood that the additional
|
||||||
|
cost of acquiring the Source Code shall not exceed the cost of
|
||||||
|
transferring the data.
|
||||||
|
|
||||||
|
|
||||||
|
5.3.2 DISTRIBUTION OF MODIFIED SOFTWARE
|
||||||
|
|
||||||
|
If the Licensee makes any Contribution to the Software, the resulting
|
||||||
|
Modified Software may be distributed under a license agreement other
|
||||||
|
than this Agreement subject to compliance with the provisions of Article
|
||||||
|
5.3.4.
|
||||||
|
|
||||||
|
|
||||||
|
5.3.3 DISTRIBUTION OF EXTERNAL MODULES
|
||||||
|
|
||||||
|
When the Licensee has developed an External Module, the terms and
|
||||||
|
conditions of this Agreement do not apply to said External Module, that
|
||||||
|
may be distributed under a separate license agreement.
|
||||||
|
|
||||||
|
|
||||||
|
5.3.4 CREDITS
|
||||||
|
|
||||||
|
Any Licensee who may distribute a Modified Software hereby expressly
|
||||||
|
agrees to:
|
||||||
|
|
||||||
|
1. indicate in the related documentation that it is based on the
|
||||||
|
Software licensed hereunder, and reproduce the intellectual
|
||||||
|
property notice for the Software,
|
||||||
|
|
||||||
|
2. ensure that written indications of the Software intended use,
|
||||||
|
intellectual property notice and license hereunder are included in
|
||||||
|
easily accessible format from the Modified Software interface,
|
||||||
|
|
||||||
|
3. mention, on a freely accessible website describing the Modified
|
||||||
|
Software, at least throughout the distribution term thereof, that
|
||||||
|
it is based on the Software licensed hereunder, and reproduce the
|
||||||
|
Software intellectual property notice,
|
||||||
|
|
||||||
|
4. where it is distributed to a third party that may distribute a
|
||||||
|
Modified Software without having to make its source code
|
||||||
|
available, make its best efforts to ensure that said third party
|
||||||
|
agrees to comply with the obligations set forth in this Article .
|
||||||
|
|
||||||
|
If the Software, whether or not modified, is distributed with an
|
||||||
|
External Module designed for use in connection with the Software, the
|
||||||
|
Licensee shall submit said External Module to the foregoing obligations.
|
||||||
|
|
||||||
|
|
||||||
|
5.3.5 COMPATIBILITY WITH THE CeCILL AND CeCILL-C LICENSES
|
||||||
|
|
||||||
|
Where a Modified Software contains a Contribution subject to the CeCILL
|
||||||
|
license, the provisions set forth in Article 5.3.4 shall be optional.
|
||||||
|
|
||||||
|
A Modified Software may be distributed under the CeCILL-C license. In
|
||||||
|
such a case the provisions set forth in Article 5.3.4 shall be optional.
|
||||||
|
|
||||||
|
|
||||||
|
Article 6 - INTELLECTUAL PROPERTY
|
||||||
|
|
||||||
|
|
||||||
|
6.1 OVER THE INITIAL SOFTWARE
|
||||||
|
|
||||||
|
The Holder owns the economic rights over the Initial Software. Any or
|
||||||
|
all use of the Initial Software is subject to compliance with the terms
|
||||||
|
and conditions under which the Holder has elected to distribute its work
|
||||||
|
and no one shall be entitled to modify the terms and conditions for the
|
||||||
|
distribution of said Initial Software.
|
||||||
|
|
||||||
|
The Holder undertakes that the Initial Software will remain ruled at
|
||||||
|
least by this Agreement, for the duration set forth in Article 4.2.
|
||||||
|
|
||||||
|
|
||||||
|
6.2 OVER THE CONTRIBUTIONS
|
||||||
|
|
||||||
|
The Licensee who develops a Contribution is the owner of the
|
||||||
|
intellectual property rights over this Contribution as defined by
|
||||||
|
applicable law.
|
||||||
|
|
||||||
|
|
||||||
|
6.3 OVER THE EXTERNAL MODULES
|
||||||
|
|
||||||
|
The Licensee who develops an External Module is the owner of the
|
||||||
|
intellectual property rights over this External Module as defined by
|
||||||
|
applicable law and is free to choose the type of agreement that shall
|
||||||
|
govern its distribution.
|
||||||
|
|
||||||
|
|
||||||
|
6.4 JOINT PROVISIONS
|
||||||
|
|
||||||
|
The Licensee expressly undertakes:
|
||||||
|
|
||||||
|
1. not to remove, or modify, in any manner, the intellectual property
|
||||||
|
notices attached to the Software;
|
||||||
|
|
||||||
|
2. to reproduce said notices, in an identical manner, in the copies
|
||||||
|
of the Software modified or not.
|
||||||
|
|
||||||
|
The Licensee undertakes not to directly or indirectly infringe the
|
||||||
|
intellectual property rights of the Holder and/or Contributors on the
|
||||||
|
Software and to take, where applicable, vis-à-vis its staff, any and all
|
||||||
|
measures required to ensure respect of said intellectual property rights
|
||||||
|
of the Holder and/or Contributors.
|
||||||
|
|
||||||
|
|
||||||
|
Article 7 - RELATED SERVICES
|
||||||
|
|
||||||
|
7.1 Under no circumstances shall the Agreement oblige the Licensor to
|
||||||
|
provide technical assistance or maintenance services for the Software.
|
||||||
|
|
||||||
|
However, the Licensor is entitled to offer this type of services. The
|
||||||
|
terms and conditions of such technical assistance, and/or such
|
||||||
|
maintenance, shall be set forth in a separate instrument. Only the
|
||||||
|
Licensor offering said maintenance and/or technical assistance services
|
||||||
|
shall incur liability therefor.
|
||||||
|
|
||||||
|
7.2 Similarly, any Licensor is entitled to offer to its licensees, under
|
||||||
|
its sole responsibility, a warranty, that shall only be binding upon
|
||||||
|
itself, for the redistribution of the Software and/or the Modified
|
||||||
|
Software, under terms and conditions that it is free to decide. Said
|
||||||
|
warranty, and the financial terms and conditions of its application,
|
||||||
|
shall be subject of a separate instrument executed between the Licensor
|
||||||
|
and the Licensee.
|
||||||
|
|
||||||
|
|
||||||
|
Article 8 - LIABILITY
|
||||||
|
|
||||||
|
8.1 Subject to the provisions of Article 8.2, the Licensee shall be
|
||||||
|
entitled to claim compensation for any direct loss it may have suffered
|
||||||
|
from the Software as a result of a fault on the part of the relevant
|
||||||
|
Licensor, subject to providing evidence thereof.
|
||||||
|
|
||||||
|
8.2 The Licensor's liability is limited to the commitments made under
|
||||||
|
this Agreement and shall not be incurred as a result of in particular:
|
||||||
|
(i) loss due the Licensee's total or partial failure to fulfill its
|
||||||
|
obligations, (ii) direct or consequential loss that is suffered by the
|
||||||
|
Licensee due to the use or performance of the Software, and (iii) more
|
||||||
|
generally, any consequential loss. In particular the Parties expressly
|
||||||
|
agree that any or all pecuniary or business loss (i.e. loss of data,
|
||||||
|
loss of profits, operating loss, loss of customers or orders,
|
||||||
|
opportunity cost, any disturbance to business activities) or any or all
|
||||||
|
legal proceedings instituted against the Licensee by a third party,
|
||||||
|
shall constitute consequential loss and shall not provide entitlement to
|
||||||
|
any or all compensation from the Licensor.
|
||||||
|
|
||||||
|
|
||||||
|
Article 9 - WARRANTY
|
||||||
|
|
||||||
|
9.1 The Licensee acknowledges that the scientific and technical
|
||||||
|
state-of-the-art when the Software was distributed did not enable all
|
||||||
|
possible uses to be tested and verified, nor for the presence of
|
||||||
|
possible defects to be detected. In this respect, the Licensee's
|
||||||
|
attention has been drawn to the risks associated with loading, using,
|
||||||
|
modifying and/or developing and reproducing the Software which are
|
||||||
|
reserved for experienced users.
|
||||||
|
|
||||||
|
The Licensee shall be responsible for verifying, by any or all means,
|
||||||
|
the suitability of the product for its requirements, its good working
|
||||||
|
order, and for ensuring that it shall not cause damage to either persons
|
||||||
|
or properties.
|
||||||
|
|
||||||
|
9.2 The Licensor hereby represents, in good faith, that it is entitled
|
||||||
|
to grant all the rights over the Software (including in particular the
|
||||||
|
rights set forth in Article 5).
|
||||||
|
|
||||||
|
9.3 The Licensee acknowledges that the Software is supplied "as is" by
|
||||||
|
the Licensor without any other express or tacit warranty, other than
|
||||||
|
that provided for in Article 9.2 and, in particular, without any warranty
|
||||||
|
as to its commercial value, its secured, safe, innovative or relevant
|
||||||
|
nature.
|
||||||
|
|
||||||
|
Specifically, the Licensor does not warrant that the Software is free
|
||||||
|
from any error, that it will operate without interruption, that it will
|
||||||
|
be compatible with the Licensee's own equipment and software
|
||||||
|
configuration, nor that it will meet the Licensee's requirements.
|
||||||
|
|
||||||
|
9.4 The Licensor does not either expressly or tacitly warrant that the
|
||||||
|
Software does not infringe any third party intellectual property right
|
||||||
|
relating to a patent, software or any other property right. Therefore,
|
||||||
|
the Licensor disclaims any and all liability towards the Licensee
|
||||||
|
arising out of any or all proceedings for infringement that may be
|
||||||
|
instituted in respect of the use, modification and redistribution of the
|
||||||
|
Software. Nevertheless, should such proceedings be instituted against
|
||||||
|
the Licensee, the Licensor shall provide it with technical and legal
|
||||||
|
assistance for its defense. Such technical and legal assistance shall be
|
||||||
|
decided on a case-by-case basis between the relevant Licensor and the
|
||||||
|
Licensee pursuant to a memorandum of understanding. The Licensor
|
||||||
|
disclaims any and all liability as regards the Licensee's use of the
|
||||||
|
name of the Software. No warranty is given as regards the existence of
|
||||||
|
prior rights over the name of the Software or as regards the existence
|
||||||
|
of a trademark.
|
||||||
|
|
||||||
|
|
||||||
|
Article 10 - TERMINATION
|
||||||
|
|
||||||
|
10.1 In the event of a breach by the Licensee of its obligations
|
||||||
|
hereunder, the Licensor may automatically terminate this Agreement
|
||||||
|
thirty (30) days after notice has been sent to the Licensee and has
|
||||||
|
remained ineffective.
|
||||||
|
|
||||||
|
10.2 A Licensee whose Agreement is terminated shall no longer be
|
||||||
|
authorized to use, modify or distribute the Software. However, any
|
||||||
|
licenses that it may have granted prior to termination of the Agreement
|
||||||
|
shall remain valid subject to their having been granted in compliance
|
||||||
|
with the terms and conditions hereof.
|
||||||
|
|
||||||
|
|
||||||
|
Article 11 - MISCELLANEOUS
|
||||||
|
|
||||||
|
|
||||||
|
11.1 EXCUSABLE EVENTS
|
||||||
|
|
||||||
|
Neither Party shall be liable for any or all delay, or failure to
|
||||||
|
perform the Agreement, that may be attributable to an event of force
|
||||||
|
majeure, an act of God or an outside cause, such as defective
|
||||||
|
functioning or interruptions of the electricity or telecommunications
|
||||||
|
networks, network paralysis following a virus attack, intervention by
|
||||||
|
government authorities, natural disasters, water damage, earthquakes,
|
||||||
|
fire, explosions, strikes and labor unrest, war, etc.
|
||||||
|
|
||||||
|
11.2 Any failure by either Party, on one or more occasions, to invoke
|
||||||
|
one or more of the provisions hereof, shall under no circumstances be
|
||||||
|
interpreted as being a waiver by the interested Party of its right to
|
||||||
|
invoke said provision(s) subsequently.
|
||||||
|
|
||||||
|
11.3 The Agreement cancels and replaces any or all previous agreements,
|
||||||
|
whether written or oral, between the Parties and having the same
|
||||||
|
purpose, and constitutes the entirety of the agreement between said
|
||||||
|
Parties concerning said purpose. No supplement or modification to the
|
||||||
|
terms and conditions hereof shall be effective as between the Parties
|
||||||
|
unless it is made in writing and signed by their duly authorized
|
||||||
|
representatives.
|
||||||
|
|
||||||
|
11.4 In the event that one or more of the provisions hereof were to
|
||||||
|
conflict with a current or future applicable act or legislative text,
|
||||||
|
said act or legislative text shall prevail, and the Parties shall make
|
||||||
|
the necessary amendments so as to comply with said act or legislative
|
||||||
|
text. All other provisions shall remain effective. Similarly, invalidity
|
||||||
|
of a provision of the Agreement, for any reason whatsoever, shall not
|
||||||
|
cause the Agreement as a whole to be invalid.
|
||||||
|
|
||||||
|
|
||||||
|
11.5 LANGUAGE
|
||||||
|
|
||||||
|
The Agreement is drafted in both French and English and both versions
|
||||||
|
are deemed authentic.
|
||||||
|
|
||||||
|
|
||||||
|
Article 12 - NEW VERSIONS OF THE AGREEMENT
|
||||||
|
|
||||||
|
12.1 Any person is authorized to duplicate and distribute copies of this
|
||||||
|
Agreement.
|
||||||
|
|
||||||
|
12.2 So as to ensure coherence, the wording of this Agreement is
|
||||||
|
protected and may only be modified by the authors of the License, who
|
||||||
|
reserve the right to periodically publish updates or new versions of the
|
||||||
|
Agreement, each with a separate number. These subsequent versions may
|
||||||
|
address new issues encountered by Free Software.
|
||||||
|
|
||||||
|
12.3 Any Software distributed under a given version of the Agreement may
|
||||||
|
only be subsequently distributed under the same version of the Agreement
|
||||||
|
or a subsequent version.
|
||||||
|
|
||||||
|
|
||||||
|
Article 13 - GOVERNING LAW AND JURISDICTION
|
||||||
|
|
||||||
|
13.1 The Agreement is governed by French law. The Parties agree to
|
||||||
|
endeavor to seek an amicable solution to any disagreements or disputes
|
||||||
|
that may arise during the performance of the Agreement.
|
||||||
|
|
||||||
|
13.2 Failing an amicable solution within two (2) months as from their
|
||||||
|
occurrence, and unless emergency proceedings are necessary, the
|
||||||
|
disagreements or disputes shall be referred to the Paris Courts having
|
||||||
|
jurisdiction, by the more diligent Party.
|
||||||
|
|
||||||
|
|
||||||
|
Version 1.0 dated 2006-09-05.
|
240
cmake_format_conf.py
Normal file
240
cmake_format_conf.py
Normal file
|
@ -0,0 +1,240 @@
|
||||||
|
# ----------------------------------
|
||||||
|
# Options affecting listfile parsing
|
||||||
|
# ----------------------------------
|
||||||
|
with section("parse"):
|
||||||
|
|
||||||
|
# Specify structure for custom cmake functions
|
||||||
|
# additional_commands = {'foo': {'flags': ['BAR', 'BAZ'],
|
||||||
|
# 'kwargs': {'DEPENDS': '*', 'HEADERS': '*', 'SOURCES': '*'}}}
|
||||||
|
|
||||||
|
# Override configurations per-command where available
|
||||||
|
override_spec = {}
|
||||||
|
|
||||||
|
# Specify variable tags.
|
||||||
|
vartags = []
|
||||||
|
|
||||||
|
# Specify property tags.
|
||||||
|
proptags = []
|
||||||
|
|
||||||
|
# -----------------------------
|
||||||
|
# Options affecting formatting.
|
||||||
|
# -----------------------------
|
||||||
|
with section("format"):
|
||||||
|
|
||||||
|
# Disable formatting entirely, making cmake-format a no-op
|
||||||
|
disable = False
|
||||||
|
|
||||||
|
# How wide to allow formatted cmake files
|
||||||
|
line_width = 100
|
||||||
|
|
||||||
|
# How many spaces to tab for indent
|
||||||
|
tab_size = 2
|
||||||
|
|
||||||
|
# If true, lines are indented using tab characters (utf-8 0x09) instead of
|
||||||
|
# <tab_size> space characters (utf-8 0x20). In cases where the layout would
|
||||||
|
# require a fractional tab character, the behavior of the fractional
|
||||||
|
# indentation is governed by <fractional_tab_policy>
|
||||||
|
use_tabchars = False
|
||||||
|
|
||||||
|
# If <use_tabchars> is True, then the value of this variable indicates how
|
||||||
|
# fractional indentions are handled during whitespace replacement. If set to
|
||||||
|
# 'use-space', fractional indentation is left as spaces (utf-8 0x20). If set
|
||||||
|
# to `round-up` fractional indentation is replaced with a single tab character
|
||||||
|
# (utf-8 0x09) effectively shifting the column to the next tabstop
|
||||||
|
fractional_tab_policy = 'round-up'
|
||||||
|
|
||||||
|
# If an argument group contains more than this many sub-groups (parg or kwarg
|
||||||
|
# groups) then force it to a vertical layout.
|
||||||
|
max_subgroups_hwrap = 2
|
||||||
|
|
||||||
|
# If a positional argument group contains more than this many arguments, then
|
||||||
|
# force it to a vertical layout.
|
||||||
|
max_pargs_hwrap = 3
|
||||||
|
|
||||||
|
# If a cmdline positional group consumes more than this many lines without
|
||||||
|
# nesting, then invalidate the layout (and nest)
|
||||||
|
max_rows_cmdline = 2
|
||||||
|
|
||||||
|
# If true, separate flow control names from their parentheses with a space
|
||||||
|
separate_ctrl_name_with_space = True
|
||||||
|
|
||||||
|
# If true, separate function names from parentheses with a space
|
||||||
|
separate_fn_name_with_space = True
|
||||||
|
|
||||||
|
# If a statement is wrapped to more than one line, than dangle the closing
|
||||||
|
# parenthesis on its own line.
|
||||||
|
dangle_parens = True
|
||||||
|
|
||||||
|
# If the trailing parenthesis must be 'dangled' on its on line, then align it
|
||||||
|
# to this reference: `prefix`: the start of the statement, `prefix-indent`:
|
||||||
|
# the start of the statement, plus one indentation level, `child`: align to
|
||||||
|
# the column of the arguments
|
||||||
|
dangle_align = 'prefix'
|
||||||
|
|
||||||
|
# If the statement spelling length (including space and parenthesis) is
|
||||||
|
# smaller than this amount, then force reject nested layouts.
|
||||||
|
min_prefix_chars = 4
|
||||||
|
|
||||||
|
# If the statement spelling length (including space and parenthesis) is larger
|
||||||
|
# than the tab width by more than this amount, then force reject un-nested
|
||||||
|
# layouts.
|
||||||
|
max_prefix_chars = 10
|
||||||
|
|
||||||
|
# If a candidate layout is wrapped horizontally but it exceeds this many
|
||||||
|
# lines, then reject the layout.
|
||||||
|
max_lines_hwrap = 2
|
||||||
|
|
||||||
|
# What style line endings to use in the output.
|
||||||
|
line_ending = 'unix'
|
||||||
|
|
||||||
|
# Format command names consistently as 'lower' or 'upper' case
|
||||||
|
command_case = 'lower'
|
||||||
|
|
||||||
|
# Format keywords consistently as 'lower' or 'upper' case
|
||||||
|
keyword_case = 'upper'
|
||||||
|
|
||||||
|
# A list of command names which should always be wrapped
|
||||||
|
always_wrap = []
|
||||||
|
|
||||||
|
# If true, the argument lists which are known to be sortable will be sorted
|
||||||
|
# lexicographicall
|
||||||
|
enable_sort = True
|
||||||
|
|
||||||
|
# If true, the parsers may infer whether or not an argument list is sortable
|
||||||
|
# (without annotation).
|
||||||
|
autosort = False
|
||||||
|
|
||||||
|
# By default, if cmake-format cannot successfully fit everything into the
|
||||||
|
# desired linewidth it will apply the last, most agressive attempt that it
|
||||||
|
# made. If this flag is True, however, cmake-format will print error, exit
|
||||||
|
# with non-zero status code, and write-out nothing
|
||||||
|
require_valid_layout = False
|
||||||
|
|
||||||
|
# A dictionary mapping layout nodes to a list of wrap decisions. See the
|
||||||
|
# documentation for more information.
|
||||||
|
layout_passes = {}
|
||||||
|
|
||||||
|
# ------------------------------------------------
|
||||||
|
# Options affecting comment reflow and formatting.
|
||||||
|
# ------------------------------------------------
|
||||||
|
with section("markup"):
|
||||||
|
|
||||||
|
# What character to use for bulleted lists
|
||||||
|
bullet_char = '*'
|
||||||
|
|
||||||
|
# What character to use as punctuation after numerals in an enumerated list
|
||||||
|
enum_char = '.'
|
||||||
|
|
||||||
|
# If comment markup is enabled, don't reflow the first comment block in each
|
||||||
|
# listfile. Use this to preserve formatting of your copyright/license
|
||||||
|
# statements.
|
||||||
|
first_comment_is_literal = False
|
||||||
|
|
||||||
|
# If comment markup is enabled, don't reflow any comment block which matches
|
||||||
|
# this (regex) pattern. Default is `None` (disabled).
|
||||||
|
literal_comment_pattern = None
|
||||||
|
|
||||||
|
# Regular expression to match preformat fences in comments default=
|
||||||
|
# ``r'^\s*([`~]{3}[`~]*)(.*)$'``
|
||||||
|
fence_pattern = '^\\s*([`~]{3}[`~]*)(.*)$'
|
||||||
|
|
||||||
|
# Regular expression to match rulers in comments default=
|
||||||
|
# ``r'^\s*[^\w\s]{3}.*[^\w\s]{3}$'``
|
||||||
|
ruler_pattern = '^\\s*[^\\w\\s]{3}.*[^\\w\\s]{3}$'
|
||||||
|
|
||||||
|
# If a comment line matches starts with this pattern then it is explicitly a
|
||||||
|
# trailing comment for the preceeding argument. Default is '#<'
|
||||||
|
explicit_trailing_pattern = '#<'
|
||||||
|
|
||||||
|
# If a comment line starts with at least this many consecutive hash
|
||||||
|
# characters, then don't lstrip() them off. This allows for lazy hash rulers
|
||||||
|
# where the first hash int8_t is not separated by space
|
||||||
|
hashruler_min_length = 10
|
||||||
|
|
||||||
|
# If true, then insert a space between the first hash int8_t and remaining hash
|
||||||
|
# chars in a hash ruler, and normalize its length to fill the column
|
||||||
|
canonicalize_hashrulers = True
|
||||||
|
|
||||||
|
# enable comment markup parsing and reflow
|
||||||
|
enable_markup = True
|
||||||
|
|
||||||
|
# ----------------------------
|
||||||
|
# Options affecting the linter
|
||||||
|
# ----------------------------
|
||||||
|
with section("lint"):
|
||||||
|
|
||||||
|
# a list of lint codes to disable
|
||||||
|
disabled_codes = []
|
||||||
|
|
||||||
|
# regular expression pattern describing valid function names
|
||||||
|
function_pattern = '[0-9a-z_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid macro names
|
||||||
|
macro_pattern = '[0-9A-Z_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid names for variables with global
|
||||||
|
# (cache) scope
|
||||||
|
global_var_pattern = '[A-Z][0-9A-Z_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid names for variables with global
|
||||||
|
# scope (but internal semantic)
|
||||||
|
internal_var_pattern = '_[A-Z][0-9A-Z_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid names for variables with local
|
||||||
|
# scope
|
||||||
|
local_var_pattern = '[a-z][a-z0-9_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid names for privatedirectory
|
||||||
|
# variables
|
||||||
|
private_var_pattern = '_[0-9a-z_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid names for public directory
|
||||||
|
# variables
|
||||||
|
public_var_pattern = '[A-Z][0-9A-Z_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid names for function/macro
|
||||||
|
# arguments and loop variables.
|
||||||
|
argument_var_pattern = '[a-z][a-z0-9_]+'
|
||||||
|
|
||||||
|
# regular expression pattern describing valid names for keywords used in
|
||||||
|
# functions or macros
|
||||||
|
keyword_pattern = '[A-Z][0-9A-Z_]+'
|
||||||
|
|
||||||
|
# In the heuristic for C0201, how many conditionals to match within a loop in
|
||||||
|
# before considering the loop a parser.
|
||||||
|
max_conditionals_custom_parser = 2
|
||||||
|
|
||||||
|
# Require at least this many newlines between statements
|
||||||
|
min_statement_spacing = 1
|
||||||
|
|
||||||
|
# Require no more than this many newlines between statements
|
||||||
|
max_statement_spacing = 2
|
||||||
|
max_returns = 6
|
||||||
|
max_branches = 12
|
||||||
|
max_arguments = 5
|
||||||
|
max_localvars = 15
|
||||||
|
max_statements = 50
|
||||||
|
|
||||||
|
# -------------------------------
|
||||||
|
# Options affecting file encoding
|
||||||
|
# -------------------------------
|
||||||
|
with section("encode"):
|
||||||
|
|
||||||
|
# If true, emit the unicode byte-order mark (BOM) at the start of the file
|
||||||
|
emit_byteorder_mark = False
|
||||||
|
|
||||||
|
# Specify the encoding of the input file. Defaults to utf-8
|
||||||
|
input_encoding = 'utf-8'
|
||||||
|
|
||||||
|
# Specify the encoding of the output file. Defaults to utf-8. Note that cmake
|
||||||
|
# only claims to support utf-8 so be careful when using anything else
|
||||||
|
output_encoding = 'utf-8'
|
||||||
|
|
||||||
|
# -------------------------------------
|
||||||
|
# Miscellaneous configurations options.
|
||||||
|
# -------------------------------------
|
||||||
|
with section("misc"):
|
||||||
|
|
||||||
|
# A dictionary containing any per-command configuration overrides. Currently
|
||||||
|
# only `command_case` is supported.
|
||||||
|
per_command = {}
|
1
hls_files/generated/.empty
Normal file
1
hls_files/generated/.empty
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Empty file
|
153
hls_files/templates/script_type_strmlen_endian_from_bytes.tcl.in
Normal file
153
hls_files/templates/script_type_strmlen_endian_from_bytes.tcl.in
Normal file
|
@ -0,0 +1,153 @@
|
||||||
|
#
|
||||||
|
# Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
# Contributor(s) : Camille Monière (2022)
|
||||||
|
#
|
||||||
|
# camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
#
|
||||||
|
# This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
# to bytes FPGA IPs.
|
||||||
|
#
|
||||||
|
# This software is governed by the CeCILL-B license under French law and
|
||||||
|
# abiding by the rules of distribution of free software. You can use,
|
||||||
|
# modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
# license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
# "http://www.cecill.info".
|
||||||
|
#
|
||||||
|
# As a counterpart to the access to the source code and rights to copy,
|
||||||
|
# modify and redistribute granted by the license, users are provided only
|
||||||
|
# with a limited warranty and the software's author, the holder of the
|
||||||
|
# economic rights, and the successive licensors have only limited
|
||||||
|
# liability.
|
||||||
|
#
|
||||||
|
# In this respect, the user's attention is drawn to the risks associated
|
||||||
|
# with loading, using, modifying and/or developing or reproducing the
|
||||||
|
# software by the user in light of its specific status of free software,
|
||||||
|
# that may mean that it is complicated to manipulate, and that also
|
||||||
|
# therefore means that it is reserved for developers and experienced
|
||||||
|
# professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
# encouraged to load and test the software's suitability as regards their
|
||||||
|
# requirements in conditions enabling the security of their systems and/or
|
||||||
|
# data to be ensured and, more generally, to use and operate it in the
|
||||||
|
# same conditions as regards security.
|
||||||
|
#
|
||||||
|
# The fact that you are presently reading this means that you have had
|
||||||
|
# knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
#
|
||||||
|
|
||||||
|
set SCRIPT_DIR [file normalize [file dirname [info script]]]
|
||||||
|
set ROOT_DIR [file normalize "${SCRIPT_DIR}/../.."]
|
||||||
|
|
||||||
|
set VERSION [version -short]
|
||||||
|
set XILINX_MAJOR [expr {int($VERSION)}]
|
||||||
|
|
||||||
|
set cnt 0
|
||||||
|
if { [expr {$argc > 0}] } {
|
||||||
|
set argp 0
|
||||||
|
while { $argp < $argc } {
|
||||||
|
set curr [lindex $argv $argp]
|
||||||
|
if { [string index $curr 0] != "-" } {
|
||||||
|
if { $cnt == 0 } {
|
||||||
|
set NLINES $curr
|
||||||
|
set cnt [expr { $cnt + 1 }]
|
||||||
|
} elseif { $cnt == 1 } {
|
||||||
|
set EXPORT_IP $curr
|
||||||
|
set cnt [expr { $cnt + 1 }]
|
||||||
|
} elseif { $cnt == 2 } {
|
||||||
|
set RUN_IMPL $curr
|
||||||
|
set cnt [expr { $cnt + 1 }]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
set argp [ expr { $argp + 1 } ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if { $cnt < 1 } {
|
||||||
|
set NLINES 10000
|
||||||
|
set EXPORT_IP 0
|
||||||
|
set RUN_IMPL 0
|
||||||
|
} elseif { $cnt < 2 } {
|
||||||
|
set EXPORT_IP 0
|
||||||
|
set RUN_IMPL 0
|
||||||
|
} elseif { $cnt < 3 } {
|
||||||
|
set RUN_IMPL 0
|
||||||
|
}
|
||||||
|
|
||||||
|
set ENDIAN @ENDIAN@
|
||||||
|
set TYPE @TYPE@
|
||||||
|
set STRMLEN @STRMLEN@
|
||||||
|
set clk "100MHz"
|
||||||
|
|
||||||
|
if [ expr {$VERSION > 2020.0} ] {
|
||||||
|
set CFLAGS "-std=c++11 -Wno-unknown-pragmas -Wno-unused-label -Wall -DNDEBUG -DXILINX_MAJOR=${XILINX_MAJOR} -isystem ${ROOT_DIR}/hls_max_template/sources/modules -I${ROOT_DIR}/sources -I${ROOT_DIR}/CORDIC_Rotate_APFX/RomGenerators/sources"
|
||||||
|
} else {
|
||||||
|
set CFLAGS "-std=c++0x -Wno-unknown-pragmas -Wno-unused-label -Wall -DNDEBUG -DXILINX_MAJOR=${XILINX_MAJOR} -isystem ${ROOT_DIR}/hls_max_template/sources/modules -I${ROOT_DIR}/sources -I${ROOT_DIR}/CORDIC_Rotate_APFX/RomGenerators/sources"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
set PROJECT_NAME "${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes_ip"
|
||||||
|
open_project -reset "${PROJECT_NAME}"
|
||||||
|
set_top ${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes
|
||||||
|
add_files "${ROOT_DIR}/sources/CConverter/CConverterFromBytes.cpp" -cflags "${CFLAGS}"
|
||||||
|
add_files "${ROOT_DIR}/sources/CConverter/CConverterFromBytes.hpp" -cflags "${CFLAGS}"
|
||||||
|
add_files "${ROOT_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes.cpp" -cflags "${CFLAGS}"
|
||||||
|
add_files "${ROOT_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes.hpp" -cflags "${CFLAGS}"
|
||||||
|
add_files -tb "${ROOT_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes_tb.cpp" -cflags "${CFLAGS}"
|
||||||
|
|
||||||
|
set SOLUTION_NAME "solution_auto"
|
||||||
|
if [ expr {$VERSION > 2020.0} ] {
|
||||||
|
open_solution ${SOLUTION_NAME} -flow_target vivado
|
||||||
|
} else {
|
||||||
|
open_solution ${SOLUTION_NAME}
|
||||||
|
}
|
||||||
|
|
||||||
|
set_part {xc7k325t-ffg900-2}
|
||||||
|
create_clock -period ${clk} -name default
|
||||||
|
set_clock_uncertainty 10%
|
||||||
|
|
||||||
|
if { [ file exists "directives.tcl" ] } {
|
||||||
|
source "directives.tcl"
|
||||||
|
}
|
||||||
|
|
||||||
|
set_directive_interface -mode ap_ctrl_none ${TYPE}_${STRMLEN}_${ENDIAN}_from_bytes
|
||||||
|
|
||||||
|
csim_design -clean -O -argv "${NLINES}"
|
||||||
|
csynth_design
|
||||||
|
cosim_design -O -argv "${NLINES}"
|
||||||
|
|
||||||
|
if { $EXPORT_IP } {
|
||||||
|
config_export \
|
||||||
|
-rtl verilog \
|
||||||
|
-format ip_catalog \
|
||||||
|
-description "Convert ${STRMLEN} ${TYPE} from bytes ${ENDIAN} at ${clk}" \
|
||||||
|
-vendor "DrasLorus" \
|
||||||
|
-display_name "${STRMLEN} ${TYPE} bus from ${ENDIAN} bytes converter ${clk}" \
|
||||||
|
-version "0.1.00${XILINX_MAJOR}" \
|
||||||
|
-ipname "bytes${ENDIAN}2${TYPE}_${STRMLEN}_${clk}" \
|
||||||
|
-vivado_optimization_level 2 \
|
||||||
|
-vivado_phys_opt route
|
||||||
|
|
||||||
|
if [ expr {! [ file isdirectory "${ROOT_DIR}/ip" ] } ] {
|
||||||
|
if { [ file exists "${ROOT_DIR}/ip" ] } {
|
||||||
|
file remove "${ROOT_DIR}/ip"
|
||||||
|
}
|
||||||
|
file mkdir "${ROOT_DIR}/ip"
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ expr {$VERSION > 2020.0} ] {
|
||||||
|
export_design -output "${ROOT_DIR}/ip/bytes${ENDIAN}2${TYPE}_${STRMLEN}_${clk}_${XILINX_MAJOR}.zip"
|
||||||
|
} else {
|
||||||
|
export_design
|
||||||
|
set IP_FILE [glob -directory "${PROJECT_NAME}/${SOLUTION_NAME}/impl/ip" -- "*.zip"]
|
||||||
|
file copy -force -- "${IP_FILE}" "${ROOT_DIR}/ip/bytes${ENDIAN}2${TYPE}_${STRMLEN}_${clk}_${XILINX_MAJOR}.zip"
|
||||||
|
}
|
||||||
|
|
||||||
|
if { $RUN_IMPL } {
|
||||||
|
export_design -flow impl
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
close_solution
|
||||||
|
|
||||||
|
|
||||||
|
close_project
|
||||||
|
exit 0
|
153
hls_files/templates/script_type_strmlen_endian_to_bytes.tcl.in
Normal file
153
hls_files/templates/script_type_strmlen_endian_to_bytes.tcl.in
Normal file
|
@ -0,0 +1,153 @@
|
||||||
|
#
|
||||||
|
# Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
# Contributor(s) : Camille Monière (2022)
|
||||||
|
#
|
||||||
|
# camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
#
|
||||||
|
# This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
# to bytes FPGA IPs.
|
||||||
|
#
|
||||||
|
# This software is governed by the CeCILL-B license under French law and
|
||||||
|
# abiding by the rules of distribution of free software. You can use,
|
||||||
|
# modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
# license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
# "http://www.cecill.info".
|
||||||
|
#
|
||||||
|
# As a counterpart to the access to the source code and rights to copy,
|
||||||
|
# modify and redistribute granted by the license, users are provided only
|
||||||
|
# with a limited warranty and the software's author, the holder of the
|
||||||
|
# economic rights, and the successive licensors have only limited
|
||||||
|
# liability.
|
||||||
|
#
|
||||||
|
# In this respect, the user's attention is drawn to the risks associated
|
||||||
|
# with loading, using, modifying and/or developing or reproducing the
|
||||||
|
# software by the user in light of its specific status of free software,
|
||||||
|
# that may mean that it is complicated to manipulate, and that also
|
||||||
|
# therefore means that it is reserved for developers and experienced
|
||||||
|
# professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
# encouraged to load and test the software's suitability as regards their
|
||||||
|
# requirements in conditions enabling the security of their systems and/or
|
||||||
|
# data to be ensured and, more generally, to use and operate it in the
|
||||||
|
# same conditions as regards security.
|
||||||
|
#
|
||||||
|
# The fact that you are presently reading this means that you have had
|
||||||
|
# knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
#
|
||||||
|
|
||||||
|
set SCRIPT_DIR [file normalize [file dirname [info script]]]
|
||||||
|
set ROOT_DIR [file normalize "${SCRIPT_DIR}/../.."]
|
||||||
|
|
||||||
|
set VERSION [version -short]
|
||||||
|
set XILINX_MAJOR [expr {int($VERSION)}]
|
||||||
|
|
||||||
|
set cnt 0
|
||||||
|
if { [expr {$argc > 0}] } {
|
||||||
|
set argp 0
|
||||||
|
while { $argp < $argc } {
|
||||||
|
set curr [lindex $argv $argp]
|
||||||
|
if { [string index $curr 0] != "-" } {
|
||||||
|
if { $cnt == 0 } {
|
||||||
|
set NLINES $curr
|
||||||
|
set cnt [expr { $cnt + 1 }]
|
||||||
|
} elseif { $cnt == 1 } {
|
||||||
|
set EXPORT_IP $curr
|
||||||
|
set cnt [expr { $cnt + 1 }]
|
||||||
|
} elseif { $cnt == 2 } {
|
||||||
|
set RUN_IMPL $curr
|
||||||
|
set cnt [expr { $cnt + 1 }]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
set argp [ expr { $argp + 1 } ]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if { $cnt < 1 } {
|
||||||
|
set NLINES 10000
|
||||||
|
set EXPORT_IP 0
|
||||||
|
set RUN_IMPL 0
|
||||||
|
} elseif { $cnt < 2 } {
|
||||||
|
set EXPORT_IP 0
|
||||||
|
set RUN_IMPL 0
|
||||||
|
} elseif { $cnt < 3 } {
|
||||||
|
set RUN_IMPL 0
|
||||||
|
}
|
||||||
|
|
||||||
|
set ENDIAN @ENDIAN@
|
||||||
|
set TYPE @TYPE@
|
||||||
|
set STRMLEN @STRMLEN@
|
||||||
|
set clk "100MHz"
|
||||||
|
|
||||||
|
if [ expr {$VERSION > 2020.0} ] {
|
||||||
|
set CFLAGS "-std=c++11 -Wno-unknown-pragmas -Wno-unused-label -Wall -DNDEBUG -DXILINX_MAJOR=${XILINX_MAJOR} -isystem ${ROOT_DIR}/hls_max_template/sources/modules -I${ROOT_DIR}/sources -I${ROOT_DIR}/CORDIC_Rotate_APFX/RomGenerators/sources"
|
||||||
|
} else {
|
||||||
|
set CFLAGS "-std=c++0x -Wno-unknown-pragmas -Wno-unused-label -Wall -DNDEBUG -DXILINX_MAJOR=${XILINX_MAJOR} -isystem ${ROOT_DIR}/hls_max_template/sources/modules -I${ROOT_DIR}/sources -I${ROOT_DIR}/CORDIC_Rotate_APFX/RomGenerators/sources"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
set PROJECT_NAME "${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes_ip"
|
||||||
|
open_project -reset "${PROJECT_NAME}"
|
||||||
|
set_top ${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes
|
||||||
|
add_files "${ROOT_DIR}/sources/CConverter/CConverterToBytes.cpp" -cflags "${CFLAGS}"
|
||||||
|
add_files "${ROOT_DIR}/sources/CConverter/CConverterToBytes.hpp" -cflags "${CFLAGS}"
|
||||||
|
add_files "${ROOT_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes.cpp" -cflags "${CFLAGS}"
|
||||||
|
add_files "${ROOT_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes.hpp" -cflags "${CFLAGS}"
|
||||||
|
add_files -tb "${ROOT_DIR}/sources/top_converters/${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes_tb.cpp" -cflags "${CFLAGS}"
|
||||||
|
|
||||||
|
set SOLUTION_NAME "solution_auto"
|
||||||
|
if [ expr {$VERSION > 2020.0} ] {
|
||||||
|
open_solution ${SOLUTION_NAME} -flow_target vivado
|
||||||
|
} else {
|
||||||
|
open_solution ${SOLUTION_NAME}
|
||||||
|
}
|
||||||
|
|
||||||
|
set_part {xc7k325t-ffg900-2}
|
||||||
|
create_clock -period ${clk} -name default
|
||||||
|
set_clock_uncertainty 10%
|
||||||
|
|
||||||
|
if { [ file exists "directives.tcl" ] } {
|
||||||
|
source "directives.tcl"
|
||||||
|
}
|
||||||
|
|
||||||
|
set_directive_interface -mode ap_ctrl_none ${TYPE}_${STRMLEN}_${ENDIAN}_to_bytes
|
||||||
|
|
||||||
|
csim_design -clean -O -argv "${NLINES}"
|
||||||
|
csynth_design
|
||||||
|
cosim_design -O -argv "${NLINES}"
|
||||||
|
|
||||||
|
if { $EXPORT_IP } {
|
||||||
|
config_export \
|
||||||
|
-rtl verilog \
|
||||||
|
-format ip_catalog \
|
||||||
|
-description "Convert ${STRMLEN} ${TYPE} to bytes ${ENDIAN} at ${clk}" \
|
||||||
|
-vendor "DrasLorus" \
|
||||||
|
-display_name "${STRMLEN} ${TYPE} bus to ${ENDIAN} bytes converter ${clk}" \
|
||||||
|
-version "0.1.00${XILINX_MAJOR}" \
|
||||||
|
-ipname "${TYPE}2bytes${ENDIAN}_${STRMLEN}_${clk}" \
|
||||||
|
-vivado_optimization_level 2 \
|
||||||
|
-vivado_phys_opt route
|
||||||
|
|
||||||
|
if [ expr {! [ file isdirectory "${ROOT_DIR}/ip" ] } ] {
|
||||||
|
if { [ file exists "${ROOT_DIR}/ip" ] } {
|
||||||
|
file remove "${ROOT_DIR}/ip"
|
||||||
|
}
|
||||||
|
file mkdir "${ROOT_DIR}/ip"
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ expr {$VERSION > 2020.0} ] {
|
||||||
|
export_design -output "${ROOT_DIR}/ip/${TYPE}2bytes${ENDIAN}_${STRMLEN}_${clk}_${XILINX_MAJOR}.zip"
|
||||||
|
} else {
|
||||||
|
export_design
|
||||||
|
set IP_FILE [glob -directory "${PROJECT_NAME}/${SOLUTION_NAME}/impl/ip" -- "*.zip"]
|
||||||
|
file copy -force -- "${IP_FILE}" "${ROOT_DIR}/ip/${TYPE}2bytes${ENDIAN}_${STRMLEN}_${clk}_${XILINX_MAJOR}.zip"
|
||||||
|
}
|
||||||
|
|
||||||
|
if { $RUN_IMPL } {
|
||||||
|
export_design -flow impl
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
close_solution
|
||||||
|
|
||||||
|
|
||||||
|
close_project
|
||||||
|
exit 0
|
42
sources/CConverter/CConverterFromBytes.cpp
Normal file
42
sources/CConverter/CConverterFromBytes.cpp
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _CONVERTER_FROM_BYTES_HPP_
|
||||||
|
#define _CONVERTER_FROM_BYTES_HPP_
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif // _CONVERTER_FROM_BYTES_HPP_
|
95
sources/CConverter/CConverterFromBytes.hpp
Normal file
95
sources/CConverter/CConverterFromBytes.hpp
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _CONVERTER_FROM_BYTES_HPP_
|
||||||
|
#define _CONVERTER_FROM_BYTES_HPP_
|
||||||
|
|
||||||
|
#include <ap_int.h>
|
||||||
|
#include <cstdint>
|
||||||
|
#include <hls_stream.h>
|
||||||
|
|
||||||
|
template <uint32_t stream_len = 1, bool LittleEndian = true>
|
||||||
|
class CConverterFromBytes;
|
||||||
|
|
||||||
|
template <uint32_t stream_len>
|
||||||
|
class CConverterFromBytes<stream_len, true> {
|
||||||
|
public:
|
||||||
|
template <typename T, uint32_t sizeofT = sizeof(T)>
|
||||||
|
static void process(hls::stream<uint8_t> & strm_in, hls::stream<T> & strm_out) {
|
||||||
|
#if !defined(XILINX_MAJOR)
|
||||||
|
static_assert(std::numeric_limits<T>::is_integer, "T must be an integer C-type.");
|
||||||
|
static_assert(std::is_unsigned<T>(), "T must be an unsigned type.");
|
||||||
|
#endif
|
||||||
|
LOOP_STR_B2T_LE:
|
||||||
|
for (uint32_t u = 0; u < stream_len; u++) {
|
||||||
|
ap_uint<sizeofT * 8> word_buffer = 0;
|
||||||
|
LOOP_BYTE_B2T_LE:
|
||||||
|
for (uint32_t v = 0; v < sizeofT; v++) {
|
||||||
|
const ap_uint<8> byte_buffer = strm_in.read();
|
||||||
|
|
||||||
|
word_buffer >>= 8;
|
||||||
|
word_buffer(sizeofT * 8 - 1, (sizeofT - 1) * 8) = byte_buffer.range();
|
||||||
|
}
|
||||||
|
strm_out.write(word_buffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <uint32_t stream_len>
|
||||||
|
class CConverterFromBytes<stream_len, false> {
|
||||||
|
public:
|
||||||
|
template <typename T, uint32_t sizeofT = sizeof(T)>
|
||||||
|
static void process(hls::stream<uint8_t> & strm_in, hls::stream<T> & strm_out) {
|
||||||
|
#if !defined(XILINX_MAJOR)
|
||||||
|
static_assert(std::numeric_limits<T>::is_integer, "T must be an integer C-type.");
|
||||||
|
static_assert(std::is_unsigned<T>(), "T must be an unsigned type.");
|
||||||
|
#endif
|
||||||
|
LOOP_STR_B2T_BE:
|
||||||
|
for (uint32_t u = 0; u < stream_len; u++) {
|
||||||
|
ap_uint<sizeofT * 8> word_buffer = 0;
|
||||||
|
LOOP_BYTE_B2T_BE:
|
||||||
|
for (uint32_t v = 0; v < sizeofT; v++) {
|
||||||
|
const ap_uint<8> byte_buffer = strm_in.read();
|
||||||
|
|
||||||
|
word_buffer <<= 8;
|
||||||
|
word_buffer += byte_buffer;
|
||||||
|
}
|
||||||
|
strm_out.write(word_buffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // _CONVERTER_FROM_BYTES_HPP_
|
42
sources/CConverter/CConverterToBytes.cpp
Normal file
42
sources/CConverter/CConverterToBytes.cpp
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _CONVERTER_TO_BYTES_HPP_
|
||||||
|
#define _CONVERTER_TO_BYTES_HPP_
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif // _CONVERTER_TO_BYTES_HPP_
|
93
sources/CConverter/CConverterToBytes.hpp
Normal file
93
sources/CConverter/CConverterToBytes.hpp
Normal file
|
@ -0,0 +1,93 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _CONVERTER_TO_BYTES_HPP_
|
||||||
|
#define _CONVERTER_TO_BYTES_HPP_
|
||||||
|
|
||||||
|
#include <ap_int.h>
|
||||||
|
#include <cstdint>
|
||||||
|
#include <hls_stream.h>
|
||||||
|
|
||||||
|
template <uint32_t stream_len = 1, bool LittleEndian = true>
|
||||||
|
class CConverterToBytes;
|
||||||
|
|
||||||
|
template <uint32_t stream_len>
|
||||||
|
class CConverterToBytes<stream_len, true> {
|
||||||
|
public:
|
||||||
|
template <typename T, uint32_t sizeofT = sizeof(T)>
|
||||||
|
static void process(hls::stream<T> & strm_in, hls::stream<uint8_t> & strm_out) {
|
||||||
|
#if !defined(XILINX_MAJOR)
|
||||||
|
static_assert(std::numeric_limits<T>::is_integer, "T must be an integer C-type.");
|
||||||
|
static_assert(std::is_unsigned<T>(), "T must be an unsigned type.");
|
||||||
|
#endif
|
||||||
|
LOOP_STR_T2B_LE:
|
||||||
|
for (uint32_t u = 0; u < stream_len; u++) {
|
||||||
|
ap_uint<sizeofT * 8> word_buffer = strm_in.read();
|
||||||
|
LOOP_BYTE_T2B_LE:
|
||||||
|
for (uint32_t v = 0; v < sizeofT; v++) {
|
||||||
|
const ap_uint<8> byte_buffer = word_buffer(7, 0);
|
||||||
|
|
||||||
|
strm_out.write(byte_buffer);
|
||||||
|
word_buffer >>= 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <uint32_t stream_len>
|
||||||
|
class CConverterToBytes<stream_len, false> {
|
||||||
|
public:
|
||||||
|
template <typename T, uint32_t sizeofT = sizeof(T)>
|
||||||
|
static void process(hls::stream<T> & strm_in, hls::stream<uint8_t> & strm_out) {
|
||||||
|
#if !defined(XILINX_MAJOR)
|
||||||
|
static_assert(std::numeric_limits<T>::is_integer, "T must be an integer C-type.");
|
||||||
|
static_assert(std::is_unsigned<T>(), "T must be an unsigned type.");
|
||||||
|
#endif
|
||||||
|
LOOP_STR_T2B_BE:
|
||||||
|
for (uint32_t u = 0; u < stream_len; u++) {
|
||||||
|
ap_uint<sizeofT * 8> word_buffer = strm_in.read();
|
||||||
|
LOOP_BYTE_T2B_BE:
|
||||||
|
for (uint32_t v = 0; v < sizeofT; v++) {
|
||||||
|
const ap_uint<8> byte_buffer = word_buffer(sizeofT * 8 - 1, (sizeofT - 1) * 8);
|
||||||
|
|
||||||
|
strm_out.write(byte_buffer);
|
||||||
|
word_buffer <<= 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // _CONVERTER_TO_BYTES_HPP_
|
41
sources/top_converters/type_strmlen_endian_from_bytes.cpp.in
Normal file
41
sources/top_converters/type_strmlen_endian_from_bytes.cpp.in
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "top_converters/@TYPE@_@STRMLEN@_@ENDIAN@_from_bytes.hpp"
|
||||||
|
|
||||||
|
void @TYPE@_@STRMLEN@_@ENDIAN@_from_bytes(hls::stream<uint8_t> & strm_in, hls::stream<@TYPE@> & strm_out) {
|
||||||
|
CConverterFromBytes<@STRMLEN@, @ENDIAN@>::process(strm_in, strm_out);
|
||||||
|
}
|
49
sources/top_converters/type_strmlen_endian_from_bytes.hpp.in
Normal file
49
sources/top_converters/type_strmlen_endian_from_bytes.hpp.in
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _@TYPE@_@STRMLEN@_@ENDIAN@_FROM_BYTES_HPP_
|
||||||
|
#define _@TYPE@_@STRMLEN@_@ENDIAN@_FROM_BYTES_HPP_
|
||||||
|
|
||||||
|
#include "CConverter/CConverterFromBytes.hpp"
|
||||||
|
|
||||||
|
#if !defined(LE) || !defined(BE) || LE != true || BE != false
|
||||||
|
#define LE true
|
||||||
|
#define BE false
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void @TYPE@_@STRMLEN@_@ENDIAN@_from_bytes(hls::stream<uint8_t> & strm_in, hls::stream<@TYPE@> & strm_out);
|
||||||
|
|
||||||
|
#endif
|
142
sources/top_converters/type_strmlen_endian_from_bytes_tb.cpp.in
Normal file
142
sources/top_converters/type_strmlen_endian_from_bytes_tb.cpp.in
Normal file
|
@ -0,0 +1,142 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "top_converters/@TYPE@_@STRMLEN@_@ENDIAN@_from_bytes.hpp"
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
|
#include <cstdio>
|
||||||
|
#include <random>
|
||||||
|
#include <string>
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
using namespace hls;
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
#if @ENDIAN@ == BE
|
||||||
|
|
||||||
|
void bytes2@TYPE@_cpp(const uint8_t * __restrict in, @TYPE@ & out) {
|
||||||
|
constexpr size_t sizeofT = sizeof(@TYPE@);
|
||||||
|
|
||||||
|
@TYPE@ buffer = @TYPE@(0);
|
||||||
|
for (uint8_t byte = 0; byte < sizeofT; byte++) {
|
||||||
|
buffer |= @TYPE@(in[byte]) << ((sizeofT - byte - 1) * 8);
|
||||||
|
}
|
||||||
|
out = buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif @ENDIAN@ == LE
|
||||||
|
|
||||||
|
void bytes2@TYPE@_cpp(const uint8_t * __restrict in, @TYPE@ & out) {
|
||||||
|
constexpr size_t sizeofT = sizeof(@TYPE@);
|
||||||
|
|
||||||
|
@TYPE@ buffer = @TYPE@(0);
|
||||||
|
for (uint8_t byte = 0; byte < sizeofT; byte++) {
|
||||||
|
buffer |= @TYPE@(in[byte]) << (byte * 8);
|
||||||
|
}
|
||||||
|
out = buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
#error "Endianess (currently: @ENDIAN@) can be LE (true) or BE (false)"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
int main(int argc, char * argv[]) {
|
||||||
|
|
||||||
|
constexpr uint64_t rand_seed = 147689;
|
||||||
|
|
||||||
|
mt19937_64 rng(rand_seed);
|
||||||
|
uniform_int_distribution<uint8_t> uniform_dist(numeric_limits<uint8_t>::min(), numeric_limits<uint8_t>::max());
|
||||||
|
|
||||||
|
constexpr uint64_t n_data = uint64_t(1e6f);
|
||||||
|
constexpr size_t sizeofT = sizeof(@TYPE@);
|
||||||
|
constexpr int64_t min_runs = int64_t(1);
|
||||||
|
constexpr int64_t max_runs = int64_t(1e6f / float(@STRMLEN@));
|
||||||
|
|
||||||
|
int64_t n_runs = max_runs;
|
||||||
|
if (argc > 1) {
|
||||||
|
n_runs = std::max(std::min(int64_t(stoi(string(argv[1]))) / int64_t(@STRMLEN@), max_runs), min_runs);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t * data_in = new uint8_t[n_data * sizeofT];
|
||||||
|
@TYPE@ * results = new @TYPE@[n_data];
|
||||||
|
|
||||||
|
hls::stream<uint8_t> strm_in;
|
||||||
|
hls::stream<@TYPE@> strm_out;
|
||||||
|
|
||||||
|
int counted_errors = 0;
|
||||||
|
|
||||||
|
for (int64_t u = 0; u < n_runs; u++) {
|
||||||
|
for (uint64_t v = 0; v < @STRMLEN@; v++) {
|
||||||
|
const uint64_t local_idx = u * @STRMLEN@ + v;
|
||||||
|
for (uint8_t byte = 0; byte < sizeofT; byte++) {
|
||||||
|
data_in[local_idx * sizeofT + byte] = uniform_dist(rng);
|
||||||
|
}
|
||||||
|
|
||||||
|
bytes2@TYPE@_cpp(data_in + local_idx * sizeofT, results[local_idx]);
|
||||||
|
|
||||||
|
for (uint8_t byte = 0; byte < sizeofT; byte++) {
|
||||||
|
strm_in.write(data_in[local_idx * sizeofT + byte]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@TYPE@_@STRMLEN@_@ENDIAN@_from_bytes(strm_in, strm_out);
|
||||||
|
|
||||||
|
for (uint64_t v = 0; v < @STRMLEN@; v++) {
|
||||||
|
const uint64_t local_idx = u * @STRMLEN@ + v;
|
||||||
|
const @TYPE@ processed = strm_out.read();
|
||||||
|
if (results[local_idx] != processed) {
|
||||||
|
counted_errors++;
|
||||||
|
if (counted_errors < 100) {
|
||||||
|
char cformat[128];
|
||||||
|
sprintf(cformat, "0x%%0%1lullx != 0x%%0%1lullx\n", sizeofT * 2, sizeofT * 2);
|
||||||
|
fprintf(stderr, cformat, results[local_idx], processed);
|
||||||
|
} else if (counted_errors == 100) {
|
||||||
|
fprintf(stderr, "Too much errors to be reported on terminal.\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
delete[] data_in;
|
||||||
|
delete[] results;
|
||||||
|
|
||||||
|
printf("RESULTS %s, %d errors for %lu runs.\n", counted_errors == 0 ? "SUCCESS" : "FAILURE", counted_errors, n_runs);
|
||||||
|
|
||||||
|
return counted_errors;
|
||||||
|
}
|
41
sources/top_converters/type_strmlen_endian_to_bytes.cpp.in
Normal file
41
sources/top_converters/type_strmlen_endian_to_bytes.cpp.in
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "top_converters/@TYPE@_@STRMLEN@_@ENDIAN@_to_bytes.hpp"
|
||||||
|
|
||||||
|
void @TYPE@_@STRMLEN@_@ENDIAN@_to_bytes(hls::stream<@TYPE@> & strm_in, hls::stream<uint8_t> & strm_out) {
|
||||||
|
CConverterToBytes<@STRMLEN@, @ENDIAN@>::process(strm_in, strm_out);
|
||||||
|
}
|
49
sources/top_converters/type_strmlen_endian_to_bytes.hpp.in
Normal file
49
sources/top_converters/type_strmlen_endian_to_bytes.hpp.in
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _@TYPE@_@STRMLEN@_@ENDIAN@_TO_BYTES_HPP_
|
||||||
|
#define _@TYPE@_@STRMLEN@_@ENDIAN@_TO_BYTES_HPP_
|
||||||
|
|
||||||
|
#include "CConverter/CConverterToBytes.hpp"
|
||||||
|
|
||||||
|
#if !defined(LE) || !defined(BE) || LE != true || BE != false
|
||||||
|
#define LE true
|
||||||
|
#define BE false
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void @TYPE@_@STRMLEN@_@ENDIAN@_to_bytes(hls::stream<@TYPE@> & strm_in, hls::stream<uint8_t> & strm_out);
|
||||||
|
|
||||||
|
#endif
|
130
sources/top_converters/type_strmlen_endian_to_bytes_tb.cpp.in
Normal file
130
sources/top_converters/type_strmlen_endian_to_bytes_tb.cpp.in
Normal file
|
@ -0,0 +1,130 @@
|
||||||
|
/*
|
||||||
|
* Copyright or © or Copr. Université de Bretagne-Sud, Lab-STICC, Bordeaux-INP, IMS
|
||||||
|
* Contributor(s) : Camille Monière (2022)
|
||||||
|
*
|
||||||
|
* camille.moniere@univ-ubs.fr, camille.moniere@ims-bordeaux.fr
|
||||||
|
*
|
||||||
|
* This software is a computer program whose purpose is to simulate and implement C-type
|
||||||
|
* to bytes FPGA IPs.
|
||||||
|
*
|
||||||
|
* This software is governed by the CeCILL-B license under French law and
|
||||||
|
* abiding by the rules of distribution of free software. You can use,
|
||||||
|
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||||||
|
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||||||
|
* "http://www.cecill.info".
|
||||||
|
*
|
||||||
|
* As a counterpart to the access to the source code and rights to copy,
|
||||||
|
* modify and redistribute granted by the license, users are provided only
|
||||||
|
* with a limited warranty and the software's author, the holder of the
|
||||||
|
* economic rights, and the successive licensors have only limited
|
||||||
|
* liability.
|
||||||
|
*
|
||||||
|
* In this respect, the user's attention is drawn to the risks associated
|
||||||
|
* with loading, using, modifying and/or developing or reproducing the
|
||||||
|
* software by the user in light of its specific status of free software,
|
||||||
|
* that may mean that it is complicated to manipulate, and that also
|
||||||
|
* therefore means that it is reserved for developers and experienced
|
||||||
|
* professionals having in-depth computer knowledge. Users are therefore
|
||||||
|
* encouraged to load and test the software's suitability as regards their
|
||||||
|
* requirements in conditions enabling the security of their systems and/or
|
||||||
|
* data to be ensured and, more generally, to use and operate it in the
|
||||||
|
* same conditions as regards security.
|
||||||
|
*
|
||||||
|
* The fact that you are presently reading this means that you have had
|
||||||
|
* knowledge of the CeCILL-B license and that you accept its terms.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "top_converters/@TYPE@_@STRMLEN@_@ENDIAN@_to_bytes.hpp"
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
|
#include <cstdio>
|
||||||
|
#include <random>
|
||||||
|
#include <string>
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
using namespace hls;
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
#if @ENDIAN@ == BE
|
||||||
|
|
||||||
|
void @TYPE@2bytes_cpp(const @TYPE@ & in, uint8_t * __restrict out) {
|
||||||
|
constexpr size_t sizeofT = sizeof(@TYPE@);
|
||||||
|
for (uint8_t byte = 0; byte < sizeofT; byte++) {
|
||||||
|
out[byte] = uint8_t((in >> ((sizeofT - byte - 1) * 8)) & 0xFF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif @ENDIAN@ == LE
|
||||||
|
|
||||||
|
void @TYPE@2bytes_cpp(const @TYPE@ & in, uint8_t * __restrict out) {
|
||||||
|
constexpr size_t sizeofT = sizeof(@TYPE@);
|
||||||
|
for (uint8_t byte = 0; byte < sizeofT; byte++) {
|
||||||
|
out[byte] = uint8_t((in >> (byte * 8)) & 0xFF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
#error "Endianess (currently: @ENDIAN@) can be LE (true) or BE (false)"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
int main(int argc, char * argv[]) {
|
||||||
|
|
||||||
|
constexpr uint64_t rand_seed = 147689;
|
||||||
|
|
||||||
|
mt19937_64 rng(rand_seed);
|
||||||
|
uniform_int_distribution<@TYPE@> uniform_dist(numeric_limits<@TYPE@>::min(), numeric_limits<@TYPE@>::max());
|
||||||
|
|
||||||
|
constexpr uint64_t n_data = uint64_t(1e6f);
|
||||||
|
constexpr size_t sizeofT = sizeof(@TYPE@);
|
||||||
|
constexpr int64_t min_runs = int64_t(1);
|
||||||
|
constexpr int64_t max_runs = int64_t(1e6f / float(@STRMLEN@));
|
||||||
|
|
||||||
|
int64_t n_runs = max_runs;
|
||||||
|
if (argc > 1) {
|
||||||
|
n_runs = std::max(std::min(int64_t(stoi(string(argv[1]))) / int64_t(@STRMLEN@), max_runs), min_runs);
|
||||||
|
}
|
||||||
|
|
||||||
|
@TYPE@ * data_in = new @TYPE@[n_data];
|
||||||
|
uint8_t * results = new uint8_t[n_data * sizeofT];
|
||||||
|
|
||||||
|
hls::stream<@TYPE@> strm_in;
|
||||||
|
hls::stream<uint8_t> strm_out;
|
||||||
|
|
||||||
|
int counted_errors = 0;
|
||||||
|
|
||||||
|
for (int64_t u = 0; u < n_runs; u++) {
|
||||||
|
for (uint64_t v = 0; v < @STRMLEN@; v++) {
|
||||||
|
const uint64_t local_idx = u * @STRMLEN@ + v;
|
||||||
|
data_in[local_idx] = uniform_dist(rng);
|
||||||
|
@TYPE@2bytes_cpp(data_in[local_idx], results + local_idx * sizeofT);
|
||||||
|
|
||||||
|
strm_in.write(data_in[local_idx]);
|
||||||
|
}
|
||||||
|
|
||||||
|
@TYPE@_@STRMLEN@_@ENDIAN@_to_bytes(strm_in, strm_out);
|
||||||
|
|
||||||
|
for (uint64_t v = 0; v < @STRMLEN@; v++) {
|
||||||
|
const uint64_t local_idx = u * @STRMLEN@ + v;
|
||||||
|
for (size_t byte = 0; byte < sizeofT; byte++) {
|
||||||
|
const uint8_t processed = strm_out.read();
|
||||||
|
if (results[local_idx * (sizeofT) + byte] != processed) {
|
||||||
|
counted_errors++;
|
||||||
|
if (counted_errors < 100) {
|
||||||
|
fprintf(stderr, "0x%02x != 0x%02x\n", (uint16_t) results[local_idx * (sizeofT) + byte], (uint16_t) processed);
|
||||||
|
} else if (counted_errors == 100) {
|
||||||
|
fprintf(stderr, "Too much errors to be reported on terminal.\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
delete[] data_in;
|
||||||
|
delete[] results;
|
||||||
|
|
||||||
|
printf("RESULTS %s, %d errors for %lu runs.\n", counted_errors == 0 ? "SUCCESS" : "FAILURE", counted_errors, n_runs);
|
||||||
|
|
||||||
|
return counted_errors;
|
||||||
|
}
|
Loading…
Reference in a new issue