Text file src/reflect/float32reg_ppc64x.s

     1  // Copyright 2021 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  //go:build ppc64 || ppc64le
     6  
     7  #include "textflag.h"
     8  
     9  // On PPC64, the float32 becomes a float64
    10  // when loaded in a register, different from
    11  // other platforms. These functions are
    12  // needed to ensure correct conversions on PPC64.
    13  
    14  // Convert float32->uint64
    15  TEXT ·archFloat32ToReg(SB),NOSPLIT,$0-16
    16  	FMOVS	val+0(FP), F1
    17  	FMOVD	F1, ret+8(FP)
    18  	RET
    19  
    20  // Convert uint64->float32
    21  TEXT ·archFloat32FromReg(SB),NOSPLIT,$0-12
    22  	FMOVD	reg+0(FP), F1
    23  	// Normally a float64->float32 conversion
    24  	// would need rounding, but that is not needed
    25  	// here since the uint64 was originally converted
    26  	// from float32, and should be avoided to
    27  	// preserve SNaN values.
    28  	FMOVS	F1, ret+8(FP)
    29  	RET
    30  
    31  

View as plain text