📄 q1_15_mulr.s43
字号:
//--------------------------------------------------------------------------
//
// Software for MSP430 based e-meters.
//
// THIS PROGRAM IS PROVIDED "AS IS". TI MAKES NO WARRANTIES OR
// REPRESENTATIONS, EITHER EXPRESS, IMPLIED OR STATUTORY,
// INCLUDING ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS
// FOR A PARTICULAR PURPOSE, LACK OF VIRUSES, ACCURACY OR
// COMPLETENESS OF RESPONSES, RESULTS AND LACK OF NEGLIGENCE.
// TI DISCLAIMS ANY WARRANTY OF TITLE, QUIET ENJOYMENT, QUIET
// POSSESSION, AND NON-INFRINGEMENT OF ANY THIRD PARTY
// INTELLECTUAL PROPERTY RIGHTS WITH REGARD TO THE PROGRAM OR
// YOUR USE OF THE PROGRAM.
//
// IN NO EVENT SHALL TI BE LIABLE FOR ANY SPECIAL, INCIDENTAL,
// CONSEQUENTIAL OR INDIRECT DAMAGES, HOWEVER CAUSED, ON ANY
// THEORY OF LIABILITY AND WHETHER OR NOT TI HAS BEEN ADVISED
// OF THE POSSIBILITY OF SUCH DAMAGES, ARISING IN ANY WAY OUT
// OF THIS AGREEMENT, THE PROGRAM, OR YOUR USE OF THE PROGRAM.
// EXCLUDED DAMAGES INCLUDE, BUT ARE NOT LIMITED TO, COST OF
// REMOVAL OR REINSTALLATION, COMPUTER TIME, LABOR COSTS, LOSS
// OF GOODWILL, LOSS OF PROFITS, LOSS OF SAVINGS, OR LOSS OF
// USE OR INTERRUPTION OF BUSINESS. IN NO EVENT WILL TI'S
// AGGREGATE LIABILITY UNDER THIS AGREEMENT OR ARISING OUT OF
// YOUR USE OF THE PROGRAM EXCEED FIVE HUNDRED DOLLARS
// (U.S.$500).
//
// Unless otherwise stated, the Program written and copyrighted
// by Texas Instruments is distributed as "freeware". You may,
// only under TI's copyright in the Program, use and modify the
// Program without any charge or restriction. You may
// distribute to third parties, provided that you transfer a
// copy of this license to the third party and the third party
// agrees to these terms by its first use of the Program. You
// must reproduce the copyright notice and any other legend of
// ownership on each copy or partial copy, of the Program.
//
// You acknowledge and agree that the Program contains
// copyrighted material, trade secrets and other TI proprietary
// information and is protected by copyright laws,
// international copyright treaties, and trade secret laws, as
// well as other intellectual property laws. To protect TI's
// rights in the Program, you agree not to decompile, reverse
// engineer, disassemble or otherwise translate any object code
// versions of the Program to a human-readable form. You agree
// that in no event will you alter, remove or destroy any
// copyright notice included in the Program. TI reserves all
// rights not specifically granted under this license. Except
// as specifically provided herein, nothing in this agreement
// shall be construed as conferring by implication, estoppel,
// or otherwise, upon you, any license or other right under any
// TI patents, copyrights or trade secrets.
//
// You may not use the Program in non-TI devices.
//
// File: q1_15_mulr.c
//
// Steve Underwood <steve-underwood@ti.com>
// Texas Instruments Hong Kong Ltd.
//
// $Id: q1_15_mulr.c,v 1.2 2003/07/28 09:48:22 XHKJAMES Exp $
//
//--------------------------------------------------------------------------
#include "io.h"
//Q1.15 style 16x16=>16 multiply with half bit rounding of the result.
;int16_t Q1_15_mulr(register int16_t x, register int16_t y)
public Q1_15_mulr
RSEG CODE
Q1_15_mulr
#if defined(RESLO_) && defined(RESHI_) && defined(MPYS_) && defined(OP2_)
push.w SR
dint
mov R12,&MPYS_
mov R14,&OP2_
mov &RESHI_,R13
mov &RESLO_,R12
pop.w SR
//Half bit round at the Q1.15 level
add #4000h,R12
addc #0,R13
//Shift to Q1.15 format (i.e. the top 16 bits are returned)
rla R12
rlc R13
mov R13,R12
#if defined(__MSP430_HAS_MSP430X_CPU__)
reta
#else
ret
#endif
#else
push.w R10
push.w R15
mov R12,R15
clr R13
mov R13,R12
mov R13,R10
tst R15
jge booth_2
mov #-1,R10
jmp booth_2
booth_6
add R15,R12
addc R10,R13
booth_1
rla R15
rlc R10
booth_2
rra R14
jc booth_5
jne booth_1
jmp booth_4
booth_5
sub R15,R12
subc R10,R13
booth_3
rla R15
rlc R10
rra R14
jnc booth_6
cmp #0xFFFF,R14
jne booth_3
booth_4
//Half bit round at the Q1.15 level
add #4000h,R12
addc #0,R13
//Shift to Q1.15 format (i.e. the top 16 bits are returned)
rla R12
rlc R13
mov R13,R12
pop.w R15
pop.w R10
#if defined(__MSP430_HAS_MSP430X_CPU__)
reta
#else
ret
#endif
#endif
end
#if defined(RESLO_) && defined(RESHI_) && defined(MPYS_) && defined(OP2_)
/$
push.w SR
dint
mov @x,&MPYS_
mov @y,&OP2_
mov &RESHI_,@z.0
mov &RESLO_,@z.1
pop.w SR
//Half bit round at the Q1.15 level
add #4000h,@z.1
addc #0,@z.0
//Shift to Q1.15 format (i.e. the top 16 bits are returned)
rla @z.1
rlc @z.0
mov @z.0,@x1
$/
#else
/$
clr @z.0
mov @z.0,@z.1
mov @z.0,@x1
tst @x
jge xbooth_2
mov #-1,@x1
jmp xbooth_2
xbooth_6
add @x,@z.1
addc @x1,@z.0
xbooth_1
rla @x
rlc @x1
xbooth_2
rra @y
jc xbooth_5
jne xbooth_1
jmp xbooth_4
xbooth_5
sub @x,@z.1
subc @x1,@z.0
xbooth_3
rla @x
rlc @x1
rra @y
jnc xbooth_6
cmp #0xFFFF,@y
jne xbooth_3
xbooth_4
//Half bit round at the Q1.15 level
add #0x4000,@z.1
addc #0,@z.0
//Shift to Q1.15 format (i.e. the top 16 bits are returned)
rla @z.1
rlc @z.0
mov @z.0,@x1
$/
#endif
#elif defined(__IAR_SYSTEMS_ICC__)
#if defined(RESLO_) && defined(RESHI_) && defined(MPYS_) && defined(OP2_)
istate_t s;
s = __get_interrupt_state();
__disable_interrupt();
MPYS = x;
OP2 = y;
z = ((int32_t) RESHI << 16);
z |= RESLO;
z += 0x4000;
__set_interrupt_state(s);
//Shift to Q1.15 format (i.e. the top 16 bits are returned)
z <<= 1;
x1 = z >> 16;
#else
z = (int32_t) x*(int32_t) y;
z += 0x4000;
x1 = (z >> 15);
#endif
#else
z = (int32_t) x*(int32_t) y;
z += 0x4000;
x1 = (z >> 15);
#endif
return x1;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -