DSP可以代表数字信号处理(Digital Signal Processing)技术,同时也可以代表数字信号处理器(Digital Signal Processor)。前者是理论和计算方法上的技术,后者是指实现这些技术的通用或专用的可编程微处理器芯片。在本书中,DSP指的是数字信号处理器,主要研究如何把数字信号处理技术应用于数字信号处理器中,从而对数字信号进行分析、处理。
DSP微处理器是为了满足数字信号处理及实时控制而制造的一类微处理器,具有特殊的芯片架构与指令集,有如下特点:
DSP内部一般采用哈佛(Harvard)结构或改进型哈佛结构,其片内至少有4套总线,分别为程序数据总线、程序地址总线、数据总线和数据地址总线。这种完全隔离的程序与数据存储器及双独立总线结构,可允许同时获取来自程序存储器的指令字和来自数据存储器的操作数,这意味着在一个机器周期内,可以同时取指令和操作数而互不干扰。
一般的算术逻辑单元(Arithmetic and Logic Unit,ALU)的乘法运算由加法和移位实现,乘法运算需要多个指令周期来完成,运算速度慢。DSP设置了专用的硬件乘法器,一次或多次乘法累加运算可以在一个指令周期内完成。
执行一条DSP指令,需要经过取指令、译码、取操作数和执行等几个阶段。DSP的流水线结构使得这几个阶段在执行程序过程中是重叠的,在执行本条指令的同时,后继的若干条指令也在完成取指令、译码、读操作数操作,即在每个指令周期内,多条指令同时处于激活状态,但是,处于不同的阶段同时处于激活状态的指令数与DSP芯片流水线的深度有关。
DSP内部一般包含多个处理单元,如硬件乘法器(MUL)、累加器(ACC)、算术逻辑单元(ALU)、辅助算术单元(ARAU)等。它们都可以在一个单独的指令周期内执行计算任务,且这些运算往往是同时完成的,因此,DSP可以完成连续乘加运算,每次运算都是单周期的。
DSP在指令系统中采用了一些特殊指令,主要包括为实现数字信号处理算法而设置的特殊指令,例如,为了实现FFT(快速傅里叶变换)算法,指令系统中设置了“循环寻址”名及“位倒序”等特殊指令。
DSP芯片采用上述哈佛结构、流水线操作,并设计了专用的硬件乘法器和特殊DSP指令,使得DSP芯片的指令周期能够达到数十纳秒至几纳秒。
DSP芯片上集成了丰富的外设资源,如定时器、ADC模块、PWM模块等,并包含许多与外设芯片通信的接口,如McBSP、SPI、I 2 C、XINTF等,这些功能性端口也可以独立配置为通用I/O端口。