60 Commits

Author SHA1 Message Date
Readon
c5362e161c Merge aef775ddf1 into 3b84555158 2024-02-27 14:44:28 +08:00
Dolu1990
3b84555158 SpinalHDL 1.10.1 2024-02-01 10:35:36 +01:00
Dolu1990
51249d4c6e SpinalHDL 1.10.0 2024-01-04 10:10:33 +01:00
Dolu1990
17607424ab Merge pull request #36 from IanBoyanZhang/patch-1
Fix typo in README
2023-11-06 11:46:07 +01:00
Ian Zhang
f3256ed4e1 Fix typo in README 2023-11-04 16:35:54 -07:00
Dolu1990
766b80b3f1 SpinalHDL 1.9.4 2023-11-01 09:41:06 +01:00
Dolu1990
f47ac2f65f SpinalHDL 1.9.3 2023-08-16 10:01:33 +02:00
Dolu1990
9fe5ded40a SpinalHDL 1.9.0 for build.sc too <3 2023-07-21 17:46:38 +02:00
Dolu1990
2bf3acd857 SpinalHDL 1.9.0 2023-07-21 17:42:13 +02:00
Yindong Xiao
aef775ddf1 fix missing command of git clone. 2023-04-16 00:52:24 +08:00
Yindong Xiao
a6773349ee use mill the same version as spinalhdl. 2023-04-16 00:49:05 +08:00
Yindong Xiao
9094b6ce2a generate images that support template compiling. 2023-04-16 00:48:40 +08:00
Dolu1990
a4eb1e65ef SpinalHDL 1.8.1 2023-03-27 09:57:17 +02:00
Dolu1990
88fb4a7f49 SpinalHDL 1.8.0 2022-12-05 20:26:59 +01:00
Dolu1990
950e9c2c72 Merge pull request #27 from SpinalHDL/25-readme-pointing-to-getting-started-from-rtd
Readme pointing to Getting started from RTD
2022-11-30 18:39:16 +01:00
Côme
dd76ac14f7 Update README.md 2022-11-30 14:45:35 +01:00
Côme
3929e815a5 Add instructions to modify the template 2022-11-30 14:42:49 +01:00
Côme
cb8b3565b9 Readme pointing to Getting started from RTD 2022-11-30 14:17:32 +01:00
Dolu1990
121ba1514d Update README.md 2022-11-28 10:49:19 +01:00
Dolu1990
07a5beaf08 Merge pull request #23 from numero-744/rework-structure
Structure suggestion
2022-11-28 10:47:29 +01:00
Côme ALLART
4849860e14 refactor: simplify project structure 2022-11-25 10:39:48 +01:00
Dolu1990
9ccca0f64a Merge pull request #21 from numero-744/big-update
Big update
2022-11-18 17:58:51 +01:00
Côme ALLART
bbbac09f8f new MyTopLevel -> MyTopLevel() 2022-11-18 00:37:28 +01:00
Côme ALLART
d40940a924 use case class for Component 2022-11-17 23:18:31 +01:00
Côme ALLART
09e7cac187 restore fancy formatting in io 2022-11-16 21:16:23 +01:00
Côme ALLART
a53d219051 add support of scalafmt 2022-11-16 18:36:01 +01:00
Côme ALLART
ed51a92116 big update
- remove not supported anymore procedural syntax for main functions
- use App instead of main
- auto format
- move comments to have more user-friendly access to "run" and "debug"
  button for Apps
