![](http://img4.cpooo.com/files/201905/17/p/79/1207632_1558063126.jpg)
3051GP4A2B21AB4M5K5HR5
Rosemount罗斯蒙特3051GP4A2B21AB4M5K5HR5如图1所示C55xDSP内核结构可知,整个处理器的地址及数据运算由P单元、A单元和D单元完成。这三个单元相对***,各自通过总线与数据区及程序区相连。这种相互***的模块化结构,在硬件特性上确保这三个单元在同一时钟周期内能够进行并行处理,完成各自不同的运算操作。在C55xDSP指令集中有一些固定搭配的并行执行指令(主要是利用D单元双MAC结构的并行指令),这些被固定使用的并行指令之间使用“::”符号连接。除了这些固有的并行指令外,用户也可以根据CPU结构特征自行定义并行指令,并行的两条指令之间需使用“||”符号连接,以区分指令集中的并行指令。用户自定义并行指令时,必须遵守如下3条并行处理基本规则:规则1:保证不产生硬件冲突,包括操作数、寄存器、总线及各运算模块的冲突。在对C55xDSP的所有操作中,对P、A、D三个单元进行操作的指令类型有14类,这14类操作指令之间有很大一部分可以相互并行运行。经过我们对C55xDSP硬件电路结构的分析,在只考虑硬件模块冲突的情况下,我们得出如图2所示的C55xDSP并行处理能力分析图。图中将14类操作指令组成了一个14×14的矩阵,列出了每一类指令与其自身及其他13类指令并行执行的能力。图中画有(符号的空格代表不能并行执行,相反没有任何符号的空格代表可以并行执行。在考虑并行处理的硬件冲突时,还需要考虑总线资源的冲突。总线资源的冲突通常发生在数据总线和常量总线,C55xDSP中含有5条数据总线和2条常量总线,各条总线与各运算模块的连接如图3所示。数据总线中,C、D总线是读数据总线,通过这两条总线进行数据读取;E、F总线是写数据总线,通过这两条总线进行数据写操作;另外还有一条特殊的B总线,这条总线可以进行读或写操作,但是它只能被CDP寄存器使用,而其它辅助寄存器无法使用B总线。两条常量总线分别是KA、KD总线。KA常量总线用于产***址数据。P单元的KA常量总线负责产生程序地址,例如跳转指令B#Routine2中,常量#Routine2就是通过KA常量总线被送到P单元的。A单元的KA常量总线负责产生数据存储区地址,例如在指令Mov*SP(#7),Brc0中,偏移量#7就是通过KA常量总线被送到A单元的。KD总线用于传送参与运算的常量数据,例如指令ADD#123,AC0中,常量123就是通过KD总线传送的。规则2:受指令缓冲队列(IBQ)的限制,并行语句的总长度不能超过6个字节。I单元中的译码器只能将IBQ中的1~6个字节的程序进行译码。如果一条并行语句的长度超过6个字节,则需要在两个时钟周期内对其进行两次译码。因此必须将两条并行语句的总长度限制在6个字节。规则3:当需要寻址两个及以上数据存储区数据时,必须使用双重AR间接寻址方式。各条总线与各运算模块的连接图图3采用双重AR间接寻址方式,可以通过使用2个不同的辅助寄存器(AR0~AR7)同时访问数据存储区中两个不同的数据。在这种寻址方式下,我们可以通过两条不同的数据总线,在同一时钟周期内寻址两个不同数据,并将其输入不同的运算模块进行计算。常用并行处理应用在编程实现过程中,对每一个并行处理都进行仔细分析将能达到事半功倍的效果。下面是我们总结出的几种典型并行处理应用:1.D单元双MAC结构的并行处理在C55xDSP的D单元中采用了双MAC的结构,其结构如图4所示。这里有3条数据总线(B、C、D数据总线)与两个MAC模块相连。在同一时钟周期里,可以同时通过3条数据总线将三个不同地址的数据传入两个MAC模块中进行并行计算。[next]通常情况下,两个MAC模块的运算总共需要4个数据,而这里的总线数却只有3条,所以在并行使用双MAC结构时,两个MAC模块必须共用一组数据,而另外两组数据分别分配给两个MAC模块。这使得双MAC结构的并行应用受到一定的限制。C55x的双MAC结构比较典型的应用如不同数据的相同算法处理和同一数据的不同算法处理。下面是对不同数据进行相同FIR滤波的实例:1771-A4BK1771-VHSCK1771-AM11771-RT411771-AM21771-RT441771-RK1771-RTP11771-DS1771-RTP31771-DW1771-RTP41771-IA1771-WA1771-IAD1771-WB1771-IADK1771-WC1771-IAN1771-WD1771-IB1771-WE1771-IBD1771-WF1771-IBDK1771-WG1771-IBN1771-WH1771-IBNK1771-WHF1771-IC1771-WHFB1771-ICD1771-WI1771-ID1771-WN1771-ID011771-AF1771-ID161771-AF11771-ID16K1771-CPR1771-IDK1771-PT41771-IG1771-ACN151771-IGD1771-ACNR151771-IH1771-CX11771-IM1771-CX101771-IMD1771-CX151771-IN1771-CX21771-IND1771-CX201771-INGA501771-CX251771-IQ1771-CX301771-IQ161771-CX51771-IQ16K1771-CX71771-IS1771-CXT1771-IT1771-DA1771-IV1771-DB1771-IVN1771-DCM1771-OA1771-CD1771-OAD1771-CE1771-OADK1771-CL21771-OAN1771-CP11771-OB1771-CP21771-OBD1771-CP31771-OBDK1771-CT1771-OBDS1771-P101771-OBDSK1771-P21771-OBN1771-P4R1771-OBNK1771-P4RK1771-OC1771-P4S1771-OD1771-P4S11771-OD161771-P4SK1771-OD16K1771-P51771-ODD1771-P5E1771-ODDK1771-P5EK1771-ODK1771-P5K1771-ODZ1771-P6R1771-OG1771-P6S1771-OGD1771-P6S11771-OM1771-P71771-OMD1771-P7K1771-ON1771-PS71771-OND1771-PS7K1771-OP1771-PSC1771-OQ1771-PSCC1771-OQ161771-EX1771-OQ16K1771-EZ1771-OR1771-XB1771-OVN1771-XL1771-OW1771-FC1771-OW161771-FD1771-OW16K1771-FD21771-OWK1771-FE1771-OWN1771-FF1771-OWNA1771-KE1771-OX1771-KF1771-OXKF1771-ACN15SERB1771-OYLF1771-ACNR15SERB1771-OZLF1771-ACNSERA1771-OZLKF1771-ACNSERB1771-SIMF1771-ASBSERA1771-IFEF1771-ASBSERB1771-IFEKF1771-ASBSERC1771-IFFF1771-ASBSERD1771-IFMSF1771-ASBSERE1771-ILF1771-ASC1771-ILKF1771-DA1771-IRF1771-DBSERA1771-IRKF1771-DMCU1771-IXEF1771-ESCSERA1771-IXEKF1771-ESCSERB1771-IXHRF1771-IEC1771-NB4SF1771-IFC1771-NB4TF1771-IFESERA1771-NBRCF1771-IFESERB1771-NBSCF1771-ILSERA1771-NBTCF1771-ILSERB1771-NBV1F1771-ILSERD1771-NBVCF1771-IRSERA1771-NC15F1771-IRSERB1771-NC6F1771-IRSERC1771-NISF1771-IXESERA1771-NIVF1771-IXESERB1771-NIV1F1771-IXESERC1771-NIVRF1771-KA1771-NIVTF1771-KA21771-NOCF1771-KE1771-NOVF1771-KF1771-NRF1771-KGM1771-NT1F1771-KGSERA1771-NT2F1771-KGSERB1771-OFE1F1771-M11771-OFE1KF1771-M3SERA1771-OFE2F1771-M3SERB1771-OFE2KF1771-NXXSERA1771-OFE3F1771-NXXSERB1771-QDF1771-OFC1771-QDCF1771-OFE1SERA1771-QIF1771-OFE2SERA1771-CFMF1771-PD1771-ACN15F1771-PM1771-ACNR15F1771-QBSERA1771-SDNF1771-QBSERB1771-ARF1771-QBSERC1771-CGF1771-QDCSERA1771-DMCF1771-QDCSERB1771-DMC1F1771-QDCSERC1771-DM***F1771-QDCSERD1771-PT1F1771-QDSERA1771-PT2F1771-QDSERB1771-PT3F1771-SDNSERB1771sc-IFE32F1771-SN1771sc-IMI16F1771-TCMRSERA1771sc-ICI16F1771-TCMSERA1771sc-OMI16F1771-TCMSERBF1771-TCMSERCF1771-VHSCSERAF1771-VHSCSERB)