详细介绍如何在linux中配置chisel环境
一、安装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
文件中添加库依赖并指定好版本,使指定版本的chisel
和firrtl
等一些所需文件自动下载; - 第二种是单独下载安装
chisel
、firrtl
和treadle
,然后导出到~/.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
文件,这样才能开始下载chisel
和firrtl
。
你会发现,下载的东西存在了家目录的如下路径中:
继续查看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环境相关推荐
- 如何在Linux中配置JDK环境变量
如何在Linux中配置JDK环境变量 目录 如何在Linux中配置JDK环境变量 一.下载JDK 二.配置环境变量 三.刷新配置 一.下载JDK Java Downloads | Oracle 得到安 ...
- linux如何配置网络设置_如何在Linux中配置网络
linux如何配置网络设置 将Linux计算机连接到网络非常简单,除非不是这样. 在本文中,我讨论了基于Red Hat的Linux发行版的主要网络配置文件,并介绍了两个网络启动服务:古老的网络启动和有 ...
- centos sudo不能运行_如何在 Linux 中配置 sudo 访问权限 | Linux 中国
Linux 系统中 root 用户拥有 Linux 中全部控制权力.Linux 系统中 root 是拥有最高权力的用户,可以在系统中实施任意的行为.-- Magesh Maruthamuthu Lin ...
- centos sudo不能运行_如何在Linux中配置sudo访问权限
Linux 系统中 root 用户拥有 Linux 中全部控制权力.Linux 系统中 root 是拥有最高权力的用户,可以在系统中实施任意的行为. 如果其他用户想去实施一些行为,不能为所有人都提供 ...
- 在linux上运行flutter,Linux中配置Flutter环境
我是在Linux系统下配置Flutter环境的,具体操作步骤如下: 在flutter官网下载Linux 最新版的flutter_sdk,这里我没有下载最新版本的,导致用Android Studio 构 ...
- 如何在linux下配置java环境变量详解
看了很多帖子,只教我们怎么去配置环境变量,没看到有几个帖子先告诉我们这几个环境变量为什么要这样设置.我觉得知道这些变量对应什么,自己配置就比较清晰了. java环境变量的时候,有这几个变量需要配置: ...
- 详细介绍如何在Eclipse中使用SVN
工具/原料 eclipse.svn 一.在Eclipse中下载安装Subclipse插件 1 打开eclipse,在Help菜单中找到marketPlace,点击进入. 2 在搜索框Find中输入su ...
- linux中配置jmeter环境变量,linux java 和jmeter 环境变量配置文件笔记(原)
我在EC2 亚马逊的ubuntu系统下进行的配置,步骤如下(非常简单) 1.在/usr/local下分别新建java和jmeter文件夹,把下载的包进行解压 注:此处有坑,需注意ll -lht 查看 ...
- scala linux 环境配置,scala在linux中配置开发环境
最近朋友想用scala做web项目,个人研究了下,搭建了个scala的研发环境(ubuntu),网上资料很多不准确也比较老,在此做个备忘. 最早是看的哪个网页的忘记了,临时根据https://www. ...
最新文章
- 自行车车把会吧车刮坏吗_花10分钟即可开始使用车把
- R语言进行dataframe数据内连接(Inner join):使用R原生方法、data.table、dplyr等方案
- 当有键盘时如何在开始编辑时使UITextField向上移动?
- 皮一皮:为啥年轻人不生孩子?
- 树型权限管理插件:jQuery Tree Multiselect详细使用指南
- 学会四招让你在linux下安装程序变得简单
- 缓存-分布式锁-缓存一致性解决
- 腾讯游戏使用Microsoft Service Fabric案例
- DevExpress控件使用经验总结
- 25. 合并两个排序的链表
- php 7 pdoexception,关于php:未捕获的异常’PDOException’
- java递归画谢尔宾斯基三角形
- 电商业务中多平台订单与全局库存管理
- 新人做ASO如何快速写好关键词?
- NPOI导出excel设置打印为A4纸张
- 用opencv画一个笑脸的图像
- 微信支付被盗刷?微信:我们全赔!支付宝:我们秒赔!
- Davinci数据可视化-新增图表类型-旭日图
- MS-SQL Server 基础类 - SQL语句
- 萌宠过春节成消费新热点 广西宠物寄养一“窝”难求
热门文章
- 华为鸿蒙系统2021年上市,2021年,华为开始规划自有操作系统“鸿蒙”。
- 【转发】IDM fabless foundry
- delphi源码 中间件 框架【网盘映射】
- LVGL 8.2 meter控件实现模拟时钟
- win7文件权限设置
- 华为鸿蒙os再度升级,华为鸿蒙官网再次更新!多达24款机型可升级鸿蒙OS:赶紧报名升级吧...
- 涂鸦智能股权曝光:王学集持股19.9% 公司市值蒸发超百亿美元
- 涂鸦智能将登陆纽交所:赤字约2亿美元,高管出自阿里,转投腾讯
- 【CAN总线】CAN总线总结
- 使用keytool生成SSL证书