求教关于430硬件乘法器

2019-03-24 08:42发布

430硬件乘法的乘累加器不知道怎么用              求一段C例程;官方例程也有看似乎都没有说到乘累加怎么用哦!想在FFT里面优化一下程序可能会用到乘累加。 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
6条回答
zzbaizhi
1楼-- · 2019-03-24 13:52
< .无符号数乘加操作 result="n1"*n2+n3*n4。第一操作数n1(16位无符号)赋给MPY寄存器,第二操作数n2(16位无符号)赋给OP2寄存器,第三操作数n3(16位无符号)赋给MAC寄存器,第四操作数n4(16位无符号)赋给OP2寄存器,结果result(32位无符号)就可以在RESLO(低16位)和RESHI(高165位)中读取。SUMEXT寄存器中保存进位标志。
代码如下:
  MPY = n1;                             // Load first operand -unsigned mult
  OP2 = n2;                             // Load second operand
  MAC = n3;    // Load 3rd operand -unsigned mult
  OP2 = n4;    // Load 4rd operand
  result = RESHI;                           // Load RESHI word result
  result = (result<<16)|RESLO;              // Shift RESHI left and concat with
这是16位的,32位的类似,希望对你有用
wstt
2楼-- · 2019-03-24 16:45
< :TI_MSP430_内容页_SA7 -->
  1. //******************************************************************************
  2. //   MSP430x26x Demo - 8x8 Signed Multiply Accumulate
  3. //
  4. //   Description: Hardware multiplier is used to multiply two numbers.
  5. //   The calculation is automatically initiated after the second operand is
  6. //   loaded.  A second multiply accumulate operation is performed after that.
  7. //   Results are stored in RESLO and RESHI.  SUMEXT contains the extended sign of
  8. //   result.
  9. //   ACLK = 32.768kHz, MCLK = SMCLK = default DCO
  10. //
  11. //            MSP430F261x/241x
  12. //             -----------------
  13. //         /||                 |
  14. //          | |                 |
  15. //          --|RST              |
  16. //            |                 |
  17. //            |                 |
  18. //
  19. //  B. Nisarga
  20. //  Texas Instruments Inc.
  21. //  September 2007
  22. //  Built with CCE Version: 3.2.0 and IAR Embedded Workbench Version: 3.42A
  23. //******************************************************************************
  24. #include  

  25. void main(void)
  26. {
  27.   unsigned char value1,value2;

  28.   WDTCTL = WDTPW+WDTHOLD;                   // Stop WDT

  29.   MPY = 0x1234;                             // Load 1st operand - unsigned mult
  30.   OP2 = 0x5678;                             // Load second operand

  31.   value1 = 0x12;                            // Load first operand - signed MAC
  32.   value2 = 0x96;                            // Load second operand

  33.   // Sign-extend the values
  34.   if (value1 >=0x80)
  35.     MACS = 0xFF00 | value1;
  36.   else
  37.     MACS = value1;
  38.   if (value2 >=0x80)
  39.     OP2 = 0xFF00 | value2;
  40.   else
  41.     OP2 = value2;

  42.   _BIS_SR(LPM4_bits);                       // LPM4
  43. }
复制代码
cz380921140
3楼-- · 2019-03-24 18:02
 精彩回答 2  元偷偷看……
恋风
4楼-- · 2019-03-24 22:47
最近也在看... 求楼主指导下
lcofjp
5楼-- · 2019-03-25 03:51
我记得在IAR下,使用乘法的时候会自动使用硬件乘法器,这个不用过多考虑,直接使用乘法就行。
infyspace
6楼-- · 2019-03-25 06:02
 精彩回答 2  元偷偷看……

一周热门 更多>

相关问题

    相关文章