首页 业界资讯 解决方案 微处理器与DSP 消费电子设计 测试与测量 电源技术 计算机与外设 可编程器件 模拟设计专区 嵌入式系统 通信与网络
→ 当前位置:照明设计网-电子专栏>嵌入式系统>正文

BCH编解码IP核在Nios SoC系统中的设计

照明设计网-电子专栏 5iLight.COM 苏勇 张剑峰 发布时间:2007-08-02
0 引 言

  循环码是最重要的一类线性分组纠错码,而BCH码又是目前发现的性能很好且应用广泛的循环码,它具有严格的代数理论,对它的理论研究也非常透彻。BCH码的实现途径有软件和硬件两种。软件实现方法灵活性强且较易实现,但硬件实现方法的工作速度快,在高数据速率和长帧应用场合时具有优势。FPGA(现场可编程门阵列)为DSP算法的硬件实现提供了很好的平台,但如果单独使用一片FPGA实现BCH编解码,对成本、功耗和交互速度都不利。最新的SoC(片上系统)设计方法可以很好地解决这个问题。

  本文基于Altera公司的Nios软核+可编程资源的SoC平台设计了BCH编解码IP核,这样,在Nios系统中可以将BCH码作为一种片内资源进行调用,在工程设计上具有积极的意义。

  1 BCH码

  BCH码于1960年前后发明,可以纠检多个错误。通常的二进制BCH码元是取自加罗瓦域GF(2m)。对于参数m和可纠错码元数目t,BCH码的码长为n=2m-1,对于m≥3,t<2m-1的BCH码,监督码元数目n-k=mt;dmin≥2t+1。同时,BCH码元多项式的根为GF(2m)中的元素α,α3,…,α2t+1。例如一个m=6,t=3的BCH码,其参数为:n=63,n-k=18,dmin=7。这就构成了可以纠正3个错误的(63,45)BCH码。

  BCH码基于加罗瓦域,BCH编解码的运算也是域内的闭合运算。加罗瓦有限域产生于一个本原多项式,GF(2m)有限域内有2m个元素。以GF(23)域为例,它的本原多项式p(x)假定为p(x)=x3+x+1,基本元素α定义为p(x)=0的根,GF(23)中的元素可以计算如下:

公式

  BCH码的编码取决于其生成多项式,令φ2i-1(x)是加罗瓦域元素α2i-1的最小多项式,则可以纠正t个错误的BCH码的生成多项式为:

公式

  有了生成多项式,BCH编码与普通的循环码编码相同,使用除法电路可以实现。一个复杂度较低的BCH译码算法对于BCH码的应用有着重要的意义。BCH译码可以分为伴随式计算和Berlekamp迭代译码两部分。设接收码元多项式为r(x),由于生成多项式的性质,如果传输过程中信道没有引入错误,α,α2,α3,…,α2t应是r(x)的根。因此,伴随式计算即将加罗瓦域中的元素代入接收码元多项式,如果所有伴随式结果都为0,则说明没有错误,否则就有错误。如果只使用BCH码进行检错,则译码过程就结束了。

  伴随式计算结束后,如果有错,首先需要计算错误位置多项式δ(x),译码的核心主要集中在这一步上。Berlekamp迭代算法不仅求解了错误位置多项式的关键方程,而且运算速度快,可以说它解决了BCH码译码的工程实用问题。其次,使用钱搜索找出δ(x)的根,即错误位置。最后,由于是二进制编码,只需把相应位置的码元取反就完成了整个译码过程。

  2 BCH编解码IP核的设计

  2.1 整体设计及CPU接口

  在NiosⅡ系统中,平台免费提供了各种常用接口IP核以及对这些外设的驱动程序包,例如UART接口、Flash接口等。作为一个自行设计的IP核,需要挂接在NiosⅡ系统的Avalon总线上。这个过程使用Sopc Builder工具中的Interface t0 user logic模块可以方便地进行设计。NiosⅡ处理器和BCH IP核之间通过Avalon总线使用寄存器映射方式进行交互。图1是整个IP核的实现方框图。

