- //******************************************************************************
- // 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
- }
|