EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
转——切换NIOS II CPU的主内存后软件中需要注意的几点设置 9 @% [# L9 |- R$ S0 t7 D) O4 \: v( A" U
. i( G, E3 {" t8 }! z& L0 R3 K有时候,我们可能面对这样一种情况:6 f8 o* k) \/ W$ F# @! h1 t1 c
1. 我们创建一个SOPC系统,并在QSYS中设置NIOS II的复位地址和异常地址都指向SRAM;
1 P6 h7 p( R$ d& h& t4 @1 ~2. 我们创建了正确的NIOS II软件工程并能够正常运行, i# K8 p" Z" P3 a# V, x
3. 由于某种需求(如SRAM内存不够用了,需要换成内存更大的SDRAM),我们在面在QSYS中将NIOS II CPU的复位地址和异常地址修改为SDRAM3 F r6 x0 t, ~8 Y: U) o
4. 我们需要继续使用之前创建的NIOS II软件工程。
+ [% z9 s$ I. d! m& u4 e* X这里,如果我们更改后直接使用原来的软件工程,则编译会报错,因此我们需要在BSP editor中重新映射各个数据段的分配,然后重新generate BSP,否则将导致固件无法烧写或者烧写后程序无法运行。
% s2 s, }; s* D2 ^例如,在芯航线FPGA开发套件提供的NIOS II教程代码中,我们第5个实验和第6个实验分别是在SRAM和SDRAM中运行同样的软件工程(串口驱动设计实验),我们第6个实验的QSYS系统是直接在第5个实验的基础上增加了SDRAM,并将NIOS II CPU的复位地址和异常地址由SRAM切换为了SDRAM。这时候,如果我们直接打开之前的NIOS II软件工程,编译会报错。(这里默认用户已经知道并在settings.bsp文件中更改了bsp工程路径,如果不知道怎么更改的,请参看我的博文:)/ o( V: Q. M2 [) s
我们检查下这个时候的bsp设置:【选中UART_hal_bsp工程】,【单击右键选择Nios II】,【在子菜单中选择BSP Editor】,如下图所示: T$ s0 J8 E+ o
( M8 e H' E8 q" r p
0 o' O/ b& e, \& A ~- J6 b) @在弹出的界面中,切换到【Linker Script】选项卡,可以看到,各个数据段都还是指向了SRAM,很显然这是不对的,因此我们点击【Restore defaults】按钮。在弹出的对话框中点击OK即可。
m& n2 @# P' T9 M9 k2 g" ~. Y5 D/ ~
$ {$ K( g/ n5 \5 o1 z然后这些数据段的位置就全部更新到SDRAM中了。如下图所示: @/ N8 x9 e5 `/ Y9 |; `2 ]
$ A/ ~5 e' L& M
, j4 s6 X& |+ g# o- V6 z' r! k
这个时候我们再点击右下角的generate按钮,就可以重新生成bsp,然后再编译工程,下载就能够通过,而且正确运行了。
- V, O o/ {9 \' n
% J. e- q& r H% O6 n3 M2 U |