整个IP核的实现方框图

  其中与NiosⅡ的接口分为控制接口和数据接口两部分。控制接口包括复位、编解码控制、存储器状态报告和编解码状态报告等。数据接口为FPGA内部的RAM,分为发送和接收两部分,它在NiosⅡ中映射成存储空间。在NiosⅡ和BCH码IP核之 间设置简单的数据协议,控制寄存器的起始控制位设置后,写入数据缓存的第1个字节为编解码输入数据的长度字节。BCH编解码模块从数据缓存中读入数据进行相应处理。其中,加罗瓦域的运算主要通过对域元素的查表得到。

  2.2 BCH编码

  BCH码属于系统码,其编码与一般循环码的编码形式基本相同,即为信息码元多项式与生成多项式之间的除法电路实现。除法电路采用带反馈的移位寄存器完成。信息码元发送完后,寄存器内存储的就是监督码元,再接着发送即可。其中反馈抽头连接为生成多项式控制。其基本结构见图2。

BCH编码结构

  信息码元首先从数据缓存中被读出,然后通过并/串变换进入编码器后,一方面直接输出,同时送入除法电路,当信息码元输入结束后,开关进行相应的变换,存在寄存器中的监督码元输出。图3为(31,16)BCH编码的RTL(寄存器传输级)仿真结果。

BCH编码的RTL

2.3 BCH译码

  前面已经介绍了BCH迭代译码的基本步骤。译码过程中的运算都为有限域运算,在运算过程中经常计算加罗瓦域的元素是不明智的,查表实现是通用的方法。例如GF(23)中,可以设计表1所示的表格来实现域元素的查找,同时,运算中还经常需要通过元素值反查元素类型,因此需要设计两张表格来正向和反向查找。图1中的GF域查表RAM模块就完成了这个功能。通过以上查表方法可以轻松实现有限域的加、减和乘运算。

 

有限域中的域元素

  首先进行伴随式计算,在设计中利用片内较高的工作频率和FPGA的并发实现优势,同时完成所有伴随式的计算。图4为伴随式计算的RTL仿真结果,当传输引入错误后,伴随式相或的结果Data_Out输出高电平,表示需要进行纠错。

共2页: 上一页 1 [2] 下一页
上一篇:基于TMS320C6000系列二次Bootloader的设计与实现   下一篇:浅谈在Windows Vista中提高SATA硬盘的性能

收藏】 【评论】 【推荐】 【关闭


相关文章
·uClinux下中断驱动的方式
·高效率嵌入式程序开发
·DCS控制器中采用ARM处理器的冗余设计
·FPGA的DSP性能揭秘
·嵌入式系统设计中FPGA问题
·基于μC/OS-II嵌入式系统的低功耗开发
·达芬奇数字媒体片上系统的架构和Linux启动
·用UML建模开发嵌入式软件
·Linux2.4与Linux2.6内核调度器的比较研究
·如何选择合适的嵌入式软件开发平台
发表评论
密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。)
阅读排行
·隔离端子的抗干扰和应用选
·达芬奇数字媒体片上系统的
·DCS控制器中采用ARM处理器
· 基于ARM-Linux和CDMA的远
· 基于单片机的嵌入式SNMP
· 利用MCU实现超长的电池使
· 面向嵌入式系统的I2C总线
· CISC和RISC微控制器
· μC/OS—II的嵌入式串口
· 波音选择风河下一代网络L
专题教程
·浅谈嵌入式数字视频播放系
·RFID(无线射频识别)芯片
·有机硅增强汽车电子产品的
·基于嵌入式WEB的工业洗衣
·视频监视领域的视频压缩与
·用TMS320DM270在MP4上实现
·分析:卫星与WiFi的集成应
·家庭网络:从带宽共享走向
· 夏普LCD技术详解
·汽车动力传动系统一体化智
最新文章
·uClinux下中断驱动的方式
·高效率嵌入式程序开发
·DCS控制器中采用ARM处理器
·FPGA的DSP性能揭秘
·嵌入式系统设计中FPGA问题
·基于μC/OS-II嵌入式系统
·达芬奇数字媒体片上系统的
·用UML建模开发嵌入式软件
·Linux2.4与Linux2.6内核调
·如何选择合适的嵌入式软件
·ARM/DSP双核系统的通信接
·嵌入式Linux系统中I2C总线
·奇趣科技宣布业界对Qtopia
·嵌入式MPEG-2远程网络视频
·飞思卡尔提供首款带片上TF

首页 - 加入收藏 - 联系我们 -照明设计
照明设计网电子专栏 5ilight.Com 版权所有
Copyright (c); 2007 - 2010 All rights reserved