- move generators to dedicated new file
2022-11-16 18:32:24 +01:00
Dolu1990
8e8b22f6ec SpinalHDL 1.7.3 2022-09-19 13:29:58 +02:00
Dolu1990
4570b17a29 Merge pull request #17 from numero-744/patch-2
Update scala version to latest maintenance release
2022-08-03 10:23:32 +02:00
Dolu1990
a9de93a481 Update build.sbt 2022-08-03 10:23:18 +02:00
Côme
310df743af Update scala version to latest maintenance release
https://www.scala-lang.org/download/2.12.16.html
2022-07-27 09:52:35 +02:00
Dolu1990
599a1e6daf SpinalHDL 1.7.1 2022-07-11 12:29:06 +02:00
Dolu1990
23f8152f1f Merge pull request #14 from numero-744/patch-1
Update sbt
2022-05-25 10:56:26 +02:00
Côme
3a93d0fe88 Update sbt
The previously chosen version of SBT does not work with JDK18.
2022-05-25 10:27:00 +02:00
Dolu1990
e2c55528af SpinalHDL 1.7.0a 2022-05-09 11:32:08 +02:00
Charles Papon
993e66c242 Update mill spinalhdl version 2022-05-05 10:54:40 +02:00
Dolu1990
1e8a644b8a Add formal comment 2022-04-29 15:26:32 +02:00
Dolu1990
df28313eea SpinalHDL 1.7.0 + formal example 2022-04-29 15:18:33 +02:00
Dolu1990
181684644c SpinalHDL 1.6.4 2022-02-16 14:27:15 +01:00
Dolu1990
884c4a7ca6 SpinalHDL 1.6.2 2022-02-05 12:09:54 +01:00
Dolu1990
16cca3e7ca Merge pull request #11 from name1e5s/master
SpinalHDL 1.6.0
2021-10-13 19:10:32 +01:00
name1e5s
2e50a23fcc SpinalHDL 1.6.0 2021-07-16 20:10:07 +08:00
Dolu1990
5502e4f7f6 update readme 2021-07-09 09:42:47 +02:00
Dolu1990
666dcbba79 SpinalHDL 1.5.0 2021-06-15 15:53:45 +02:00
Dolu1990
9c0aed7c0d Merge pull request #10 from typingArtist/sbt-mill-unification
Sbt mill unification
2021-06-14 19:34:46 +02:00
Matthias Wächter
ef4d9b7db3 reverted Scala to 2.11.12 and sbt to 1.4.7 2021-06-14 17:05:43 +02:00
Matthias Wächter
9b3093e193 add support for Mill 2021-06-14 08:35:22 +02:00
Matthias Wächter
bb5f15798e restructure build.sbt according to latest sbt docs 2021-06-14 07:29:01 +02:00
Matthias Wächter
08d79c6134 Add gitignore for metals 2021-06-14 07:03:42 +02:00
Matthias Wächter
131c6e7654 bump sbt (1.5.3) and Scala (2.12.14) 2021-06-14 06:59:20 +02:00
Dolu1990
e03a66e8f9 Notes about eclipse added #8 2021-04-12 13:05:33 +02:00
Dolu1990
8acbd1d747 update verilator version 2021-04-09 16:25:56 +02:00
Dolu1990
173bbb9bb8 Remove eclipse plugin 2021-04-06 11:32:10 +02:00
Dolu1990
162e9b5c6b Merge pull request #7 from azaparov/patch-1
Fix to correct verilator branch
2021-03-29 12:58:43 +02:00
Alexey Zaparovanny
c7e1834cb4 Fix to correct verilator branch
Update README.md to reflect correct verilator branch for checkout
2021-03-28 13:42:26 -04:00
Dolu1990
754351b8a1 SpinalHDL 1.4.3 2021-02-01 12:33:12 +01:00
Dolu1990
fd7f2b7165 SpinalHDL 1.4.2 2020-10-15 12:41:48 +02:00
Dolu1990
b524ddddd8 cleanup build.sbt 2020-03-09 12:34:41 +01:00
Dolu1990
648d530e4d Merge remote-tracking branch 'origin/compiler_plugin' 2020-03-09 12:25:15 +01:00
Dolu1990
4f93c929d4 sbt 1.3.3 for windows compatibility 2020-03-02 19:41:14 +01:00
19 changed files with 270 additions and 216 deletions

10
.github/Dockerfile vendored Normal file
View File

