summaryrefslogtreecommitdiffstatshomepage
path: root/tests/inlineasm/asmfpsqrt.py
blob: f2c2d3a9540281901228ccd18ba138cfac32a841 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# test vsqrt, vneg
@micropython.asm_thumb      # r0 = -(int)(sqrt(r0)*r1)
def sqrt_test(r0, r1):
    vmov(s1, r0)
    vcvt_f32_s32(s1, s1)
    vsqrt(s1, s1)
    vmov(s2, r1)
    vcvt_f32_s32(s2, s2)
    vmul(s0, s1, s2)
    vneg(s7, s0)
    vcvt_s32_f32(s31, s7)
    vmov(r0, s31)

print(sqrt_test(256, 10))