2020-09-30 16:53:55 +02:00

106 lines
3.2 KiB
C

#ifndef ZQFROMZQ_DEFINED
#define ZQFROMZQ_DEFINED
#include "lsdefs.h"
#define zqLim 1491309L /* higher resolution will overflow */
long ZqFromZa_C (long, long);
#ifdef _X86_
long ZqFromZa_Asm (long, long);
__int64 Div64_Asm (__int64, __int64);
__int64 Mul64_Asm (__int64, __int64);
#define ZqFromZa(dzqInch,za) ZqFromZa_Asm ((dzqInch),(za))
#define Div64(DVND,DVSR) Div64_Asm ((DVND),(DVSR))
#define Mul64(A,B) Mul64_Asm ((A),(B))
#else
#define ZqFromZa(dzqInch,za) ZqFromZa_C ((dzqInch),(za))
#define Div64(DVND,DVSR) ((__int64) (DVND) / (__int64) (DVSR))
#define Mul64(A,B) ((__int64) (A) * (__int64) (B))
#endif
long ZaFromZq(long, long);
long LsLwMultDivR(long, long, long);
#define I_UpFromUa(pdevres,ua) (ZqFromZa((pdevres)->dxpInch, (ua)))
#define I_UrFromUa(pdevres,ua) (ZqFromZa((pdevres)->dxrInch, (ua)))
#define I_VpFromVa(pdevres,va) (ZqFromZa((pdevres)->dypInch, (va)))
#define I_VrFromVa(pdevres,va) (ZqFromZa((pdevres)->dyrInch, (va)))
#define I_UaFromUp(pdevres,up) (ZaFromZq((pdevres)->dxpInch, (up)))
#define I_VaFromVp(pdevres,vp) (ZaFromZq((pdevres)->dypInch, (vp)))
#define I_UaFromUr(pdevres,ur) (ZaFromZq((pdevres)->dxrInch, (ur)))
#define I_VaFromVr(pdevres,vr) (ZaFromZq((pdevres)->dyrInch, (vr)))
#define UpFromUa(tfl,pdevres,ua) (((tfl) & fUVertical) ? \
I_VpFromVa(pdevres,ua) :\
I_UpFromUa(pdevres,ua) \
)
#define UrFromUa(tfl,pdevres,ua) (((tfl) & fUVertical) ? \
I_VrFromVa(pdevres,ua) :\
I_UrFromUa(pdevres,ua) \
)
#define VpFromVa(tfl,pdevres,va) ((tfl) & fUVertical) ? \
I_UpFromUa(pdevres,va) :\
I_VpFromVa(pdevres,va) \
)
#define VrFromVa(tfl,pdevres,va) (((tfl) & fUVertical) ? \
I_UrFromUa(pdevres,va) :\
I_VrFromVa(pdevres,va) \
)
#define UaFromUp(tfl,pdevres,up) (((tfl) & fUVertical) ? \
I_VaFromVp(pdevres,up) :\
I_UaFromUp(pdevres,up) \
)
#define VaFromVp(tfl,pdevres,vp) (((tfl) & fUVertical) ? \
I_UaFromUp(pdevres,vp) :\
I_VaFromVp(pdevres,vp) \
)
#define UaFromUr(tfl,pdevres,ur) (((tfl) & fUVertical) ? \
I_VaFromVr(pdevres,ur) :\
I_UaFromUr(pdevres,ur) \
)
#define VaFromVr(tfl,pdevres,vr) (((tfl) & fUVertical) ? \
I_UaFromUr(pdevres,vr) :\
I_VaFromVr(pdevres,vr) \
)
/*
#define UpFromUr(pdevres,ur) UpFromUa(pdevres, UaFromUr(pdevres, ur))
#define VpFromVr(pdevres,vr) VpFromVa(pdevres, VaFromVr(pdevres, vr))
*/
#define UpFromUr(tfl,pdevres,ur) (((tfl) & fUVertical) ? \
LsLwMultDivR(ur, (pdevres)->dypInch, (pdevres)->dyrInch): \
LsLwMultDivR(ur, (pdevres)->dxpInch, (pdevres)->dxrInch) \
)
#define VpFromVr(tfl,pdevres,vr) (((tfl) & fUVertical) ? \
LsLwMultDivR(vr, (pdevres)->dxpInch, (pdevres)->dxrInch): \
LsLwMultDivR(vr, (pdevres)->dypInch, (pdevres)->dyrInch) \
)
#define UrFromUp(tfl,pdevres,up) (((tfl) & fUVertical) ? \
LsLwMultDivR(up, (pdevres)->dyrInch, (pdevres)->dypInch): \
LsLwMultDivR(up, (pdevres)->dxrInch, (pdevres)->dxpInch) \
)
#define VrFromVp(tfl,pdevres,vp) (((tfl) & fUVertical) ? \
LsLwMultDivR(vp, (pdevres)->dxrInch, (pdevres)->dxpInch): \
LsLwMultDivR(vp, (pdevres)->dyrInch, (pdevres)->dypInch) \
)
#endif /* ZQFROMZQ_DEFINED */