一、安装java和scala

1、安装java

安装java

sudo apt install openjdk-11-jre-headless

安装javac

sudo apt install openjdk-11-jdk-headless

测试是否安装成功:

java --version或javac --version

2、安装scala

1)下载

传送门:https://www.scala-lang.org/download/2.12.12.html

2)解压缩文件包,可将其移动至/usr/local/share下:

sudo mv /downloadpath/scala-2.12.12/ /usr/local/share # 下载目录需要按你实际的下载路径

3)修改环境变量,在profile文件的末尾加入下面第二行的内容:

sudo vim /etc/profileexport PATH="$PATH:/usr/local/share/scala-2.12.12/bin"

4)保存退出

先按:esc键
然后按下::wq

5)重启

6)最后测试是否安装成功即可

二、安装sbt

依次执行以下命令:

echo "deb https://repo.scala-sbt.org/scalasbt/debian all main" | sudo tee /etc/apt/sources.list.d/sbt.list
echo "deb https://repo.scala-sbt.org/scalasbt/debian /" | sudo tee /etc/apt/sources.list.d/sbt_old.list
curl -sL "https://keyserver.ubuntu.com/pks/lookup?op=get&search=0x2EE0EA64E40A89B84B2DF73499E82A75642AC823" | sudo apt-key add
sudo apt-get update
sudo apt-get install sbt

有一点需要注意的是,如果安装了sbt,我们其实就不需要安装scala了,也就是前面安装的scala压根就用不到,你可以理解为sbt会自动下载所需版本的scala!!!

三、安装chisel及相关文件

有两种方式:

  • 第一种是通过在工程文件夹下的build.sbt文件中添加库依赖并指定好版本,使指定版本的chiselfirrtl等一些所需文件自动下载;
  • 第二种是单独下载安装chiselfirrtltreadle,然后导出到~/.ivy2/local/edu.berkeley.cs路径下供sbt使用;

1、第一种方式

①先从GitHub上克隆一个chisel-examples文件夹:

git clone https://github.com/schoeberl/chisel-examples.git

可以看到文件夹中有个build.sbt,重点在于修改版本号:

scalaVersion := "2.12.12"scalacOptions := Seq("-deprecation", "-Xsource:2.11")resolvers ++= Seq(Resolver.sonatypeRepo("snapshots"),Resolver.sonatypeRepo("releases")
)// Chisel 3.4
libraryDependencies += "edu.berkeley.cs" %% "chisel3" % "3.4.3"
libraryDependencies += "edu.berkeley.cs" %% "chisel-iotesters" % "1.5.3"
libraryDependencies += "edu.berkeley.cs" %% "chiseltest" % "0.3.3"

你可以合理的修改其中的版本号,来控制自动下载的chisel版本,虽然没有显式配置firrtl,但是firrtl也会同步下载。

关于以上指定的版本号,可以在这里传送门查看,对应起来就好,如下所示:



至于这里库依赖的格式,可以参考:

https://www.scala-sbt.org/1.x/docs/zh-cn/Library-Dependencies.html

②接着在该文件夹下打开终端,执行:

make alu

也可以执行其他命令,这里主要是为了运行sbt命令生成.v文件,这样才能开始下载chiselfirrtl

你会发现,下载的东西存在了家目录的如下路径中:

继续查看chisel3_2.12/3.4.3/下面的文件:

chisel3_2.12-3.4.3.jar文件其实就是以后写chisel程序会使用的chisel3库,如下所示:

chisel3_2.12-3.4.3.pom文件提供了groupId, artifactId 和 version的具体信息,在.sbt文件中写库依赖的时候会用到这几个信息,如下所示:

需要说明的是:

其实你可以理解为在使用sbt编译运行chisel程序,最终生成verilog代码的过程中,sbt会自动在以下路径寻找chisel3库文件和firrtl

/home/alex/.cache/coursier/v1/https/repo1.maven.org/maven2

然后根据build.sbt中的库依赖(比如libraryDependencies += "edu.berkeley.cs")定位到更加具体的如下路径,并在其中寻找所需版本的chisel3库文件和firrtl

/home/alex/.cache/coursier/v1/https/repo1.maven.org/maven2/edu/berkeley/cs

又会根据%% "chisel3" % "3.4.3"找到下图中的文件,也即chisel3库。

因为此时只安装了一个版本的chisel3,当有多个版本的时候,你就需要在build.sbt里正确指定版本号,这样就不会使用其他版本,也不会再下载新版本。所以也就是说,当上述路径下存在了相关文件后,以后就不需要再下载了,除非你又指定了不同的版本,更新或更旧的版本!!!

