EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
转——切换NIOS II CPU的主内存后软件中需要注意的几点设置
7 @5 \. @6 E9 a, }4 i# v8 E. a
; m. @4 ?, B6 V- R1 f有时候,我们可能面对这样一种情况:
2 a8 T# N# _3 O1. 我们创建一个SOPC系统,并在QSYS中设置NIOS II的复位地址和异常地址都指向SRAM;, ^) t P( H% V$ T/ a
2. 我们创建了正确的NIOS II软件工程并能够正常运行
, w$ e9 w3 ] Z" J ?0 Q3 @6 E3. 由于某种需求(如SRAM内存不够用了,需要换成内存更大的SDRAM),我们在面在QSYS中将NIOS II CPU的复位地址和异常地址修改为SDRAM) ~' U# u: V- p( C! n: ?
4. 我们需要继续使用之前创建的NIOS II软件工程。
, P3 D8 Q; L' P- `4 U/ e- g" ~/ J这里,如果我们更改后直接使用原来的软件工程,则编译会报错,因此我们需要在BSP editor中重新映射各个数据段的分配,然后重新generate BSP,否则将导致固件无法烧写或者烧写后程序无法运行。
% O3 j& |0 N4 X5 L例如,在芯航线FPGA开发套件提供的NIOS II教程代码中,我们第5个实验和第6个实验分别是在SRAM和SDRAM中运行同样的软件工程(串口驱动设计实验),我们第6个实验的QSYS系统是直接在第5个实验的基础上增加了SDRAM,并将NIOS II CPU的复位地址和异常地址由SRAM切换为了SDRAM。这时候,如果我们直接打开之前的NIOS II软件工程,编译会报错。(这里默认用户已经知道并在settings.bsp文件中更改了bsp工程路径,如果不知道怎么更改的,请参看我的博文:)" D* A9 H, o8 ^; U; I
我们检查下这个时候的bsp设置:【选中UART_hal_bsp工程】,【单击右键选择Nios II】,【在子菜单中选择BSP Editor】,如下图所示:; O! l, U% ?) _9 O0 F
% n; c( u4 Q2 S) B
2 E+ I5 G, | G5 \, d: \ [$ E在弹出的界面中,切换到【Linker Script】选项卡,可以看到,各个数据段都还是指向了SRAM,很显然这是不对的,因此我们点击【Restore defaults】按钮。在弹出的对话框中点击OK即可。
8 F' t$ o/ S' p6 r+ T, m" d/ ^% V
7 W- r' n S2 F; a3 I) `; m5 o$ q4 V
! ?! l3 _* l( x; @) U; P" O然后这些数据段的位置就全部更新到SDRAM中了。如下图所示:% Z1 A s/ C' B" H/ u
) V/ K& [) s) T# Y
6 B+ r" `+ V0 q# [. t4 Q) y
这个时候我们再点击右下角的generate按钮,就可以重新生成bsp,然后再编译工程,下载就能够通过,而且正确运行了。
3 l' x) E6 O4 @3 J b
3 k! @5 e- ?4 d1 v4 d1 m5 b* s |