㈠ 單片機怎麼處理32位數據
#include <stdio.h>
//fl 第一個64位整數的低32位
//fh 第一個64位整數的高32位
//sl 第二個64位整數的低32位
//sh 第二個64位整數的高32位
//ol 結果值64位整數的低32位指針
//oh 結果值64位整數的高32位指針
void i64mul(__int32 fl, __int32 fh,__int32 sl, __int32 sh, __int32 *ol, __int32 *oh)
{
unsigned __int16 f[4]={fl & 0xFFFF,(unsigned __int32)fl >> 16,fh & 0xFFFF,(unsigned __int32)fh >> 16};
unsigned __int16 s[4]={sl & 0xFFFF,(unsigned __int32)sl >> 16,sh & 0xFFFF,(unsigned __int32)sh >> 16};
unsigned __int16 o[8]={};
int nf=0,ns=0,no;
if(f[3]&0x8000)
{
nf=1;
for (int i=0;i<4;i++)
f[i]=~f[i];
for (int i=0;i<4 && !++f[i];i++)
;
}
if(s[3]&0x8000)
{
ns=1;
for (int i=0;i<4;i++)
s[i]=~s[i];
for (int i=0;i<4 && !++s[i];i++)
;
}
no=nf ^ ns;
for (int i=0;i<4;i++)
{
for (int j=0;j<4;j++)
{
unsigned __int32 t=f[j]*s[i]+o[i+j];
o[i+j]=t & 0xFFFF;
t>>=16;
for (int k=i+j+1;k<8;k++)
{
t=t+o[k];
o[k]= t & 0xFFFF;
t>>=16;
}
}
}
if(no)
{
for (int i=0;i<8 && --o[i]==0xFFFF;i++)
;
for (int i=0;i<4;i++)
o[i]=~o[i];
}
*ol=o[0]+((unsigned __int32)o[1]<<16);
*oh=o[2]+((unsigned __int32)o[3]<<16);
}
int main()
{
/*
你的用法為
計算data32l,data32h乘7
i64mul(data32l,data32h,0,7,&data32l,&data32h);
計算data32l,data32h乘_data32l,_data32h 也就是兩個64位數相乘
i64mul(data32l,data32h,_data32l,_data32h,&data32l,&data32h);
*/
//下面是一個在PC機上驗證函數正確的樣本
__int64 o2=0,o,f,s;
f=-1234899233;
s=1567991233;
o=f*s;
i64mul(f,f>>32,s,s>>32, (__int32*)&o2,(__int32*)&o2+1);
if(o==o2)
{
printf("計算正確\n");
}
f=1234899999233;
s=1567999991233;
o=f*s;
i64mul(f,f>>32,s,s>>32, (__int32*)&o2,(__int32*)&o2+1);
if(o==o2)
{
printf("計算正確\n");
}
}