打印

关于430硬件乘法器

[复制链接]
519|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
Rollo|  楼主 | 2017-2-28 21:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
沙发
Rangar| | 2017-2-28 21:09 | 只看该作者
.无符号数乘加操作 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位的类似

使用特权

评论回复
板凳
Stannis| | 2017-2-28 21:24 | 只看该作者
//******************************************************************************
//   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
}

使用特权

评论回复
地板
Brand2| | 2017-2-28 21:47 | 只看该作者
记得在IAR下,使用乘法的时候会自动使用硬件乘法器,这个不用过多考虑,直接使用乘法就行

使用特权

评论回复
5
Soraka| | 2017-2-28 21:59 | 只看该作者
IAR中,工程->options,勾选后自动使用硬件乘法器。

使用特权

评论回复
6
dirtwillfly| | 2017-3-1 20:25 | 只看该作者
ccs也可以设置使用硬件乘法器

使用特权

评论回复
7
dspmana| | 2017-3-5 16:42 | 只看该作者
8
dspmana| | 2017-3-5 16:43 | 只看该作者
使用编译器自动使用硬件乘法器的方法,需要在IAR环境了里面设置,默认使用乘法器

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

115

主题

730

帖子

1

粉丝