[Beignet] [PATCH] do not force float for immediate value load

Song, Ruiling ruiling.song at intel.com
Wed Aug 5 20:00:23 PDT 2015


The patch LGTM. But I think below description is a little clearer.

Use Integer for U32/S32 Immediate load.

Previously we use float type for U32/S32 immediate load from performance perspective, but using integer type would make things clearer and easy to debug.

> -----Original Message-----
> From: Beignet [mailto:beignet-bounces at lists.freedesktop.org] On Behalf Of
> Guo Yejun
> Sent: Wednesday, August 5, 2015 8:39 AM
> To: beignet at lists.freedesktop.org
> Cc: Guo, Yejun
> Subject: [Beignet] [PATCH] do not force float for immediate value load
> 
> float format is used to load immediate value with TYPE_U32/TYPE_S32, actually
> it is not necessary since it is not a performance sensitive point.
> 
> Signed-off-by: Guo Yejun <yejun.guo at intel.com>
> ---
>  backend/src/backend/gen_insn_selection.cpp | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
> 
> diff --git a/backend/src/backend/gen_insn_selection.cpp
> b/backend/src/backend/gen_insn_selection.cpp
> index b0ba9e3..0256d24 100644
> --- a/backend/src/backend/gen_insn_selection.cpp
> +++ b/backend/src/backend/gen_insn_selection.cpp
> @@ -3205,8 +3205,8 @@ namespace gbe
>            }
>            sel.MOV(dst, imm.getIntegerValue() ? GenRegister::immuw(0xffff) :
> GenRegister::immuw(0));
>          break;
> -        case TYPE_U32:
> -        case TYPE_S32:
> +        case TYPE_U32: sel.MOV(dst,
> GenRegister::immud(imm.getIntegerValue())); break;
> +        case TYPE_S32: sel.MOV(dst,
> + GenRegister::immd(imm.getIntegerValue())); break;
>          case TYPE_FLOAT:
>            sel.MOV(GenRegister::retype(dst, GEN_TYPE_F),
>                    GenRegister::immf(imm.asFloatValue()));
> --
> 1.9.1
> 
> _______________________________________________
> Beignet mailing list
> Beignet at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/beignet


More information about the Beignet mailing list