如果正确下载了以上文件,make alu最后会执行成功,如下所示:

2、第二种方式

首先需要说明的是,接下来将要下载下来的三个包,它们的build.sbt里面的scala版本,至少要保证三者(其实是四者,还有工程文件夹下的build.sbt)的版本号都是2.12.x或者2.13.x。如果有的是2.12.x,有的是2.13.x,可能会报路径错误,你可以自己试试。

之所以会有路径错误,是因为如下图所示:

文件夹的名字中的2.12其实是会随你设置的scala版本的不同变化的,也即如果下面安装的三个包的build.sbt设置的是2.13.x,那么上图中的文件夹的名字里也是2.13

而执行make alu时,如果工程文件夹中的build.sbt设置的是2.12.x,它寻找依赖时会访问比如chisel3_2.12文件夹,不会访问chisel3_2.13文件夹,那么就会找不到。大概是这意思吧,反正我是出错了,所以最好直接设置成同一个版本,应该会好些!!!

如下三张图依次是下载好这三个包后,首先修改后的build.sbt中版本内容:


①安装Firrtl:

git clone https://github.com/freechipsproject/firrtl.git && cd firrtl

克隆完成后,cd命令会把终端路径切换到firrtl文件夹下,在该路径下执行:

pushd firrtl; sbt publishLocal; popd

②安装treadle:

编译完成后,执行测试命令:

git clone https://github.com/chipsalliance/treadle.git && cd treadle

克隆完成后,cd命令会把终端路径切换到treadle文件夹下,在该路径下执行:

pushd treadle; sbt publishLocal; popd

安装chisel3,依次执行如下命令:

git clone https://github.com/freechipsproject/chisel3.git && cd chisel3sbt compilesbt publishLocal

如果安装正确,会在~/.ivy2/local/edu.berkeley.cs路径下看到:

完成上面的步骤后,更改一下你的项目工程chisel-examples下的build.sbt中的版本号即可:

scalaVersion := "2.12.12"scalacOptions := Seq("-deprecation", "-Xsource:2.11")resolvers ++= Seq(Resolver.sonatypeRepo("snapshots"),Resolver.sonatypeRepo("releases")
)// Chisel 3.5
libraryDependencies +=  "edu.berkeley.cs" %% "chisel3" % "3.5-SNAPSHOT"
libraryDependencies += "edu.berkeley.cs" %% "chisel-iotesters" % "1.5.3"
libraryDependencies += "edu.berkeley.cs" %% "chiseltest" % "0.3.3"

需要说明的是:

第二种方式直接git下来的firrtl、treadle、chisel,后面都带有-snapshot。比如我写这篇文章的时候,下载的这三个东西的版本分别是:

1.5-SNAPSHOT
1.5-SNAPSHOT
3.5-SNAPSHOT

回忆一下第一种方式下载下来的包,它们的版本就没有-snapshot,比如之前的chisel的版本就是3.4.3。个人认为这里版本号不同的特点非常关键,因为由于两者的版本号明显不同,所以当如下路径:

/home/alex/.cache/coursier/v1/https/repo1.maven.org/maven2/edu/berkeley/cs

和如下路径:

~/.ivy2/local/edu.berkeley.cs

同时存在chisel时,也不会有冲突,因为它们的版本号正如上面所说的,有着明显的不同,所以你只需要在工程目录下的build.sbt文件中指定好chisel的版本号即可,如下所示:

libraryDependencies += "edu.berkeley.cs" %% "chisel3" % "3.5-SNAPSHOT"

你可以理解为sbt看到-SNAPSHOT就会去第二个路径下找chisel,否则就去第一个路径下找chisel,而其他包的寻找保持和chisel一致即可,也即总是使用选择的chisel库同路径下的其他包,比如firrtl

四、小结

以上的第三部分内容部分属于自己的猜测,可能不完全对,如有错误,还望指正。会再继续研究研究!!!溜了溜了!!!