@@ -0,0 +1,10 @@
FROM ghcr.io/readon/spinalhdl:master
ARG JAVA_EXTRA_OPTS="-Xmx2g -Xms2g"
ENV JAVA_OPTS="${JAVA_OPTS} ${JAVA_EXTRA_OPTS}"
RUN git clone https://github.com/SpinalHDL/SpinalTemplateSbt.git && \
cd SpinalTemplateSbt && \
git submodule update --init --recursive && \
sbt compile && \
mill _.compile && \
cd .. && rm -rf SpinalTemplateSbt

43
.github/workflows/docker.yml vendored Normal file
View File

@@ -0,0 +1,43 @@
name: Build and Push Docker Image
on:
push:
branches:
- master
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}
jobs:
build-and-push:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Check out the repo
uses: actions/checkout@v2
- name: Log in to the Container registry
uses: docker/login-action@v1
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Docker meta
id: meta
uses: docker/metadata-action@v4
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
- name: Build and push Docker image
uses: docker/build-push-action@v4
with:
context: .
file: .github/Dockerfile
push: true
labels: ${{ steps.meta.outputs.labels }}
tags: ${{ steps.meta.outputs.tags }}

7
.gitignore vendored
View File

@@ -11,15 +11,21 @@ target
lib_managed/ lib_managed/
src_managed/ src_managed/
project/boot/ project/boot/
project/project
project/plugins/project/ project/plugins/project/
# Scala-IDE specific # Scala-IDE specific
.scala_dependencies .scala_dependencies
.worksheet .worksheet
.bloop
.idea .idea
out out
# Metals
.metals
project/metals.sbt
# Eclipse # Eclipse
bin/ bin/
.classpath .classpath
@@ -38,3 +44,4 @@ bin/
simWorkspace/ simWorkspace/
tmp/ tmp/
null

1
.mill-version Normal file
View File

@@ -0,0 +1 @@
0.10.9

5
.scalafmt.conf Normal file
View File

@@ -0,0 +1,5 @@
version = 3.6.0
runner.dialect = scala212
align.preset = some
maxColumn = 120
docstrings.wrap = no

169
README.md
View File

