From 2fbef9f98e58ce9045a8384b7033f2d560a1007e Mon Sep 17 00:00:00 2001 From: viv-eth Date: Fri, 1 Nov 2024 11:56:07 +0100 Subject: [PATCH 01/19] [toolchain] Move to LLVM toolchain to support OpenTitan peripherals --- CMakeLists.txt | 4 ++++ cmake/toolchain_llvm.cmake | 2 +- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 1c8404e..e237c3c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -12,6 +12,10 @@ set(CMAKE_C_STANDARD 99) # SCHEREMO: Needed to skip compiler test, which doesn't support baremetal targets set(CMAKE_C_COMPILER_WORKS 1) +set(CMAKE_CXX_STANDARD 11) + +set(CMAKE_EXPORT_COMPILE_COMMANDS TRUE) +set(CMAKE_VERBOSE_MAKEFILE TRUE) set(CMAKE_EXPORT_COMPILE_COMMANDS TRUE) set(CMAKE_VERBOSE_MAKEFILE TRUE) diff --git a/cmake/toolchain_llvm.cmake b/cmake/toolchain_llvm.cmake index 916f7e7..9bea652 100644 --- a/cmake/toolchain_llvm.cmake +++ b/cmake/toolchain_llvm.cmake @@ -20,4 +20,4 @@ set(CMAKE_OBJDUMP ${TOOLCHAIN_DIR}/${LLVM_TAG}-objdump) set(CMAKE_AR ${TOOLCHAIN_DIR}/${LLVM_TAG}-ar) set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} --target=riscv32-unknown-elf") -set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} --target=riscv32-unknown-elf") \ No newline at end of file +set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} --target=riscv32-unknown-elf") From fac4a51fe6ef91e34c1871f621b0a3c616927af2 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Fri, 1 Nov 2024 14:46:59 +0100 Subject: [PATCH 02/19] [drivers] Add OpenTitan as external project to SDK --- cmake/opentitan.cmake | 31 +++++++++++++++++++++++++++++++ drivers/CMakeLists.txt | 7 +++++++ 2 files changed, 38 insertions(+) create mode 100644 cmake/opentitan.cmake diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake new file mode 100644 index 0000000..cb7a958 --- /dev/null +++ b/cmake/opentitan.cmake @@ -0,0 +1,31 @@ +# Copyright 2024 ETH Zurich and University of Bologna. +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +# +# Viviane Potocnik + +include(ExternalProject) + +set(OPENTITAN_DIR ${CMAKE_CURRENT_BINARY_DIR}/../drivers/opentitan) + +# Add OpenTitan as an external project +ExternalProject_Add( + opentitan + GIT_REPOSITORY https://github.com/lowRISC/opentitan.git + GIT_TAG master # Consider specifying a specific tag or commit for stability + UPDATE_COMMAND "" # Disable updates to avoid unexpected changes + CONFIGURE_COMMAND "" # No configure step needed + BUILD_COMMAND "" # No build step needed + INSTALL_COMMAND "" # No install step needed + SOURCE_DIR ${OPENTITAN_DIR} +) + +message(STATUS "OpenTitan added as an external project.") + +add_library(opentitan_lib STATIC IMPORTED GLOBAL) + +set_target_properties(opentitan_lib PROPERTIES + IMPORTED_LOCATION ${OPENTITAN_DIR}/sw/device/lib/libot.a +) + +add_dependencies(opentitan_lib opentitan) diff --git a/drivers/CMakeLists.txt b/drivers/CMakeLists.txt index 4b28bdc..9b85128 100644 --- a/drivers/CMakeLists.txt +++ b/drivers/CMakeLists.txt @@ -2,6 +2,7 @@ # Licensed under the Apache License, Version 2.0, see LICENSE for details. # SPDX-License-Identifier: Apache-2.0 # +# Viviane Potocnik # Philip Wiese # Define mappings for drivers @@ -17,3 +18,9 @@ add_chimera_subdirectories(${TARGET_PLATFORM} "Driver" "${DRIVER_MAPPINGS}") # WIESEP: Export this directory as root include directory for the drivers target_include_directories(runtime_host PUBLIC ${CMAKE_CURRENT_LIST_DIR}) + +# VIVIANEP: Link to the opentitan library +target_link_libraries(runtime + PUBLIC + opentitan_lib +) \ No newline at end of file From 941360af18603d80e362fd044e74bb726390f7eb Mon Sep 17 00:00:00 2001 From: viv-eth Date: Fri, 1 Nov 2024 16:17:05 +0100 Subject: [PATCH 03/19] [drivers] Sparse checkout of OpenTitan sources --- cmake/opentitan.cmake | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index cb7a958..bfecb8b 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -8,11 +8,34 @@ include(ExternalProject) set(OPENTITAN_DIR ${CMAKE_CURRENT_BINARY_DIR}/../drivers/opentitan) +if(EXISTS ${OPENTITAN_DIR}) + file(REMOVE_RECURSE ${OPENTITAN_DIR}) +endif() + +set(SPARSE_CHECKOUT_FILE ${CMAKE_CURRENT_BINARY_DIR}/sparse-checkout) + +set(SPARSE_PATTERNS + "util/*" + "hw/ip/*" + "sw/device/lib/base/*" + "sw/device/lib/base/internal/*" + "sw/device/lib/dif/*" + "sw/device/lib/dif/autogen/*" +) + +file(WRITE ${SPARSE_CHECKOUT_FILE} "") +foreach(PATTERN ${SPARSE_PATTERNS}) + file(APPEND ${SPARSE_CHECKOUT_FILE} "${PATTERN}\n") +endforeach() + # Add OpenTitan as an external project ExternalProject_Add( opentitan - GIT_REPOSITORY https://github.com/lowRISC/opentitan.git - GIT_TAG master # Consider specifying a specific tag or commit for stability + DOWNLOAD_COMMAND + git clone --no-checkout https://github.com/lowRISC/opentitan.git ${OPENTITAN_DIR} + COMMAND git -C ${OPENTITAN_DIR} config core.sparseCheckout true + COMMAND ${CMAKE_COMMAND} -E copy ${SPARSE_CHECKOUT_FILE} ${OPENTITAN_DIR}/.git/info/sparse-checkout + COMMAND git -C ${OPENTITAN_DIR} checkout master UPDATE_COMMAND "" # Disable updates to avoid unexpected changes CONFIGURE_COMMAND "" # No configure step needed BUILD_COMMAND "" # No build step needed From dd00c1916760304787957e35716e46ceea268c04 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Fri, 1 Nov 2024 16:50:23 +0100 Subject: [PATCH 04/19] [drivers] Compile OpenTitan sources into STATIC lib --- cmake/opentitan.cmake | 58 ++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 54 insertions(+), 4 deletions(-) diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index bfecb8b..211a7e9 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -45,10 +45,60 @@ ExternalProject_Add( message(STATUS "OpenTitan added as an external project.") -add_library(opentitan_lib STATIC IMPORTED GLOBAL) +set(OPENTITAN_SW_DIR ${OPENTITAN_DIR}/sw) +set(OPENTITAN_HW_IP_DIR ${OPENTITAN_DIR}/hw/ip) +set(OPENTITAN_UTIL_DIR ${OPENTITAN_DIR}/util) -set_target_properties(opentitan_lib PROPERTIES - IMPORTED_LOCATION ${OPENTITAN_DIR}/sw/device/lib/libot.a +set(REGTOOL_PY ${OPENTITAN_UTIL_DIR}/regtool.py) +set(UART_HJSON ${OPENTITAN_HW_IP_DIR}/uart/data/uart.hjson) +set(UART_REGS_H ${OPENTITAN_SW_DIR}/device/lib/dif/autogen/uart_regs.h) + +add_custom_command( + OUTPUT ${UART_REGS_H} + COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H} + DEPENDS ${REGTOOL_PY} ${UART_HJSON} + COMMENT "Generating uart_regs.h" +) + +add_custom_target( + generate_uart_regs ALL + DEPENDS ${UART_REGS_H} +) + +add_dependencies(generate_uart_regs opentitan) + +ExternalProject_Get_Property(opentitan SOURCE_DIR) + +file(GLOB_RECURSE OPENTITAN_SOURCES + "${OPENTITAN_SW_DIR}/device/lib/base/*.c" + "${OPENTITAN_SW_DIR}/device/lib/dif/*.c" + "${OPENTITAN_SW_DIR}/device/lib/dif/autogen/*.c" + "${OPENTITAN_SW_DIR}/device/lib/runtime/*.c" +) + +list(FILTER OPENTITAN_SOURCES EXCLUDE REGEX ".*crc32.*") +list(FILTER OPENTITAN_SOURCES EXCLUDE REGEX ".*hardened.*") + +message(STATUS "OpenTitan sources collected.") + +add_library(opentitan_lib STATIC ${OPENTITAN_SOURCES}) + +add_dependencies(opentitan_lib opentitan generate_uart_regs) + +target_include_directories(opentitan_lib + PUBLIC + ${OPENTITAN_SW_DIR} + ${OPENTITAN_SW_DIR}/device/lib + ${OPENTITAN_SW_DIR}/device/lib/base + ${OPENTITAN_SW_DIR}/device/lib/base/internal + ${OPENTITAN_SW_DIR}/device/lib/dif + ${OPENTITAN_SW_DIR}/device/lib/dif/autogen +) + +target_link_libraries(opentitan_lib + PUBLIC + runtime ) -add_dependencies(opentitan_lib opentitan) +message(STATUS "OpenTitan library configured.") + From 98f1f640895641cfd1579e97dcaef9d5b0a809e7 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Fri, 29 Nov 2024 12:02:24 +0100 Subject: [PATCH 05/19] [opentitan] Remove superfluous CXX Standard flag --- CMakeLists.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index e237c3c..bb2adbf 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -12,7 +12,6 @@ set(CMAKE_C_STANDARD 99) # SCHEREMO: Needed to skip compiler test, which doesn't support baremetal targets set(CMAKE_C_COMPILER_WORKS 1) -set(CMAKE_CXX_STANDARD 11) set(CMAKE_EXPORT_COMPILE_COMMANDS TRUE) set(CMAKE_VERBOSE_MAKEFILE TRUE) From 6c3b3943afc5f80d9a7847bdbcb1205d40fedf0d Mon Sep 17 00:00:00 2001 From: viv-eth Date: Fri, 29 Nov 2024 12:09:59 +0100 Subject: [PATCH 06/19] [cmake] Remove duplicate lines --- CMakeLists.txt | 6 ------ 1 file changed, 6 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index bb2adbf..1c6f067 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -16,12 +16,6 @@ set(CMAKE_C_COMPILER_WORKS 1) set(CMAKE_EXPORT_COMPILE_COMMANDS TRUE) set(CMAKE_VERBOSE_MAKEFILE TRUE) -set(CMAKE_EXPORT_COMPILE_COMMANDS TRUE) -set(CMAKE_VERBOSE_MAKEFILE TRUE) - -# SCHEREMO: Help most IDE's LSPs find definitions -set(CMAKE_EXPORT_COMPILE_COMMANDS 1) - # SCHEREMO: This toolchain file is only used for test compilation! set(CMAKE_TOOLCHAIN_FILE cmake/toolchain_llvm.cmake) From 97c0487c161c6283ad2ddb13b1dfe1073432ed23 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Tue, 3 Dec 2024 16:10:43 +0100 Subject: [PATCH 07/19] [drivers] Improve OpenTitan Integration and Adjust Build System --- CMakeLists.txt | 2 + cmake/opentitan.cmake | 139 +++++++++++++++++++++++++++++------------- 2 files changed, 98 insertions(+), 43 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 1c6f067..e21eb85 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -40,6 +40,8 @@ else() endif() include(${CMAKE_CURRENT_LIST_DIR}/cmake/Utils.cmake) +# VIVIANEP: Add OpenTitan as an external project +include(${CMAKE_CURRENT_LIST_DIR}/cmake/opentitan.cmake) ################################################################################ # Add subdirectories # diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index 211a7e9..ea82485 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -7,20 +7,24 @@ include(ExternalProject) set(OPENTITAN_DIR ${CMAKE_CURRENT_BINARY_DIR}/../drivers/opentitan) - -if(EXISTS ${OPENTITAN_DIR}) - file(REMOVE_RECURSE ${OPENTITAN_DIR}) -endif() - set(SPARSE_CHECKOUT_FILE ${CMAKE_CURRENT_BINARY_DIR}/sparse-checkout) set(SPARSE_PATTERNS - "util/*" - "hw/ip/*" - "sw/device/lib/base/*" - "sw/device/lib/base/internal/*" - "sw/device/lib/dif/*" - "sw/device/lib/dif/autogen/*" + "util/design/*" + "util/reggen/*" + "util/regtool.py" + "util/version_file.py" + "hw/ip/uart/data/uart.hjson" + "sw/device/lib/base/abs_mmio.c" + "sw/device/lib/base/abs_mmio.h" + "sw/device/lib/base/bitfield.c" + "sw/device/lib/base/bitfield.h" + "sw/device/lib/base/macros.h" + "sw/device/lib/base/math.c" + "sw/device/lib/base/math.h" + "sw/device/lib/base/math_builtins.c" + "sw/device/lib/base/memory.c" + "sw/device/lib/base/memory.h" ) file(WRITE ${SPARSE_CHECKOUT_FILE} "") @@ -28,36 +32,90 @@ foreach(PATTERN ${SPARSE_PATTERNS}) file(APPEND ${SPARSE_CHECKOUT_FILE} "${PATTERN}\n") endforeach() -# Add OpenTitan as an external project +# Clone and set up the OpenTitan repository during configuration +if(NOT EXISTS ${OPENTITAN_DIR}/.git) + message(STATUS "Cloning OpenTitan repository...") + execute_process( + COMMAND git clone --no-checkout https://github.com/lowRISC/opentitan.git ${OPENTITAN_DIR} + RESULT_VARIABLE GIT_CLONE_RESULT + OUTPUT_VARIABLE GIT_CLONE_OUTPUT + ERROR_VARIABLE GIT_CLONE_ERROR + ) + if(NOT GIT_CLONE_RESULT EQUAL 0) + message(FATAL_ERROR "Failed to clone OpenTitan repository: ${GIT_CLONE_ERROR}") + endif() +else() + message(STATUS "OpenTitan repository already exists.") +endif() + +# Configure sparse checkout +message(STATUS "Configuring sparse checkout for OpenTitan...") +execute_process( + COMMAND git -C ${OPENTITAN_DIR} config core.sparseCheckout true + RESULT_VARIABLE GIT_CONFIG_RESULT + OUTPUT_VARIABLE GIT_CONFIG_OUTPUT + ERROR_VARIABLE GIT_CONFIG_ERROR +) +if(NOT GIT_CONFIG_RESULT EQUAL 0) + message(FATAL_ERROR "Failed to configure sparse checkout: ${GIT_CONFIG_ERROR}") +endif() + +file(COPY ${SPARSE_CHECKOUT_FILE} DESTINATION ${OPENTITAN_DIR}/.git/info/) + +# Apply sparse checkout +execute_process( + COMMAND git -C ${OPENTITAN_DIR} read-tree -mu HEAD + RESULT_VARIABLE GIT_READ_TREE_RESULT + OUTPUT_VARIABLE GIT_READ_TREE_OUTPUT + ERROR_VARIABLE GIT_READ_TREE_ERROR +) +if(NOT GIT_READ_TREE_RESULT EQUAL 0) + message(FATAL_ERROR "Failed to apply sparse checkout: ${GIT_READ_TREE_ERROR}") +endif() + +# Checkout the desired branch (e.g., master) +execute_process( + COMMAND git -C ${OPENTITAN_DIR} checkout master + RESULT_VARIABLE GIT_CHECKOUT_RESULT + OUTPUT_VARIABLE GIT_CHECKOUT_OUTPUT + ERROR_VARIABLE GIT_CHECKOUT_ERROR +) +if(NOT GIT_CHECKOUT_RESULT EQUAL 0) + message(FATAL_ERROR "Failed to checkout branch 'master': ${GIT_CHECKOUT_ERROR}") +endif() + +message(STATUS "OpenTitan repository prepared.") + +# Now proceed with adding the external project to manage build steps ExternalProject_Add( - opentitan - DOWNLOAD_COMMAND - git clone --no-checkout https://github.com/lowRISC/opentitan.git ${OPENTITAN_DIR} - COMMAND git -C ${OPENTITAN_DIR} config core.sparseCheckout true - COMMAND ${CMAKE_COMMAND} -E copy ${SPARSE_CHECKOUT_FILE} ${OPENTITAN_DIR}/.git/info/sparse-checkout - COMMAND git -C ${OPENTITAN_DIR} checkout master - UPDATE_COMMAND "" # Disable updates to avoid unexpected changes - CONFIGURE_COMMAND "" # No configure step needed - BUILD_COMMAND "" # No build step needed - INSTALL_COMMAND "" # No install step needed + opentitan_build SOURCE_DIR ${OPENTITAN_DIR} + CONFIGURE_COMMAND "" # No configure step needed + BUILD_COMMAND "" # No build step needed (unless you have specific build steps) + INSTALL_COMMAND "" # No install step needed + BUILD_BYPRODUCTS ${OPENTITAN_DIR}/.git/config ) -message(STATUS "OpenTitan added as an external project.") - +# Define directories for OpenTitan sources set(OPENTITAN_SW_DIR ${OPENTITAN_DIR}/sw) set(OPENTITAN_HW_IP_DIR ${OPENTITAN_DIR}/hw/ip) set(OPENTITAN_UTIL_DIR ${OPENTITAN_DIR}/util) +# Paths for regtool and UART headers set(REGTOOL_PY ${OPENTITAN_UTIL_DIR}/regtool.py) set(UART_HJSON ${OPENTITAN_HW_IP_DIR}/uart/data/uart.hjson) set(UART_REGS_H ${OPENTITAN_SW_DIR}/device/lib/dif/autogen/uart_regs.h) +# Define the output directory +get_filename_component(UART_REGS_DIR ${UART_REGS_H} DIRECTORY) + +# Custom command to generate UART registers header add_custom_command( OUTPUT ${UART_REGS_H} + COMMAND ${CMAKE_COMMAND} -E make_directory ${UART_REGS_DIR} COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H} DEPENDS ${REGTOOL_PY} ${UART_HJSON} - COMMENT "Generating uart_regs.h" + COMMENT "Generating ${UART_REGS_H} with COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H}" ) add_custom_target( @@ -65,34 +123,29 @@ add_custom_target( DEPENDS ${UART_REGS_H} ) -add_dependencies(generate_uart_regs opentitan) +add_dependencies(generate_uart_regs opentitan_build) -ExternalProject_Get_Property(opentitan SOURCE_DIR) - -file(GLOB_RECURSE OPENTITAN_SOURCES - "${OPENTITAN_SW_DIR}/device/lib/base/*.c" - "${OPENTITAN_SW_DIR}/device/lib/dif/*.c" - "${OPENTITAN_SW_DIR}/device/lib/dif/autogen/*.c" - "${OPENTITAN_SW_DIR}/device/lib/runtime/*.c" +# Explicitly list OpenTitan source files +set(OPENTITAN_SOURCES + ${OPENTITAN_SW_DIR}/device/lib/base/abs_mmio.c + ${OPENTITAN_SW_DIR}/device/lib/base/bitfield.c + ${OPENTITAN_SW_DIR}/device/lib/base/math.c + ${OPENTITAN_SW_DIR}/device/lib/base/math_builtins.c + ${OPENTITAN_SW_DIR}/device/lib/base/memory.c ) -list(FILTER OPENTITAN_SOURCES EXCLUDE REGEX ".*crc32.*") -list(FILTER OPENTITAN_SOURCES EXCLUDE REGEX ".*hardened.*") - message(STATUS "OpenTitan sources collected.") +# Create OpenTitan library add_library(opentitan_lib STATIC ${OPENTITAN_SOURCES}) -add_dependencies(opentitan_lib opentitan generate_uart_regs) +# Ensure the library depends on the external project build +add_dependencies(opentitan_lib opentitan_build generate_uart_regs) +# Include directories for OpenTitan library target_include_directories(opentitan_lib PUBLIC - ${OPENTITAN_SW_DIR} - ${OPENTITAN_SW_DIR}/device/lib - ${OPENTITAN_SW_DIR}/device/lib/base - ${OPENTITAN_SW_DIR}/device/lib/base/internal - ${OPENTITAN_SW_DIR}/device/lib/dif - ${OPENTITAN_SW_DIR}/device/lib/dif/autogen + ${OPENTITAN_DIR} ) target_link_libraries(opentitan_lib From 858b0d979b317a0f90a003c3a51738fc8bfbec56 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Tue, 3 Dec 2024 17:07:55 +0100 Subject: [PATCH 08/19] [drivers] Recursively add .c files to OpenTitan sources --- cmake/opentitan.cmake | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index ea82485..096d688 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -125,13 +125,9 @@ add_custom_target( add_dependencies(generate_uart_regs opentitan_build) -# Explicitly list OpenTitan source files -set(OPENTITAN_SOURCES - ${OPENTITAN_SW_DIR}/device/lib/base/abs_mmio.c - ${OPENTITAN_SW_DIR}/device/lib/base/bitfield.c - ${OPENTITAN_SW_DIR}/device/lib/base/math.c - ${OPENTITAN_SW_DIR}/device/lib/base/math_builtins.c - ${OPENTITAN_SW_DIR}/device/lib/base/memory.c +file(GLOB_RECURSE OPENTITAN_SOURCES + LIST_DIRECTORIES false + ${OPENTITAN_SW_DIR}/device/lib/base/*.c ) message(STATUS "OpenTitan sources collected.") From 2c298d96436a9f9b6903a0504fd79a1dd0ae64b9 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Thu, 19 Dec 2024 12:00:31 +0100 Subject: [PATCH 09/19] [drivers] Link OT drivers against host runtime --- cmake/opentitan.cmake | 2 +- drivers/CMakeLists.txt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index 096d688..3ed08b1 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -146,7 +146,7 @@ target_include_directories(opentitan_lib target_link_libraries(opentitan_lib PUBLIC - runtime + runtime_host ) message(STATUS "OpenTitan library configured.") diff --git a/drivers/CMakeLists.txt b/drivers/CMakeLists.txt index 9b85128..7aaf945 100644 --- a/drivers/CMakeLists.txt +++ b/drivers/CMakeLists.txt @@ -20,7 +20,7 @@ add_chimera_subdirectories(${TARGET_PLATFORM} "Driver" "${DRIVER_MAPPINGS}") target_include_directories(runtime_host PUBLIC ${CMAKE_CURRENT_LIST_DIR}) # VIVIANEP: Link to the opentitan library -target_link_libraries(runtime +target_link_libraries(runtime_host PUBLIC opentitan_lib ) \ No newline at end of file From a2974abbae9210e1e3469e1644a73fb1898a2d7b Mon Sep 17 00:00:00 2001 From: viv-eth Date: Thu, 19 Dec 2024 12:24:55 +0100 Subject: [PATCH 10/19] [OT] remove superfluous dependency --- cmake/opentitan.cmake | 5 ----- 1 file changed, 5 deletions(-) diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index 3ed08b1..718a4e4 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -144,10 +144,5 @@ target_include_directories(opentitan_lib ${OPENTITAN_DIR} ) -target_link_libraries(opentitan_lib - PUBLIC - runtime_host -) - message(STATUS "OpenTitan library configured.") From b0f9d161cd9fc14109896b7c707f878231a937ff Mon Sep 17 00:00:00 2001 From: viv-eth Date: Thu, 19 Dec 2024 13:02:47 +0100 Subject: [PATCH 11/19] [OT] Select commit hash on target-level for OT drivers --- CMakeLists.txt | 1 - cmake/opentitan.cmake | 22 ++++++++++------------ targets/chimera-open/CMakeLists.txt | 10 ++++++++++ 3 files changed, 20 insertions(+), 13 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index e21eb85..01e695d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -41,7 +41,6 @@ endif() include(${CMAKE_CURRENT_LIST_DIR}/cmake/Utils.cmake) # VIVIANEP: Add OpenTitan as an external project -include(${CMAKE_CURRENT_LIST_DIR}/cmake/opentitan.cmake) ################################################################################ # Add subdirectories # diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index 718a4e4..2392e02 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -6,9 +6,15 @@ include(ExternalProject) -set(OPENTITAN_DIR ${CMAKE_CURRENT_BINARY_DIR}/../drivers/opentitan) +set(OPENTITAN_DIR ${CMAKE_SOURCE_DIR}/drivers/opentitan) set(SPARSE_CHECKOUT_FILE ${CMAKE_CURRENT_BINARY_DIR}/sparse-checkout) +if(NOT DEFINED OPENTITAN_COMMIT_HASH) + message(FATAL_ERROR "Please set a commit hash in your target.") +endif() + +message(STATUS "[OT Drivers] Using OpenTitan commit hash: ${OPENTITAN_COMMIT_HASH}") + set(SPARSE_PATTERNS "util/design/*" "util/reggen/*" @@ -34,7 +40,6 @@ endforeach() # Clone and set up the OpenTitan repository during configuration if(NOT EXISTS ${OPENTITAN_DIR}/.git) - message(STATUS "Cloning OpenTitan repository...") execute_process( COMMAND git clone --no-checkout https://github.com/lowRISC/opentitan.git ${OPENTITAN_DIR} RESULT_VARIABLE GIT_CLONE_RESULT @@ -45,11 +50,10 @@ if(NOT EXISTS ${OPENTITAN_DIR}/.git) message(FATAL_ERROR "Failed to clone OpenTitan repository: ${GIT_CLONE_ERROR}") endif() else() - message(STATUS "OpenTitan repository already exists.") + message(STATUS "[OT Drivers] OpenTitan repository already exists.") endif() # Configure sparse checkout -message(STATUS "Configuring sparse checkout for OpenTitan...") execute_process( COMMAND git -C ${OPENTITAN_DIR} config core.sparseCheckout true RESULT_VARIABLE GIT_CONFIG_RESULT @@ -75,17 +79,15 @@ endif() # Checkout the desired branch (e.g., master) execute_process( - COMMAND git -C ${OPENTITAN_DIR} checkout master + COMMAND git -C ${OPENTITAN_DIR} checkout ${OPENTITAN_COMMIT_HASH} RESULT_VARIABLE GIT_CHECKOUT_RESULT OUTPUT_VARIABLE GIT_CHECKOUT_OUTPUT ERROR_VARIABLE GIT_CHECKOUT_ERROR ) if(NOT GIT_CHECKOUT_RESULT EQUAL 0) - message(FATAL_ERROR "Failed to checkout branch 'master': ${GIT_CHECKOUT_ERROR}") + message(FATAL_ERROR "Failed to checkout commit ${OPENTITAN_COMMIT_HASH}: ${GIT_CHECKOUT_ERROR}") endif() -message(STATUS "OpenTitan repository prepared.") - # Now proceed with adding the external project to manage build steps ExternalProject_Add( opentitan_build @@ -130,8 +132,6 @@ file(GLOB_RECURSE OPENTITAN_SOURCES ${OPENTITAN_SW_DIR}/device/lib/base/*.c ) -message(STATUS "OpenTitan sources collected.") - # Create OpenTitan library add_library(opentitan_lib STATIC ${OPENTITAN_SOURCES}) @@ -144,5 +144,3 @@ target_include_directories(opentitan_lib ${OPENTITAN_DIR} ) -message(STATUS "OpenTitan library configured.") - diff --git a/targets/chimera-open/CMakeLists.txt b/targets/chimera-open/CMakeLists.txt index 57d4cad..17895df 100644 --- a/targets/chimera-open/CMakeLists.txt +++ b/targets/chimera-open/CMakeLists.txt @@ -9,8 +9,18 @@ ################################################################################ # Host Runtime Library # ################################################################################ + +# VIVIANEP: Select target-specific commit hash of the OT lib +set(TARGET_OPENTITAN_COMMIT_HASH 22168a3d42febfca725b36dd0d1554b68cf5783e) + +set(OPENTITAN_COMMIT_HASH ${TARGET_OPENTITAN_COMMIT_HASH}) + +# VIVIANEP: Add OpenTitan as an external project +include(${CMAKE_SOURCE_DIR}/cmake/opentitan.cmake) + add_library(runtime_host STATIC) + file(GLOB_RECURSE ASM_SOURCES "src/crt0.S" ) From f149ee410ecbad048e7ff0bf8978ec093ce22da2 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Thu, 19 Dec 2024 13:06:51 +0100 Subject: [PATCH 12/19] [cmake] Remove OT drivers from top level --- CMakeLists.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 01e695d..1c6f067 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -40,7 +40,6 @@ else() endif() include(${CMAKE_CURRENT_LIST_DIR}/cmake/Utils.cmake) -# VIVIANEP: Add OpenTitan as an external project ################################################################################ # Add subdirectories # From 57498d6fb76d45ea085edd0c9b169fcee5827698 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Sat, 21 Dec 2024 03:02:45 +0100 Subject: [PATCH 13/19] [drivers] Refactor OT peripherals on driver-level --- cmake/opentitan.cmake | 150 ++++++++++---------------- drivers/CMakeLists.txt | 8 +- drivers/uart_opentitan/CMakeLists.txt | 67 ++++++++++++ targets/chimera-open/CMakeLists.txt | 7 +- 4 files changed, 128 insertions(+), 104 deletions(-) create mode 100644 drivers/uart_opentitan/CMakeLists.txt diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index 2392e02..78febae 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -6,141 +6,105 @@ include(ExternalProject) -set(OPENTITAN_DIR ${CMAKE_SOURCE_DIR}/drivers/opentitan) -set(SPARSE_CHECKOUT_FILE ${CMAKE_CURRENT_BINARY_DIR}/sparse-checkout) - +# ------------------------------------------------------------------------------ +# Validate prerequisites +# ------------------------------------------------------------------------------ if(NOT DEFINED OPENTITAN_COMMIT_HASH) - message(FATAL_ERROR "Please set a commit hash in your target.") + message(FATAL_ERROR "[CHIMERA-SDK] Please set OPENTITAN_COMMIT_HASH in your target.") endif() -message(STATUS "[OT Drivers] Using OpenTitan commit hash: ${OPENTITAN_COMMIT_HASH}") - -set(SPARSE_PATTERNS - "util/design/*" - "util/reggen/*" - "util/regtool.py" - "util/version_file.py" - "hw/ip/uart/data/uart.hjson" - "sw/device/lib/base/abs_mmio.c" - "sw/device/lib/base/abs_mmio.h" - "sw/device/lib/base/bitfield.c" - "sw/device/lib/base/bitfield.h" - "sw/device/lib/base/macros.h" - "sw/device/lib/base/math.c" - "sw/device/lib/base/math.h" - "sw/device/lib/base/math_builtins.c" - "sw/device/lib/base/memory.c" - "sw/device/lib/base/memory.h" -) +if(NOT DEFINED OPENTITAN_SPARSE_PATTERNS) + message(FATAL_ERROR "[CHIMERA-SDK] Please set OPENTITAN_SPARSE_PATTERNS for your target drivers.") +endif() + +if(NOT DEFINED OPENTITAN_DIR) + message(FATAL_ERROR "[CHIMERA-SDK] Please set OPENTITAN_DIR in your target driver.") +endif() -file(WRITE ${SPARSE_CHECKOUT_FILE} "") -foreach(PATTERN ${SPARSE_PATTERNS}) - file(APPEND ${SPARSE_CHECKOUT_FILE} "${PATTERN}\n") +# ------------------------------------------------------------------------------ +# Write sparse checkout file +# ------------------------------------------------------------------------------ +set(SPARSE_CHECKOUT_FILE "${CMAKE_CURRENT_BINARY_DIR}/sparse-checkout") +file(WRITE "${SPARSE_CHECKOUT_FILE}" "") +foreach(PATTERN ${OPENTITAN_SPARSE_PATTERNS}) + file(APPEND "${SPARSE_CHECKOUT_FILE}" "${PATTERN}\n") endforeach() -# Clone and set up the OpenTitan repository during configuration -if(NOT EXISTS ${OPENTITAN_DIR}/.git) +# ------------------------------------------------------------------------------ +# Clone logic +# ------------------------------------------------------------------------------ +if(NOT EXISTS "${OPENTITAN_DIR}/.git") execute_process( - COMMAND git clone --no-checkout https://github.com/lowRISC/opentitan.git ${OPENTITAN_DIR} + COMMAND git clone --no-checkout https://github.com/lowRISC/opentitan.git "${OPENTITAN_DIR}" RESULT_VARIABLE GIT_CLONE_RESULT - OUTPUT_VARIABLE GIT_CLONE_OUTPUT ERROR_VARIABLE GIT_CLONE_ERROR ) if(NOT GIT_CLONE_RESULT EQUAL 0) message(FATAL_ERROR "Failed to clone OpenTitan repository: ${GIT_CLONE_ERROR}") endif() else() - message(STATUS "[OT Drivers] OpenTitan repository already exists.") + message(STATUS "[CHIMERA-SDK] OpenTitan repository already exists at ${OPENTITAN_DIR}") endif() +# ------------------------------------------------------------------------------ # Configure sparse checkout +# ------------------------------------------------------------------------------ execute_process( - COMMAND git -C ${OPENTITAN_DIR} config core.sparseCheckout true + COMMAND git -C "${OPENTITAN_DIR}" config core.sparseCheckout true RESULT_VARIABLE GIT_CONFIG_RESULT OUTPUT_VARIABLE GIT_CONFIG_OUTPUT - ERROR_VARIABLE GIT_CONFIG_ERROR ) + if(NOT GIT_CONFIG_RESULT EQUAL 0) - message(FATAL_ERROR "Failed to configure sparse checkout: ${GIT_CONFIG_ERROR}") + message(FATAL_ERROR "Failed to configure sparse checkout: ${GIT_CONFIG_OUTPUT}") endif() -file(COPY ${SPARSE_CHECKOUT_FILE} DESTINATION ${OPENTITAN_DIR}/.git/info/) +file(COPY "${SPARSE_CHECKOUT_FILE}" DESTINATION "${OPENTITAN_DIR}/.git/info") +# ------------------------------------------------------------------------------ # Apply sparse checkout +# ------------------------------------------------------------------------------ execute_process( - COMMAND git -C ${OPENTITAN_DIR} read-tree -mu HEAD + COMMAND git -C "${OPENTITAN_DIR}" read-tree -mu HEAD RESULT_VARIABLE GIT_READ_TREE_RESULT OUTPUT_VARIABLE GIT_READ_TREE_OUTPUT - ERROR_VARIABLE GIT_READ_TREE_ERROR ) + if(NOT GIT_READ_TREE_RESULT EQUAL 0) - message(FATAL_ERROR "Failed to apply sparse checkout: ${GIT_READ_TREE_ERROR}") + message(FATAL_ERROR "Failed to apply sparse checkout: ${GIT_READ_TREE_OUTPUT}") endif() -# Checkout the desired branch (e.g., master) +# ------------------------------------------------------------------------------ +# Checkout the desired commit hash +# ------------------------------------------------------------------------------ execute_process( - COMMAND git -C ${OPENTITAN_DIR} checkout ${OPENTITAN_COMMIT_HASH} + COMMAND git -C "${OPENTITAN_DIR}" checkout "${OPENTITAN_COMMIT_HASH}" RESULT_VARIABLE GIT_CHECKOUT_RESULT OUTPUT_VARIABLE GIT_CHECKOUT_OUTPUT - ERROR_VARIABLE GIT_CHECKOUT_ERROR ) + if(NOT GIT_CHECKOUT_RESULT EQUAL 0) - message(FATAL_ERROR "Failed to checkout commit ${OPENTITAN_COMMIT_HASH}: ${GIT_CHECKOUT_ERROR}") + message(FATAL_ERROR "Failed to checkout commit ${OPENTITAN_COMMIT_HASH}: ${GIT_CHECKOUT_OUTPUT}") endif() -# Now proceed with adding the external project to manage build steps +# ------------------------------------------------------------------------------ +# Add OpenTitan as an external project +# ------------------------------------------------------------------------------ ExternalProject_Add( - opentitan_build - SOURCE_DIR ${OPENTITAN_DIR} - CONFIGURE_COMMAND "" # No configure step needed - BUILD_COMMAND "" # No build step needed (unless you have specific build steps) - INSTALL_COMMAND "" # No install step needed - BUILD_BYPRODUCTS ${OPENTITAN_DIR}/.git/config + opentitan_build_${OPENTITAN_COMMIT_HASH} + SOURCE_DIR "${OPENTITAN_DIR}" + CONFIGURE_COMMAND "" + BUILD_COMMAND "" + INSTALL_COMMAND "" + BUILD_BYPRODUCTS "${OPENTITAN_DIR}/.git/config" ) -# Define directories for OpenTitan sources -set(OPENTITAN_SW_DIR ${OPENTITAN_DIR}/sw) -set(OPENTITAN_HW_IP_DIR ${OPENTITAN_DIR}/hw/ip) -set(OPENTITAN_UTIL_DIR ${OPENTITAN_DIR}/util) - -# Paths for regtool and UART headers -set(REGTOOL_PY ${OPENTITAN_UTIL_DIR}/regtool.py) -set(UART_HJSON ${OPENTITAN_HW_IP_DIR}/uart/data/uart.hjson) -set(UART_REGS_H ${OPENTITAN_SW_DIR}/device/lib/dif/autogen/uart_regs.h) - -# Define the output directory -get_filename_component(UART_REGS_DIR ${UART_REGS_H} DIRECTORY) - -# Custom command to generate UART registers header -add_custom_command( - OUTPUT ${UART_REGS_H} - COMMAND ${CMAKE_COMMAND} -E make_directory ${UART_REGS_DIR} - COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H} - DEPENDS ${REGTOOL_PY} ${UART_HJSON} - COMMENT "Generating ${UART_REGS_H} with COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H}" -) - -add_custom_target( - generate_uart_regs ALL - DEPENDS ${UART_REGS_H} -) - -add_dependencies(generate_uart_regs opentitan_build) - -file(GLOB_RECURSE OPENTITAN_SOURCES - LIST_DIRECTORIES false - ${OPENTITAN_SW_DIR}/device/lib/base/*.c -) - -# Create OpenTitan library -add_library(opentitan_lib STATIC ${OPENTITAN_SOURCES}) - -# Ensure the library depends on the external project build -add_dependencies(opentitan_lib opentitan_build generate_uart_regs) - -# Include directories for OpenTitan library -target_include_directories(opentitan_lib - PUBLIC - ${OPENTITAN_DIR} +add_custom_target(opentitan_target_${OPENTITAN_COMMIT_HASH} ALL + DEPENDS opentitan_build_${OPENTITAN_COMMIT_HASH} ) +# ------------------------------------------------------------------------------ +# Interface target for other targets to depend on +# ------------------------------------------------------------------------------ +add_library(opentitan_interface_${OPENTITAN_COMMIT_HASH} INTERFACE) +add_dependencies(opentitan_interface_${OPENTITAN_COMMIT_HASH} opentitan_target_${OPENTITAN_COMMIT_HASH}) diff --git a/drivers/CMakeLists.txt b/drivers/CMakeLists.txt index 7aaf945..4b5c67b 100644 --- a/drivers/CMakeLists.txt +++ b/drivers/CMakeLists.txt @@ -8,7 +8,7 @@ # Define mappings for drivers set(DRIVER_MAPPINGS chimera-convolve:cluster - chimera-open:cluster + chimera-open:cluster,uart_${UART_DRIVER_VERSION} chimera-host: ) @@ -18,9 +18,3 @@ add_chimera_subdirectories(${TARGET_PLATFORM} "Driver" "${DRIVER_MAPPINGS}") # WIESEP: Export this directory as root include directory for the drivers target_include_directories(runtime_host PUBLIC ${CMAKE_CURRENT_LIST_DIR}) - -# VIVIANEP: Link to the opentitan library -target_link_libraries(runtime_host - PUBLIC - opentitan_lib -) \ No newline at end of file diff --git a/drivers/uart_opentitan/CMakeLists.txt b/drivers/uart_opentitan/CMakeLists.txt new file mode 100644 index 0000000..5652d50 --- /dev/null +++ b/drivers/uart_opentitan/CMakeLists.txt @@ -0,0 +1,67 @@ +# Copyright 2024 ETH Zurich and University of Bologna. +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +# +# Viviane Potocnik + +# ------------------------------------------------------------------------------ +# Set the variables for the OpenTitan UART driver +# ------------------------------------------------------------------------------ +set(OPENTITAN_DIR "${CMAKE_CURRENT_SOURCE_DIR}/thirdparty/opentitan") +set(OPENTITAN_SPARSE_PATTERNS + "util/design/*" + "util/reggen/*" + "util/regtool.py" + "util/version_file.py" + "hw/ip/uart/data/uart.hjson" + "sw/device/lib/base/abs_mmio.c" + "sw/device/lib/base/abs_mmio.h" + "sw/device/lib/base/bitfield.c" + "sw/device/lib/base/bitfield.h" + "sw/device/lib/base/macros.h" + "sw/device/lib/base/math.c" + "sw/device/lib/base/math.h" + "sw/device/lib/base/math_builtins.c" + "sw/device/lib/base/memory.c" + "sw/device/lib/base/memory.h" +) + +# ------------------------------------------------------------------------------ +# Call the OpenTitan driver setup +# ------------------------------------------------------------------------------ +include(${CMAKE_SOURCE_DIR}/cmake/opentitan.cmake) + +# ------------------------------------------------------------------------------ +# Generate the uart_regs.h header using the OT regtool +# ------------------------------------------------------------------------------ +set(OPENTITAN_SW_DIR "${OPENTITAN_DIR}/sw") +set(OPENTITAN_HW_IP_DIR "${OPENTITAN_DIR}/hw/ip") +set(OPENTITAN_UTIL_DIR "${OPENTITAN_DIR}/util") + +set(REGTOOL_PY "${OPENTITAN_UTIL_DIR}/regtool.py") +set(UART_HJSON "${OPENTITAN_HW_IP_DIR}/uart/data/uart.hjson") +set(UART_REGS_H "${OPENTITAN_SW_DIR}/device/lib/dif/autogen/uart_regs.h") + + +# Define the output directory +get_filename_component(UART_REGS_DIR ${UART_REGS_H} DIRECTORY) + +# Custom command to generate UART registers header +add_custom_command( + OUTPUT ${UART_REGS_H} + COMMAND ${CMAKE_COMMAND} -E make_directory ${UART_REGS_DIR} + COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H} + DEPENDS ${REGTOOL_PY} ${UART_HJSON} + COMMENT "Generating ${UART_REGS_H} with COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H}" +) + +message(STATUS "[REMOVE ME] COMMAND: ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H}") + +# Generate the uart_regs.h header using the OT regtool +add_custom_target( + generate_uart_regs + ALL + DEPENDS "${UART_REGS_H}" +) + +add_dependencies(generate_uart_regs opentitan_interface_${OPENTITAN_COMMIT_HASH}) \ No newline at end of file diff --git a/targets/chimera-open/CMakeLists.txt b/targets/chimera-open/CMakeLists.txt index 17895df..3fd6895 100644 --- a/targets/chimera-open/CMakeLists.txt +++ b/targets/chimera-open/CMakeLists.txt @@ -12,11 +12,10 @@ # VIVIANEP: Select target-specific commit hash of the OT lib set(TARGET_OPENTITAN_COMMIT_HASH 22168a3d42febfca725b36dd0d1554b68cf5783e) +set(OPENTITAN_COMMIT_HASH ${TARGET_OPENTITAN_COMMIT_HASH} CACHE STRING "OpenTitan commit hash") -set(OPENTITAN_COMMIT_HASH ${TARGET_OPENTITAN_COMMIT_HASH}) - -# VIVIANEP: Add OpenTitan as an external project -include(${CMAKE_SOURCE_DIR}/cmake/opentitan.cmake) +# VIVIANEP: Choose driver versions (if applicable) +set(UART_DRIVER_VERSION "opentitan" CACHE STRING "UART driver version") add_library(runtime_host STATIC) From 67598f163114e034226090d53be223bb15e96735 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Sat, 21 Dec 2024 03:04:23 +0100 Subject: [PATCH 14/19] [gitignore] Add all thirdparty folders --- .gitignore | 1 + 1 file changed, 1 insertion(+) diff --git a/.gitignore b/.gitignore index faf318a..7185a46 100644 --- a/.gitignore +++ b/.gitignore @@ -1,6 +1,7 @@ *~ .ninja* **/build/* +drivers/*/thirdparty/ .vscode/settings.json From d4ec327fac290aa5e7e05712e2cdc429979992af Mon Sep 17 00:00:00 2001 From: viv-eth Date: Mon, 23 Dec 2024 04:56:30 +0100 Subject: [PATCH 15/19] [cmake] Switch to CMAKE_C_STANDARD 11 for static assertions --- CMakeLists.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 1c6f067..ed0e5b6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -8,7 +8,8 @@ cmake_minimum_required(VERSION 3.13) -set(CMAKE_C_STANDARD 99) +# set(CMAKE_C_STANDARD 99) +set(CMAKE_C_STANDARD 11) # SCHEREMO: Needed to skip compiler test, which doesn't support baremetal targets set(CMAKE_C_COMPILER_WORKS 1) From 13ca8beaf456f9f764ba679d2cd8ef9b3627e852 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Mon, 23 Dec 2024 04:57:21 +0100 Subject: [PATCH 16/19] [drivers] Enable always build for OT periphs --- cmake/opentitan.cmake | 1 + 1 file changed, 1 insertion(+) diff --git a/cmake/opentitan.cmake b/cmake/opentitan.cmake index 78febae..5a78fe2 100644 --- a/cmake/opentitan.cmake +++ b/cmake/opentitan.cmake @@ -97,6 +97,7 @@ ExternalProject_Add( BUILD_COMMAND "" INSTALL_COMMAND "" BUILD_BYPRODUCTS "${OPENTITAN_DIR}/.git/config" + BUILD_ALWAYS 1 ) add_custom_target(opentitan_target_${OPENTITAN_COMMIT_HASH} ALL From 0489216d4f1c3ba1686f8a6866cdfd4a5304e097 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Mon, 23 Dec 2024 04:58:22 +0100 Subject: [PATCH 17/19] [drivers] Enable UART for host only atm to test HAL and avoid ABI conflicts --- drivers/CMakeLists.txt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/CMakeLists.txt b/drivers/CMakeLists.txt index 4b5c67b..219d355 100644 --- a/drivers/CMakeLists.txt +++ b/drivers/CMakeLists.txt @@ -8,8 +8,8 @@ # Define mappings for drivers set(DRIVER_MAPPINGS chimera-convolve:cluster - chimera-open:cluster,uart_${UART_DRIVER_VERSION} - chimera-host: + chimera-open:cluster + chimera-host:uart_opentitan ) # Call the macro From 48617f43addceecc4c6e8e633c77172e9874d952 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Mon, 23 Dec 2024 05:01:35 +0100 Subject: [PATCH 18/19] [hal] WIP: Integrate picolibc and UART HAL testing --- cmake/picolibc.cmake | 64 +++++++++++++ drivers/uart_opentitan/CMakeLists.txt | 40 +++++++- hal/CMakeLists.txt | 6 ++ hal/inc/device_api.h | 39 ++++---- hal/inc/uart.h | 67 ++++++++++++++ hal/src/uart.c | 91 +++++++++++++++++++ scripts/picolibc-cross-file.txt.in | 19 ++++ targets/chimera-host/CMakeLists.txt | 36 ++++++++ targets/chimera-host/link.ld | 5 + tests/chimera-host/host/CMakeLists.txt | 2 + .../host/uartSimple/CMakeLists.txt | 32 +++++++ .../host/uartSimple/src_host/test_host.c | 23 +++++ 12 files changed, 402 insertions(+), 22 deletions(-) create mode 100644 cmake/picolibc.cmake create mode 100644 hal/inc/uart.h create mode 100644 hal/src/uart.c create mode 100644 scripts/picolibc-cross-file.txt.in create mode 100644 tests/chimera-host/host/uartSimple/CMakeLists.txt create mode 100644 tests/chimera-host/host/uartSimple/src_host/test_host.c diff --git a/cmake/picolibc.cmake b/cmake/picolibc.cmake new file mode 100644 index 0000000..fd7506f --- /dev/null +++ b/cmake/picolibc.cmake @@ -0,0 +1,64 @@ +# Copyright 2024 ETH Zurich and University of Bologna. +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +# +# Viviane Potocnik + +include(ExternalProject) + +message(STATUS "[CHIMERA-SDK] Setting up picolibc for target ${TARGET}") + +foreach(var CROSS_C_COMPILER CROSS_C_COMPILER_ARGS CROSS_AR CROSS_STRIP CROSS_CPU CROSS_CPU_FAMILY CROSS_ENDIAN CROSS_SYSTEM CROSS_C_ARGS CROSS_C_LINK_ARGS) + if(NOT DEFINED ${var}) + message(FATAL_ERROR "[CHIMERA-SDK] Variable ${var} is not set. It must be defined before including picolibc.cmake.") + endif() +endforeach() + +# Prepare Meson arrays +function(prepare_meson_array output_var input_string) + string(REPLACE " " ";" temp_list "${input_string}") + set(formatted_list "") + foreach(item IN LISTS temp_list) + list(APPEND formatted_list "'${item}'") + endforeach() + string(JOIN ", " result ${formatted_list}) + set(${output_var} "${result}" PARENT_SCOPE) +endfunction() + +prepare_meson_array(CROSS_C_COMPILER_ARGS_LIST "${CROSS_C_COMPILER_ARGS}") +prepare_meson_array(CROSS_C_ARGS_LIST "${CROSS_C_ARGS}") +prepare_meson_array(CROSS_C_LINK_ARGS_LIST "${CROSS_C_LINK_ARGS}") + +set(PICOLIBC_SRC_DIR ${CMAKE_BINARY_DIR}/picolibc-src) +set(PICOLIBC_BUILD_DIR ${CMAKE_BINARY_DIR}/picolibc-build-${TARGET}) +set(PICOLIBC_INSTALL_DIR ${CMAKE_BINARY_DIR}/picolibc-install-${TARGET}) +set(PICOLIBC_CROSS_FILE ${CMAKE_BINARY_DIR}/picolibc-cross-file-${TARGET}.txt) + + +# Generate the Meson cross-file +configure_file(${CMAKE_CURRENT_LIST_DIR}/../scripts/picolibc-cross-file.txt.in ${PICOLIBC_CROSS_FILE} @ONLY) + +message(STATUS "[CHIMERA-SDK] Saving cross compilation file to ${PICOLIBC_CROSS_FILE}") +# Add picolibc as an external project +ExternalProject_Add( + picolibc-${TARGET} + GIT_REPOSITORY https://github.com/picolibc/picolibc.git + GIT_TAG main + SOURCE_DIR ${PICOLIBC_SRC_DIR} + BINARY_DIR ${PICOLIBC_BUILD_DIR} + INSTALL_DIR ${PICOLIBC_INSTALL_DIR} + CONFIGURE_COMMAND meson setup ${PICOLIBC_BUILD_DIR} ${PICOLIBC_SRC_DIR} --cross-file ${PICOLIBC_CROSS_FILE} --prefix ${PICOLIBC_INSTALL_DIR} --default-library=static + BUILD_COMMAND ninja -C ${PICOLIBC_BUILD_DIR} + INSTALL_COMMAND ninja -C ${PICOLIBC_BUILD_DIR} install +) + +set(PICOLIBC_INSTALL_DIR ${PICOLIBC_INSTALL_DIR} PARENT_SCOPE) +set(PICOLIBC_TARGET picolibc-${TARGET} PARENT_SCOPE) + +add_library(picolibc STATIC IMPORTED GLOBAL) + +set_target_properties(picolibc PROPERTIES + IMPORTED_LOCATION "${PICOLIBC_INSTALL_DIR}/lib/libc.a" +) + +add_dependencies(picolibc picolibc-${TARGET}) \ No newline at end of file diff --git a/drivers/uart_opentitan/CMakeLists.txt b/drivers/uart_opentitan/CMakeLists.txt index 5652d50..fef3de7 100644 --- a/drivers/uart_opentitan/CMakeLists.txt +++ b/drivers/uart_opentitan/CMakeLists.txt @@ -24,6 +24,18 @@ set(OPENTITAN_SPARSE_PATTERNS "sw/device/lib/base/math_builtins.c" "sw/device/lib/base/memory.c" "sw/device/lib/base/memory.h" + "sw/device/lib/base/mmio.c" + "sw/device/lib/base/mmio.h" + "sw/device/lib/base/multibits.c" + "sw/device/lib/base/multibits.h" + "sw/device/lib/base/internal/status.h" + "sw/device/lib/base/internal/absl_status.h" + "sw/device/lib/dif/dif_base.c" + "sw/device/lib/dif/dif_base.h" + "sw/device/lib/dif/dif_uart.c" + "sw/device/lib/dif/dif_uart.h" + "sw/device/lib/dif/autogen/dif_uart_autogen.c" + "sw/device/lib/dif/autogen/dif_uart_autogen.h" ) # ------------------------------------------------------------------------------ @@ -55,8 +67,6 @@ add_custom_command( COMMENT "Generating ${UART_REGS_H} with COMMAND ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H}" ) -message(STATUS "[REMOVE ME] COMMAND: ${Python3_EXECUTABLE} ${REGTOOL_PY} ${UART_HJSON} -D > ${UART_REGS_H}") - # Generate the uart_regs.h header using the OT regtool add_custom_target( generate_uart_regs @@ -64,4 +74,28 @@ add_custom_target( DEPENDS "${UART_REGS_H}" ) -add_dependencies(generate_uart_regs opentitan_interface_${OPENTITAN_COMMIT_HASH}) \ No newline at end of file +add_dependencies(generate_uart_regs opentitan_interface_${OPENTITAN_COMMIT_HASH}) + +# ------------------------------------------------------------------------------ +# Add the UART driver library +# ------------------------------------------------------------------------------ +add_library(uart_lib STATIC) + +file(GLOB_RECURSE UART_SOURCES + "${OPENTITAN_SW_DIR}/device/lib/base/*.c" + "${OPENTITAN_SW_DIR}/device/lib/dif/*.c" +) + +target_sources( + uart_lib + PRIVATE + ${UART_SOURCES} + ${UART_REGS_H} +) + +target_include_directories( + uart_lib + PUBLIC + ${OPENTITAN_DIR} + ${OPENTITAN_SW_DIR}/device/lib/dif/autogen +) \ No newline at end of file diff --git a/hal/CMakeLists.txt b/hal/CMakeLists.txt index c1c6bf3..35c517a 100644 --- a/hal/CMakeLists.txt +++ b/hal/CMakeLists.txt @@ -14,3 +14,9 @@ target_include_directories(hal_host PUBLIC "inc/" ) + +target_link_libraries(hal_host + PUBLIC + uart_lib + picolibc +) diff --git a/hal/inc/device_api.h b/hal/inc/device_api.h index b7a476d..ecbee28 100644 --- a/hal/inc/device_api.h +++ b/hal/inc/device_api.h @@ -6,12 +6,32 @@ #include #include +#include /** * \addtogroup device * @{ */ +/** + * @brief Device structure. + * + */ +typedef struct chi_device { + /** + * @brief Device API. + */ + struct chi_device_api *api; // function pointers + /** + * @brief Device address. + */ + uint32_t *device_addr; + /** + * @brief Device configuration. + */ + void *cfg; +} chi_device_t; + /** * @brief Callback function for asynchronous device operations. * @@ -59,23 +79,4 @@ typedef struct chi_device_api { chi_device_callback cb); } chi_device_api_t; -/** - * @brief Device structure. - * - */ -typedef struct chi_device { - /** - * @brief Device API. - */ - struct chi_device_api *api; // function pointers - /** - * @brief Device address. - */ - uint32_t *device_addr; - /** - * @brief Device configuration. - */ - void *cfg; -} chi_device_t; - /** @} */ \ No newline at end of file diff --git a/hal/inc/uart.h b/hal/inc/uart.h new file mode 100644 index 0000000..abeb0d0 --- /dev/null +++ b/hal/inc/uart.h @@ -0,0 +1,67 @@ +// Copyright 2024 ETH Zurich and University of Bologna. +// Licensed under the Apache License, Version 2.0, see LICENSE for details. +// SPDX-License-Identifier: Apache-2.0 +// +// Viviane Potcnik + +#ifndef UART_H +#define UART_H + +#include +#include "device_api.h" +#include "sw/device/lib/base/mmio.h" +#include "sw/device/lib/dif/dif_uart.h" +#include "uart_regs.h" +#include +#include + +// Parity options +#define UART_PARITY_NONE 0 +#define UART_PARITY_EVEN 1 +#define UART_PARITY_ODD 2 + +// Default UART configurations (can be overridden via compiler defines) +#ifndef UART_DEFAULT_BAUD_RATE +#define UART_DEFAULT_BAUD_RATE 115200 +#endif + +#ifndef UART_DEFAULT_DATA_BITS +#define UART_DEFAULT_DATA_BITS 8 +#endif + +#ifndef UART_DEFAULT_PARITY +#define UART_DEFAULT_PARITY UART_PARITY_NONE +#endif + +#ifndef UART_DEFAULT_STOP_BITS +#define UART_DEFAULT_STOP_BITS 1 +#endif + +#ifndef UART_CLK_FREQ_HZ +#define UART_CLK_FREQ_HZ 100000000 +#endif + +#ifndef UART_BASE_ADDR +#define UART_BASE_ADDR 0x40000000 +#endif + +// UART configuration structure +typedef struct { + uint32_t baud_rate; + uint32_t clk_freq_hz; + uint8_t data_bits; + uint8_t parity; + uint8_t stop_bits; +} uart_config_t; + +// Function declarations +int uart_open(struct chi_device *device); +int uart_close(struct chi_device *device); +ssize_t uart_read_async(struct chi_device *device, void *buffer, uint32_t size, chi_device_callback cb); +ssize_t uart_write_async(struct chi_device *device, const void *buffer, uint32_t size, chi_device_callback cb); + +// Extern the UART API structure +extern struct chi_device_api uart_api; +extern uart_config_t default_cfg; + +#endif // UART_H \ No newline at end of file diff --git a/hal/src/uart.c b/hal/src/uart.c new file mode 100644 index 0000000..3e9dbf2 --- /dev/null +++ b/hal/src/uart.c @@ -0,0 +1,91 @@ +// Copyright 2024 ETH Zurich and University of Bologna. +// Licensed under the Apache License, Version 2.0, see LICENSE for details. +// SPDX-License-Identifier: Apache-2.0 +// +// Viviane Potcnik + +#include "uart.h" + +// Define the UART API structure +struct chi_device_api uart_api = { + .open = uart_open, + .close = uart_close, + .read_async = uart_read_async, + .write_async = uart_write_async +}; + +// UART context structure +typedef struct uart_context { + dif_uart_t uart; // UART DIF handle + // Asynchronous read state + uint8_t *rx_buffer; + uint32_t rx_size; + uint32_t rx_pos; + chi_device_callback rx_callback; + // Asynchronous write state + const uint8_t *tx_buffer; + uint32_t tx_size; + uint32_t tx_pos; + chi_device_callback tx_callback; +} uart_context_t; + +// Default UART configuration +uart_config_t default_cfg = { + .baud_rate = UART_DEFAULT_BAUD_RATE, + .clk_freq_hz = UART_CLK_FREQ_HZ, + .data_bits = UART_DEFAULT_DATA_BITS, + .parity = UART_DEFAULT_PARITY, + .stop_bits = UART_DEFAULT_STOP_BITS +}; + +int uart_open(struct chi_device *device) { + + // Check if the device and device address are valid + if (device == NULL || device->device_addr == NULL) { + return -1; // Invalid argument + } + + // Initialize the UART context + uart_context_t *ctx = malloc(sizeof(uart_context_t)); + if (ctx == NULL) { + return -2; // Out of memory error + } + memset(ctx, 0, sizeof(uart_context_t)); + + // // If no cfg is provided, use the default configuration + // uart_config_t *cfg = device->cfg; + // if (cfg == NULL) { + // cfg = &default_cfg; + // } + + // free(ctx); // Free the UART context + + return 0; // Success +} + +int uart_close(struct chi_device *device) { + + if (device == NULL || device->cfg == NULL) { + return -1; // Invalid argument + } + + return 0; // Success +} + +ssize_t uart_read_async(struct chi_device *device, void *buffer, uint32_t size, chi_device_callback cb) { + + if (device == NULL || device->cfg == NULL || buffer == NULL || size == 0) { + return -1; // Invalid argument + } + + return size; // Return the number of bytes to be read +} + +ssize_t uart_write_async(struct chi_device *device, const void *buffer, uint32_t size, chi_device_callback cb) { + + if (device == NULL || device->cfg == NULL || buffer == NULL || size == 0) { + return -1; // Invalid argument + } + + return size; // Return the number of bytes to be written +} \ No newline at end of file diff --git a/scripts/picolibc-cross-file.txt.in b/scripts/picolibc-cross-file.txt.in new file mode 100644 index 0000000..5013a0b --- /dev/null +++ b/scripts/picolibc-cross-file.txt.in @@ -0,0 +1,19 @@ +# Copyright 2024 ETH Zurich and University of Bologna. +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 + +[binaries] +c = [ '@CROSS_C_COMPILER@', @CROSS_C_COMPILER_ARGS_LIST@ ] +ar = '@CROSS_AR@' +strip = '@CROSS_STRIP@' + +[host_machine] +system = '@CROSS_SYSTEM@' +cpu_family = '@CROSS_CPU_FAMILY@' +cpu = '@CROSS_CPU@' +endian = '@CROSS_ENDIAN@' + +[properties] +c_args = [ @CROSS_C_ARGS_LIST@ ] +c_link_args = [ @CROSS_C_LINK_ARGS_LIST@ ] +skip_sanity_check = @CROSS_SKIP_SANITY_CHECK@ \ No newline at end of file diff --git a/targets/chimera-host/CMakeLists.txt b/targets/chimera-host/CMakeLists.txt index 1a7cb65..b0a047c 100644 --- a/targets/chimera-host/CMakeLists.txt +++ b/targets/chimera-host/CMakeLists.txt @@ -6,9 +6,39 @@ # Viviane Potocnik # Philip Wiese +################################################################################ +# Set up picolibc +################################################################################ + +set(TARGET "chimera-host") + +set(CROSS_C_COMPILER "clang") +set(CROSS_AR "llvm-ar") +set(CROSS_STRIP "llvm-strip") +set(TARGET_FLAG "riscv32-unknown-elf") + +set(CROSS_CPU "riscv32") +set(CROSS_CPU_FAMILY "riscv32") +set(CROSS_ENDIAN "little") +set(CROSS_SYSTEM "none") + +set(CROSS_C_COMPILER_ARGS "-target ${TARGET_FLAG} -march=${ISA_HOST} -nostdlib") +set(CROSS_C_ARGS "-Werror=double-promotion -Wno-unsupported-floating-point-opt -fshort-enums -mno-relax -march=${ISA_HOST} -mabi=${ABI}") +set(CROSS_C_LINK_ARGS "-Wl,-z,noexecstack -march=${ISA_HOST} -mabi=${ABI}") + +set(CROSS_SKIP_SANITY_CHECK "true") + +include(${CMAKE_CURRENT_LIST_DIR}/../../cmake/picolibc.cmake) + ################################################################################ # Host Runtime Library # ################################################################################ + +# VIVIANEP: Select target-specific commit hash of the OT lib +set(TARGET_OPENTITAN_COMMIT_HASH 22168a3d42febfca725b36dd0d1554b68cf5783e) +set(OPENTITAN_COMMIT_HASH ${TARGET_OPENTITAN_COMMIT_HASH} CACHE STRING "OpenTitan commit hash") + + add_library(runtime_host STATIC) file(GLOB_RECURSE ASM_SOURCES @@ -44,6 +74,12 @@ target_compile_options(runtime_host -mabi=${ABI} ) +# VIVIANEP: Must set s +target_compile_definitions(runtime_host + PUBLIC + -DOT_PLATFORM_RV32=1 +) + # WIESEP: Export the target specific linkerscript target_link_options(runtime_host PUBLIC diff --git a/targets/chimera-host/link.ld b/targets/chimera-host/link.ld index 6dcf16c..1f639e9 100644 --- a/targets/chimera-host/link.ld +++ b/targets/chimera-host/link.ld @@ -39,6 +39,11 @@ SECTIONS { . = ALIGN(32); __bss_end = .; + .heap : ALIGN(16) { + __heap_start = .; + __heap_end = ORIGIN(memisl) + LENGTH(memisl); + } > memisl + .bulk : ALIGN(16) { *(.bulk) *(.bulk.*) diff --git a/tests/chimera-host/host/CMakeLists.txt b/tests/chimera-host/host/CMakeLists.txt index 483cc57..b4e7aad 100644 --- a/tests/chimera-host/host/CMakeLists.txt +++ b/tests/chimera-host/host/CMakeLists.txt @@ -4,5 +4,7 @@ # # Moritz Scherer # Philip Wiese +# Viviane Potocnik add_subdirectory(returnZero) +add_subdirectory(uartSimple) diff --git a/tests/chimera-host/host/uartSimple/CMakeLists.txt b/tests/chimera-host/host/uartSimple/CMakeLists.txt new file mode 100644 index 0000000..20631d6 --- /dev/null +++ b/tests/chimera-host/host/uartSimple/CMakeLists.txt @@ -0,0 +1,32 @@ +# Copyright 2024 ETH Zurich and University of Bologna. +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +# +# Viviane Potocnik + +set(TEST_NAME test_host_uartSimple) + +######## HOST Code ############################################################# +file(GLOB_RECURSE TEST_HOST_SRCS + "src_host/*.c" +) + +add_library(${TEST_NAME}_host OBJECT ${TEST_HOST_SRCS}) +# target_include_directories(${TEST_NAME}_host PUBLIC include) + +# WIESEP: Set the correct ISA and ABI for the host +target_compile_options(${TEST_NAME}_host + PRIVATE + -O2 +) +target_link_libraries(${TEST_NAME}_host PUBLIC runtime_host hal_host) + +######## TEST Executable ####################################################### +add_chimera_test( + ${TEST_NAME} +) + +# WIESEP: Link the host to the test executable +target_link_libraries(${TEST_NAME} PUBLIC ${TEST_NAME}_host) + + diff --git a/tests/chimera-host/host/uartSimple/src_host/test_host.c b/tests/chimera-host/host/uartSimple/src_host/test_host.c new file mode 100644 index 0000000..e2f981a --- /dev/null +++ b/tests/chimera-host/host/uartSimple/src_host/test_host.c @@ -0,0 +1,23 @@ +// Copyright 2024 ETH Zurich and University of Bologna. +// Licensed under the Apache License, Version 2.0, see LICENSE for details. +// SPDX-License-Identifier: Apache-2.0 +// +// Viviane Potcnik + +#include "uart.h" + +int main() +{ + struct chi_device device; + device.api = &uart_api; + device.device_addr = (uint32_t *)0x40000000; + device.cfg = &default_cfg; + + int open_result = device.api->open(&device); + // int close_result = device.api->close(&device); + + // int open_result = 0; + int close_result = 0; + + return open_result + close_result; +} \ No newline at end of file From 6ba0485b59ed7b0d15b2cded3c7f1d5133794ed0 Mon Sep 17 00:00:00 2001 From: viv-eth Date: Mon, 23 Dec 2024 05:02:01 +0100 Subject: [PATCH 19/19] [targets] chimera-open: remove UART_VERSION macro for clarity --- targets/chimera-open/CMakeLists.txt | 2 -- 1 file changed, 2 deletions(-) diff --git a/targets/chimera-open/CMakeLists.txt b/targets/chimera-open/CMakeLists.txt index 3fd6895..c467554 100644 --- a/targets/chimera-open/CMakeLists.txt +++ b/targets/chimera-open/CMakeLists.txt @@ -14,8 +14,6 @@ set(TARGET_OPENTITAN_COMMIT_HASH 22168a3d42febfca725b36dd0d1554b68cf5783e) set(OPENTITAN_COMMIT_HASH ${TARGET_OPENTITAN_COMMIT_HASH} CACHE STRING "OpenTitan commit hash") -# VIVIANEP: Choose driver versions (if applicable) -set(UART_DRIVER_VERSION "opentitan" CACHE STRING "UART driver version") add_library(runtime_host STATIC)