forked from OSchip/llvm-project
12 lines
373 B
C++
12 lines
373 B
C++
|
|
// We need to use shifts here in order to mantain the sign bit for signed
|
|
// integers. The compiler should optimize this to (x & 0x00FFFFFF) for
|
|
// unsigned integers.
|
|
#define CONVERT_TO_24BIT(x) (((x) << 8) >> 8)
|
|
|
|
_CLC_OVERLOAD _CLC_DEF __CLC_GENTYPE mul24(__CLC_GENTYPE x, __CLC_GENTYPE y){
|
|
return CONVERT_TO_24BIT(x) * CONVERT_TO_24BIT(y);
|
|
}
|
|
|
|
#undef CONVERT_TO_24BIT
|