打印

关于430硬件乘法器

[复制链接]
562|9
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
Rangar|  楼主 | 2017-10-16 14:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
沙发
Brand2| | 2017-10-16 15:12 | 只看该作者
无符号数乘加操作 result="n1"*n2+n3*n4。第一操作数n1(16位无符号)赋给MPY寄存器,第二操作数n2(16位无符号)赋给OP2寄存器,第三操作数n3(16位无符号)赋给MAC寄存器,第四操作数n4(16位无符号)赋给OP2寄存器,结果result(32位无符号)就可以在RESLO(低16位)和RESHI(高165位)中读取。SUMEXT寄存器中保存进位标志。

使用特权

评论回复
板凳
Soraka| | 2017-10-16 15:43 | 只看该作者
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位的类似,希望对你有用

使用特权

评论回复
地板
Garen2| | 2017-10-16 15:51 | 只看该作者
  • //******************************************************************************
  • //   MSP430x26x Demo - 8x8 Signed Multiply Accumulate
  • //
  • //   Description: Hardware multiplier is used to multiply two numbers.
  • //   The calculation is automatically initiated after the second operand is
  • //   loaded.  A second multiply accumulate operation is performed after that.
  • //   Results are stored in RESLO and RESHI.  SUMEXT contains the extended sign of
  • //   result.
  • //   ACLK = 32.768kHz, MCLK = SMCLK = default DCO
  • //
  • //            MSP430F261x/241x
  • //             -----------------
  • //         /|\|                 |
  • //          | |                 |
  • //          --|RST              |
  • //            |                 |
  • //            |                 |
  • //
  • //  B. Nisarga
  • //  Texas Instruments Inc.
  • //  September 2007
  • //  Built with CCE Version: 3.2.0 and IAR Embedded Workbench Version: 3.42A
  • //******************************************************************************
  • #include  
  • void main(void)
  • {
  •   unsigned char value1,value2;
  •   WDTCTL = WDTPW+WDTHOLD;                   // Stop WDT
  •   MPY = 0x1234;                             // Load 1st operand - unsigned mult
  •   OP2 = 0x5678;                             // Load second operand
  •   value1 = 0x12;                            // Load first operand - signed MAC
  •   value2 = 0x96;                            // Load second operand
  •   // Sign-extend the values
  •   if (value1 >=0x80)
  •     MACS = 0xFF00 | value1;
  •   else
  •     MACS = value1;
  •   if (value2 >=0x80)
  •     OP2 = 0xFF00 | value2;
  •   else
  •     OP2 = value2;
  •   _BIS_SR(LPM4_bits);                       // LPM4
  • }

使用特权

评论回复
5
Ryze| | 2017-10-16 15:59 | 只看该作者
我记得在IAR下,使用乘法的时候会自动使用硬件乘法器,这个不用过多考虑,直接使用乘法就行。

使用特权

评论回复
6
Varus| | 2017-10-16 16:09 | 只看该作者
IAR中,工程->options,勾选后自动使用硬件乘法器。

使用特权

评论回复
7
fentianyou| | 2017-10-16 21:56 | 只看该作者
这个没有用过,硬件的乘法这个问问TI在线支持社区。

使用特权

评论回复
8
fentianyou| | 2017-10-16 22:03 | 只看该作者
9
gygp| | 2017-10-17 21:40 | 只看该作者
10
gygp| | 2017-10-17 21:57 | 只看该作者
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

154

主题

763

帖子

0

粉丝