📄 q1_15_mulq.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_mulq.c
//
// Steve Underwood <steve-underwood@ti.com>
// Texas Instruments Hong Kong Ltd.
//
// $Id: q1_15_mulq.c,v 1.2 2003/07/28 09:48:22 XHKJAMES Exp $
//
//--------------------------------------------------------------------------
#include "io.h"
//uint16_t rndnum;
//uint16_t tpdnum;
//Q1.15 style 16x16=>16 multiply with TPD (triangular
//probability density) dithered rounding of the result.
;int16_t Q1_15_mulq(register int16_t x, register int16_t y)
public Q1_15_mulq
public tpd_gen
RSEG CODE
Q1_15_mulq
#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
#if 0
//Do TPD dithering at the Q1.15 level
add @tpdnum,R12
addc #0,R13
//Shift to Q1.15 format (i.e. the top 16 bits are returned)
rla R12
rlc R13
mov R13,R12
#endif
#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
//Do TPD dithering at the Q1.15 level
//add @tpdnum,R12
//addc #0,R13
//Shift to Q1.15 format (i.e. the top 16 bits are returned)
rla R12
rlc R13
mov R9,R12
pop.w R15
pop.w R10
#if defined(__MSP430_HAS_MSP430X_CPU__)
reta
#else
ret
#endif
#endif
// Use a linear congrual generator function to generate
// a TPD (triangular probability density) weighted random
// number. Adding a pair of even distribution random numbers
// will create a TPD. We can reuse an old random number in the
// generation of each new TPD value, as there should be very
// weak correlation between the numbers.
;void tpd_gen(void)
tpd_gen
#if 0
mov rndnum,@x1
mov #0,@x2
sub @x1,@x2 //0
rla @x1
add @x1,@x2 //1
rla @x1
sub @x1,@x2 //2
rla @x1
rla @x1
add @x1,@x2 //4
rla @x1
rla @x1
sub @x1,@x2 //6
rla @x1
add @x1,@x2 //7
rla @x1
rla @x1
rla @x1
sub @x1,@x2 //10
add #13489,@x2
and #0x3FFF,@x2
mov rndnum,R8
add @x2,R8
mov R8,tpdnum
mov @x2,rndnum
#endif
#if defined(__MSP430_HAS_MSP430X_CPU__)
reta
#else
ret
#endif
end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -