| /* libs/opengles/arch-mips/fixed_asm.S |
| ** |
| ** Copyright 2012, The Android Open Source Project |
| ** |
| ** Licensed under the Apache License, Version 2.0 (the "License"); |
| ** you may not use this file except in compliance with the License. |
| ** You may obtain a copy of the License at |
| ** |
| ** http://www.apache.org/licenses/LICENSE-2.0 |
| ** |
| ** Unless required by applicable law or agreed to in writing, software |
| ** distributed under the License is distributed on an "AS IS" BASIS, |
| ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| ** See the License for the specific language governing permissions and |
| ** limitations under the License. |
| */ |
| |
| |
| .text |
| .align |
| |
| /* |
| * this version rounds-to-nearest and saturates numbers |
| * outside the range (but not NaNs). |
| */ |
| |
| .global gglFloatToFixed |
| .ent gglFloatToFixed |
| .type gglFloatToFixed, @function |
| gglFloatToFixed: |
| #if !defined(__mips_soft_float) |
| mfc1 $a0,$f12 |
| #endif |
| srl $t0,$a0,31 /* t0 <- sign bit */ |
| srl $t1,$a0,23 |
| andi $t1,$t1,0xff /* get the e */ |
| li $t2,0x8e |
| subu $t1,$t2,$t1 /* t1=127+15-e */ |
| blez $t1,0f /* t1<=0? */ |
| sll $t2,$a0,8 /* mantissa<<8 */ |
| lui $t3,0x8000 |
| or $t2,$t2,$t3 /* add the missing 1 */ |
| subu $t1,$t1,1 |
| srl $v0,$t2,$t1 |
| sltiu $t3,$t1,32 /* t3=1 if t1<32, else t3=0. t1>=32 means the float value is too small. */ |
| andi $t4,$v0,0x1 |
| srl $v0,$v0,1 /* scale to 16.16 */ |
| addu $v0,$v0,$t4 /* round-to-nearest */ |
| subu $t2,$zero,$v0 |
| movn $v0,$t2,$t0 /* if negative? */ |
| or $t1,$a0,$zero /* a0=0? */ |
| movz $v0,$zero,$t1 |
| movz $v0,$zero,$t3 /* t3=0 then res=0 */ |
| jr $ra |
| 0: |
| lui $t1,0x8000 |
| and $v0,$a0,$t1 /* keep only the sign bit */ |
| li $t1,0x7fffffff |
| movz $v0,$t1,$t0 /* positive, maximum value */ |
| jr $ra |
| .end gglFloatToFixed |