@@ -1,108 +1,83 @@
Spinal Base Project # SpinalHDL Base Project
============
This repository is a base SBT project added to help non Scala/SBT native people in their first steps.
Just one important note, you need a java JDK >= 8 This repository is a base project to help Spinal users set-up project without knowledge about Scala and SBT.
On debian :
## If it is your are learning SpinalHDL
You can follow the tutorial on the [Getting Started](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/index.html) page.
More specifically:
* instructions to install tools can be found on the [Install and setup](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/Install%20and%20setup.html#install-and-setup) page
* instructions to get this repository locally are available in the [Create a SpinalHDL project](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/Install%20and%20setup.html#create-a-spinalhdl-project) section.
### TL;DR Things have already been set up in my environment, how do I run things to try SpinalHDL?
Once in the `SpinalTemplateSbt` directory, when tools are installed, the commands below can be run to use `sbt`.
```sh ```sh
sudo add-apt-repository -y ppa:openjdk-r/ppa // To generate the Verilog from the example
sudo apt-get update sbt "runMain projectname.MyTopLevelVerilog"
sudo apt-get install openjdk-8-jdk -y
#To set the default java // To generate the VHDL from the example
sudo update-alternatives --config java sbt "runMain projectname.MyTopLevelVhdl"
sudo update-alternatives --config javac
// To run the testbench
sbt "runMain projectname.MyTopLevelSim"
``` ```
## Basics, without any IDE * The example hardware description is into `hw/spinal/projectname/MyTopLevel.scala`
* The testbench is into `hw/spinal/projectname/MyTopLevelSim.scala`
You need to install SBT When you really start working with SpinalHDL, it is recommended (both for comfort and efficiency) to use an IDE, see the [Getting started](https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Getting%20Started/index.html).
## If you want to create a new project from this template
### Change project name
You might want to change the project name, which is currently `projectname`. To do so (let's say your actual project name is `myproject`; it must be all lowercase with no separators):
* Update `build.sbt` and/or `build.sc` by replacing `projectname` by the name of your project `myproject` (1 occurrence in each file). The better is to replace in both (it will always work), but in some contexts you can keep only one of these two files:
* If you are sure all people only use `sbt`, you can replace only in `build.sbt` and remove `build.sc`
* If you are sure all people only use `mill`, you can replace only in `build.sc` and remove `build.sbt`
* Replace in both files for open-source project.
* Put all your scala files into `hw/spinal/myproject/` (remove the unused `hw/spinal/projectname/` folder)
* Start all your scala files with `package myproject`
### Change project structure
You can change the project structure as you want. The only restrictions (from Scala environment) are (let's say your actual project name is `myproject`):
* you must have a `myproject` folder and files in it must start with `package myproject`
* if you have a file in a subfolder `myproject/somepackage/MyElement.scala` it must start with `package myproject.somepackage`.
* `sbt` and `mill` must be run right in the folder containing their configurations (recommended to not move these files)
Once the project structure is modified, update configurations:
* In `build.sbt` and/or `build.sc` (see above) replace `/ "hw" / "spinal"` by the new path to the folder containing the `myproject` folder.
* In the spinal configuration file (if you kept it, by default it is in `projectname/Config.scala`) change the path in `targetDirectory = "hw/gen"` to the directory where you want generated files to be written. If you don't use a config or if it doesn't contain this element, generated files will be written in the root directory.
### Update this README
Of course you can replace/modify this file to help people with your own project!
## Mill Support (Experimental)
The [Mill build tool](https://com-lihaoyi.github.io/mill) can be installed and used instead of `sbt`.
```sh ```sh
echo "deb https://dl.bintray.com/sbt/debian /" | sudo tee -a /etc/apt/sources.list.d/sbt.list // To generate the Verilog from the example
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2EE0EA64E40A89B84B2DF73499E82A75642AC823 mill projectname.runMain projectname.MyTopLevelVerilog
sudo apt-get update
sudo apt-get install sbt // To generate the VHDL from the example
mill projectname.runMain projectname.MyTopLevelVhdl
// To run the testbench
mill projectname.runMain projectname.MyTopLevelSim
``` ```
If you want to run the scala written testbench, you have to be on linux and have Verilator installed (a recent version) :
```sh
sudo apt-get install git make autoconf g++ flex bison -y # First time prerequisites
git clone http://git.veripool.org/git/verilator # Only first time
unsetenv VERILATOR_ROOT # For csh; ignore error if on bash
unset VERILATOR_ROOT # For bash
cd verilator
git pull # Make sure we're up-to-date
git checkout verilator_3_916
autoconf # Create ./configure script
./configure
make -j$(nproc)
sudo make install
cd ..
echo "DONE"
```
Clone or download this repository.
```sh
git clone https://github.com/SpinalHDL/SpinalTemplateSbt.git
```
Open a terminal in the root of it and run "sbt run". At the first execution, the process could take some seconds
```sh
cd SpinalTemplateSbt
//If you want to generate the Verilog of your design
sbt "runMain mylib.MyTopLevelVerilog"
//If you want to generate the VHDL of your design
sbt "runMain mylib.MyTopLevelVhdl"
//If you want to run the scala written testbench
sbt "runMain mylib.MyTopLevelSim"
```
The top level spinal code is defined into src\main\scala\mylib
## Basics, with Intellij IDEA and its scala plugin
You need to install :
- Java JDK 8
- SBT
- Intellij IDEA (the free Community Edition is good enough)
- Intellij IDEA Scala plugin (when you run Intellij IDEA the first time, he will ask you about it)
And do the following :
- Clone or download this repository.
- In Intellij IDEA, "import project" with the root of this repository, Import project from external model SBT
- In addition maybe you need to specify some path like JDK to Intellij
- In the project (Intellij project GUI), go in src/main/scala/mylib/MyTopLevel.scala, right click on MyTopLevelVerilog, "Run MyTopLevelVerilog"
Normally, this must generate an MyTopLevel.v output files.
## Basics, with Eclipse and its scala plugin
You need to install :
- Java JDK
- Scala
- SBT
- Eclipse (tested with Mars.2 - 4.5.2)
- [scala plugin](http://scala-ide.org/) (tested with 4.4.1)
And do the following :
- Clone or download this repository.
- Run ```sbt eclipse``` in the ```SpinalTemplateSbt``` directory.
- Import the eclipse project from eclipse.
- In the project (eclipse project GUI), right click on src/main/scala/mylib/MyTopLevel.scala, right click on MyTopLevelVerilog, and select run it
Normally, this must generate output file ```MyTopLevel.v```.

View File

@@ -1,15 +1,16 @@
name := "SpinalTemplateSbt" ThisBuild / version := "1.0"
ThisBuild / scalaVersion := "2.12.18"
ThisBuild / organization := "org.example"
version := "1.0" val spinalVersion = "1.10.1"
val spinalCore = "com.github.spinalhdl" %% "spinalhdl-core" % spinalVersion
val spinalLib = "com.github.spinalhdl" %% "spinalhdl-lib" % spinalVersion
val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl-plugin" % spinalVersion)
scalaVersion := "2.11.12" lazy val projectname = (project in file("."))
.settings(
EclipseKeys.withSource := true Compile / scalaSource := baseDirectory.value / "hw" / "spinal",
libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin)
libraryDependencies ++= Seq( )
"com.github.spinalhdl" % "spinalhdl-core_2.11" % "1.4.0",
"com.github.spinalhdl" % "spinalhdl-lib_2.11" % "1.4.0",
compilerPlugin("com.github.spinalhdl" % "spinalhdl-idsl-plugin_2.11" % "1.4.0")
)
fork := true fork := true

16
build.sc Normal file
View File

@@ -0,0 +1,16 @@
import mill._, scalalib._
val spinalVersion = "1.10.1"
object projectname extends SbtModule {
def scalaVersion = "2.12.18"
override def millSourcePath = os.pwd
def sources = T.sources(
millSourcePath / "hw" / "spinal"
)
def ivyDeps = Agg(
ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion",
ivy"com.github.spinalhdl::spinalhdl-lib:$spinalVersion"
)
def scalacPluginIvyDeps = Agg(ivy"com.github.spinalhdl::spinalhdl-idsl-plugin:$spinalVersion")
}

1
hw/gen/.gitignore vendored Normal file
View File

@@ -0,0 +1 @@
*

View File

@@ -0,0 +1,16 @@
package projectname
import spinal.core._
import spinal.core.sim._
object Config {
def spinal = SpinalConfig(
targetDirectory = "hw/gen",
defaultConfigForClockDomains = ClockDomainConfig(
resetActiveLevel = HIGH
),
onlyStdLogicVectorAtTopLevelIo = true
)
def sim = SimConfig.withConfig(spinal).withFstWave
}

View File

@@ -0,0 +1,30 @@
package projectname
import spinal.core._
// Hardware definition
case class MyTopLevel() extends Component {
val io = new Bundle {
val cond0 = in Bool()
val cond1 = in Bool()
val flag = out Bool()
val state = out UInt(8 bits)
}
val counter = Reg(UInt(8 bits)) init 0
when(io.cond0) {
counter := counter + 1
}
io.state := counter
io.flag := (counter === 0) | io.cond1
}
object MyTopLevelVerilog extends App {
Config.spinal.generateVerilog(MyTopLevel())
}
object MyTopLevelVhdl extends App {
Config.spinal.generateVhdl(MyTopLevel())
}

View File

@@ -0,0 +1,24 @@
package projectname
import spinal.core._
import spinal.core.formal._
// You need SymbiYosys to be installed.
// See https://spinalhdl.github.io/SpinalDoc-RTD/master/SpinalHDL/Formal%20verification/index.html#installing-requirements
object MyTopLevelFormal extends App {
FormalConfig
.withBMC(10)
.doVerify(new Component {
val dut = FormalDut(MyTopLevel())
// Ensure the formal test start with a reset
assumeInitial(clockDomain.isResetActive)
// Provide some stimulus
anyseq(dut.io.cond0)
anyseq(dut.io.cond1)
// Check the state initial value and increment
assert(dut.io.state === past(dut.io.state + U(dut.io.cond0)).init(0))
})
}

View File

@@ -0,0 +1,31 @@
package projectname
import spinal.core._
import spinal.core.sim._
object MyTopLevelSim extends App {
Config.sim.compile(MyTopLevel()).doSim { dut =>
// Fork a process to generate the reset and the clock on the dut
dut.clockDomain.forkStimulus(period = 10)
var modelState = 0
for (idx <- 0 to 99) {
// Drive the dut inputs with random values
dut.io.cond0.randomize()
dut.io.cond1.randomize()
// Wait a rising edge on the clock
dut.clockDomain.waitRisingEdge()
// Check that the dut values match with the reference model ones
val modelFlag = modelState == 0 || dut.io.cond1.toBoolean
assert(dut.io.state.toInt == modelState)
assert(dut.io.flag.toBoolean == modelFlag)
// Update the reference model value
if (dut.io.cond0.toBoolean) {
modelState = (modelState + 1) & 0xff
}
}
}
}

0
hw/verilog/.gitignore vendored Normal file
View File

0
hw/vhdl/.gitignore vendored Normal file
View File

View File

@@ -1 +1 @@
sbt.version=1.2.7 sbt.version=1.6.0

View File

@@ -1,2 +1 @@
addSbtPlugin("com.typesafe.sbteclipse" % "sbteclipse-plugin" % "5.2.4") addSbtPlugin("org.scalameta" % "sbt-scalafmt" % "2.4.6")

View File

@@ -1,67 +0,0 @@
/*
* SpinalHDL
* Copyright (c) Dolu, All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3.0 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library.
*/
package mylib
import spinal.core._
import spinal.lib._
import scala.util.Random
//Hardware definition
class MyTopLevel extends Component {
val io = new Bundle {
val cond0 = in Bool
val cond1 = in Bool
val flag = out Bool
val state = out UInt(8 bits)
}
val counter = Reg(UInt(8 bits)) init(0)
when(io.cond0){
counter := counter + 1
}
io.state := counter
io.flag := (counter === 0) | io.cond1
}
//Generate the MyTopLevel's Verilog
object MyTopLevelVerilog {
def main(args: Array[String]) {
SpinalVerilog(new MyTopLevel)
}
}
//Generate the MyTopLevel's VHDL
object MyTopLevelVhdl {
def main(args: Array[String]) {
SpinalVhdl(new MyTopLevel)
}
}
//Define a custom SpinalHDL configuration with synchronous reset instead of the default asynchronous one. This configuration can be resued everywhere
object MySpinalConfig extends SpinalConfig(defaultConfigForClockDomains = ClockDomainConfig(resetKind = SYNC))
//Generate the MyTopLevel's Verilog using the above custom configuration.
object MyTopLevelVerilogWithCustomConfig {
def main(args: Array[String]) {
MySpinalConfig.generateVerilog(new MyTopLevel)
}
}

View File

@@ -1,38 +0,0 @@
package mylib
import spinal.core._
import spinal.sim._
import spinal.core.sim._
import scala.util.Random
//MyTopLevel's testbench
object MyTopLevelSim {
def main(args: Array[String]) {
SimConfig.withWave.doSim(new MyTopLevel){dut =>
//Fork a process to generate the reset and the clock on the dut
dut.clockDomain.forkStimulus(period = 10)
var modelState = 0
for(idx <- 0 to 99){
//Drive the dut inputs with random values
dut.io.cond0 #= Random.nextBoolean()
dut.io.cond1 #= Random.nextBoolean()
//Wait a rising edge on the clock
dut.clockDomain.waitRisingEdge()
//Check that the dut values match with the reference model ones
val modelFlag = modelState == 0 || dut.io.cond1.toBoolean
assert(dut.io.state.toInt == modelState)
assert(dut.io.flag.toBoolean == modelFlag)
//Update the reference model value
if(dut.io.cond0.toBoolean) {
modelState = (modelState + 1) & 0xFF
}
}
}
}
}