mesa/src/intel/compiler/brw/brw_packed_float.c
Caio Oliveira 74f1d4f47b intel/compiler: Use SPDX annotations
Minor adjustments to formatting of the copyright line, but keep
dates and holders.  "Authors" entries that could be
obtained via Git logs were also removed.

The license in brw_disasm.c and elk_disasm.c don't match directly
any SPDX pattern I could find, so kept as is.

Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
Acked-by: Alyssa Rosenzweig <alyssa.rosenzweig@intel.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/39503>
2026-01-24 20:37:31 +00:00

58 lines
1.1 KiB
C

/*
* Copyright © 2014 Intel Corporation
* SPDX-License-Identifier: MIT
*/
#include "brw_reg.h"
union fu {
float f;
unsigned u;
struct {
unsigned mantissa:23;
unsigned exponent:8;
unsigned sign:1;
} s;
};
int
brw_float_to_vf(float f)
{
union fu fu = { .f = f };
/* ±0.0f is special cased. */
if (f == 0.0f)
return fu.s.sign << 7;
unsigned mantissa = fu.s.mantissa >> (23 - 4);
unsigned exponent = fu.s.exponent - (127 - 3);
unsigned vf = (fu.s.sign << 7) | (exponent << 4) | mantissa;
/* 0.125 would have had the same representation as 0.0, so reject it. */
if ((vf & 0x7f) == 0)
return -1;
/* Make sure the mantissa fits in 4-bits and the exponent in 3-bits. */
if (fu.u & 0x7ffff || exponent > 7)
return -1;
return vf;
}
float
brw_vf_to_float(unsigned char vf)
{
union fu fu;
/* ±0.0f is special cased. */
if (vf == 0x00 || vf == 0x80) {
fu.u = (unsigned)vf << 24;
return fu.f;
}
fu.s.sign = vf >> 7;
fu.s.exponent = ((vf & 0x70) >> 4) + (127 - 3);
fu.s.mantissa = (vf & 0xf) << (23 - 4);
return fu.f;
}