详细介绍如何在linux中配置chisel环境相关推荐

  1. 如何在Linux中配置JDK环境变量

    如何在Linux中配置JDK环境变量 目录 如何在Linux中配置JDK环境变量 一.下载JDK 二.配置环境变量 三.刷新配置 一.下载JDK Java Downloads | Oracle 得到安 ...

  2. linux如何配置网络设置_如何在Linux中配置网络

    linux如何配置网络设置 将Linux计算机连接到网络非常简单,除非不是这样. 在本文中,我讨论了基于Red Hat的Linux发行版的主要网络配置文件,并介绍了两个网络启动服务:古老的网络启动和有 ...

  3. centos sudo不能运行_如何在 Linux 中配置 sudo 访问权限 | Linux 中国

    Linux 系统中 root 用户拥有 Linux 中全部控制权力.Linux 系统中 root 是拥有最高权力的用户,可以在系统中实施任意的行为.-- Magesh Maruthamuthu Lin ...

  4. centos sudo不能运行_如何在Linux中配置sudo访问权限

    Linux 系统中 root 用户拥有 Linux 中全部控制权力.Linux 系统中 root 是拥有最高权力的用户,可以在系统中实施任意的行为. 如果其他用户想去实施一些行为,不能为所有人都提供 ...

  5. 在linux上运行flutter,Linux中配置Flutter环境

    我是在Linux系统下配置Flutter环境的,具体操作步骤如下: 在flutter官网下载Linux 最新版的flutter_sdk,这里我没有下载最新版本的,导致用Android Studio 构 ...

  6. 如何在linux下配置java环境变量详解

    看了很多帖子,只教我们怎么去配置环境变量,没看到有几个帖子先告诉我们这几个环境变量为什么要这样设置.我觉得知道这些变量对应什么,自己配置就比较清晰了. java环境变量的时候,有这几个变量需要配置: ...

  7. 详细介绍如何在Eclipse中使用SVN

    工具/原料 eclipse.svn 一.在Eclipse中下载安装Subclipse插件 1 打开eclipse,在Help菜单中找到marketPlace,点击进入. 2 在搜索框Find中输入su ...

  8. linux中配置jmeter环境变量,linux java 和jmeter 环境变量配置文件笔记(原)

    我在EC2 亚马逊的ubuntu系统下进行的配置,步骤如下(非常简单) 1.在/usr/local下分别新建java和jmeter文件夹,把下载的包进行解压 注:此处有坑,需注意ll -lht  查看 ...

  9. scala linux 环境配置,scala在linux中配置开发环境

    最近朋友想用scala做web项目,个人研究了下,搭建了个scala的研发环境(ubuntu),网上资料很多不准确也比较老,在此做个备忘. 最早是看的哪个网页的忘记了,临时根据https://www. ...

最新文章

  1. 自行车车把会吧车刮坏吗_花10分钟即可开始使用车把
  2. R语言进行dataframe数据内连接(Inner join):使用R原生方法、data.table、dplyr等方案
  3. 当有键盘时如何在开始编辑时使UITextField向上移动?
  4. 皮一皮:为啥年轻人不生孩子?
  5. 树型权限管理插件:jQuery Tree Multiselect详细使用指南
  6. 学会四招让你在linux下安装程序变得简单
  7. 缓存-分布式锁-缓存一致性解决
  8. 腾讯游戏使用Microsoft Service Fabric案例
  9. DevExpress控件使用经验总结
  10. 25. 合并两个排序的链表
  11. php 7 pdoexception,关于php:未捕获的异常’PDOException’
  12. java递归画谢尔宾斯基三角形
  13. 电商业务中多平台订单与全局库存管理
  14. 新人做ASO如何快速写好关键词?
  15. NPOI导出excel设置打印为A4纸张
  16. 用opencv画一个笑脸的图像
  17. 微信支付被盗刷?微信:我们全赔!支付宝:我们秒赔!
  18. Davinci数据可视化-新增图表类型-旭日图
  19. MS-SQL Server 基础类 - SQL语句
  20. 萌宠过春节成消费新热点 广西宠物寄养一“窝”难求

热门文章

  1. 华为鸿蒙系统2021年上市,2021年,华为开始规划自有操作系统“鸿蒙”。
  2. 【转发】IDM fabless foundry
  3. delphi源码 中间件 框架【网盘映射】
  4. LVGL 8.2 meter控件实现模拟时钟
  5. win7文件权限设置
  6. 华为鸿蒙os再度升级,华为鸿蒙官网再次更新!多达24款机型可升级鸿蒙OS:赶紧报名升级吧...
  7. 涂鸦智能股权曝光:王学集持股19.9% 公司市值蒸发超百亿美元
  8. 涂鸦智能将登陆纽交所:赤字约2亿美元,高管出自阿里,转投腾讯
  9. 【CAN总线】CAN总线总结
  10. 使用keytool生成SSL证书