From 2964080b55c6a1439f16146c9e9b9fda6b0a88f4 Mon Sep 17 00:00:00 2001 From: Marc Emery Date: Thu, 18 Apr 2024 23:18:59 +0200 Subject: [PATCH 1/3] Add doc for History(that, range) --- source/SpinalHDL/Libraries/utils.rst | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/source/SpinalHDL/Libraries/utils.rst b/source/SpinalHDL/Libraries/utils.rst index 95447544a4c..3c7923c97a6 100644 --- a/source/SpinalHDL/Libraries/utils.rst +++ b/source/SpinalHDL/Libraries/utils.rst @@ -89,11 +89,23 @@ State full utilities * - Delay(that: T, cycleCount: Int) - T - Return ``that`` delayed by ``cycleCount`` cycles - * - History(that: T, length: Int[,when : Bool]) - - List[T] + * - | History ( + | that: T, length: Int + | *[*\ , when : Bool\ *][*\ , init : T\ *]* + | ) + - Vec[T] - | Return a Vec of ``length`` elements - | The first element is ``that``\ , the last one is ``that`` delayed by ``length``\ -1\ + | The first element is ``that``\ , the last one is ``that`` delayed by ``length`` - 1 | The internal shift register sample when ``when`` is asserted + * - | History ( + | that: T, range: Range + | *[*\ , when : Bool\ *][*\ , init : T\ *]* + | ) + - Vec[T] + - | Same as ``History(that, length)`` + | but return a Vec of size ``range.length`` + | where the first element is delayed by ``range.low`` + | and the last by ``range.high`` * - BufferCC(input : T) - T - Return the input signal synchronized with the current clock domain by using 2 flip flop From 745b5b9d436e61ab7a9f8d53bda92b1e4056f3a7 Mon Sep 17 00:00:00 2001 From: Marc Emery Date: Fri, 19 Apr 2024 09:25:35 +0200 Subject: [PATCH 2/3] Fix faulty code-block in blackbox doc --- source/SpinalHDL/Structuring/blackbox.rst | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/source/SpinalHDL/Structuring/blackbox.rst b/source/SpinalHDL/Structuring/blackbox.rst index c462bf63e3c..f888356ec3e 100644 --- a/source/SpinalHDL/Structuring/blackbox.rst +++ b/source/SpinalHDL/Structuring/blackbox.rst @@ -183,7 +183,8 @@ By default the ports of the blackbox are considered clock-less, meaning no clock You can also apply the tag to the whole bundle with : .. code-block:: scala - val io = new Bundle{ + + val io = new Bundle { val clk, rst = in Bool() val a = in Bool() val b = out Bool() @@ -193,7 +194,8 @@ You can also apply the tag to the whole bundle with : You can also apply the current clock domain to all the ports using (SpinalHDL 1.10.2): .. code-block:: scala - val io = new Bundle{ + + val io = new Bundle { val clk, rst = in Bool() val a = in Bool() val b = out Bool() From 2448fec249bdcabfa1a1f46479d7a9ac30b27013 Mon Sep 17 00:00:00 2001 From: Marc Emery Date: Fri, 19 Apr 2024 09:34:37 +0200 Subject: [PATCH 3/3] Fix hyperlink duplicate target name warning --- source/SpinalHDL/Getting Started/Install and setup.rst | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/source/SpinalHDL/Getting Started/Install and setup.rst b/source/SpinalHDL/Getting Started/Install and setup.rst index dd1599ba7be..3f091cccd40 100644 --- a/source/SpinalHDL/Getting Started/Install and setup.rst +++ b/source/SpinalHDL/Getting Started/Install and setup.rst @@ -128,7 +128,7 @@ Windows installation .. note:: While a native installation is possible the simpler and currently recommended way is to use WSL on Windows. - If you want to use WSL, install `it `_, a distribution of your choice and + If you want to use WSL, install `it `__, a distribution of your choice and follow the Linux installation instructions. Data in your WSL instance can be accessed from windows under ``\\wsl$``. In case you want to use IntelliJ you'll have to download the Linux version to WSL, if you want to use VSCode then the Windows version can be used to remotely edit in WSL. @@ -147,7 +147,7 @@ In case you want to build the tools yourself have a look at the legacy simulatio .. note:: An All-in-One solution offered by SpinalHDL maintainer `Readon ` is available to install and run SpinalHDL with Verilator simulation and formal verification via SymbiYosys. - Download `it `_ and install the environment anywhere on your disk. + Download `it `__ and install the environment anywhere on your disk. Start the build environment by clicking on the MSYS2-MINGW64 icon in the Start menu and use the MSYS2 default console. An alternative is to use the Windows Terminal or a Tabby-like application and use the startup command ``%MSYS2_ROOT%\msys2_shell.cmd -defterm -here -no-start -mingw64``, where the ``%MSYS2_ROOT%`` is the location of the msys2 installation. It is worth noting that if you want to use it offline, you should carefully select the libraries that the project depends on, otherwise you will need to download the packages manually.