1b1994897Sopenharmony_ci# Copyright (c) 2021-2022 Huawei Device Co., Ltd.
2b1994897Sopenharmony_ci# Licensed under the Apache License, Version 2.0 (the "License");
3b1994897Sopenharmony_ci# you may not use this file except in compliance with the License.
4b1994897Sopenharmony_ci# You may obtain a copy of the License at
5b1994897Sopenharmony_ci#
6b1994897Sopenharmony_ci# http://www.apache.org/licenses/LICENSE-2.0
7b1994897Sopenharmony_ci#
8b1994897Sopenharmony_ci# Unless required by applicable law or agreed to in writing, software
9b1994897Sopenharmony_ci# distributed under the License is distributed on an "AS IS" BASIS,
10b1994897Sopenharmony_ci# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11b1994897Sopenharmony_ci# See the License for the specific language governing permissions and
12b1994897Sopenharmony_ci# limitations under the License.
13b1994897Sopenharmony_ci
14b1994897Sopenharmony_ci#assert that operations with array of f32 works fine
15b1994897Sopenharmony_ci#f32[] array = [0, 1, 2, 3, 4, 5, 6];
16b1994897Sopenharmony_ci#for(i=6; i>=0; i--) assert_eq(i, array[i]);
17b1994897Sopenharmony_ci
18b1994897Sopenharmony_ci.array array_f32 f32 7 {0 1 2 3 4 5 6}
19b1994897Sopenharmony_ci
20b1994897Sopenharmony_ci.function i32 main(){
21b1994897Sopenharmony_ci    lda.const v0, array_f32
22b1994897Sopenharmony_ci    movi v1, 6
23b1994897Sopenharmony_ci    ldai 6
24b1994897Sopenharmony_ciloop:
25b1994897Sopenharmony_ci    jltz loop_exit
26b1994897Sopenharmony_ci    lda v1
27b1994897Sopenharmony_ci    i32tof32
28b1994897Sopenharmony_ci    sta v2
29b1994897Sopenharmony_ci    lda v1
30b1994897Sopenharmony_ci    fldarr.32 v0
31b1994897Sopenharmony_ci    fsub2 v2
32b1994897Sopenharmony_ci    sta v2
33b1994897Sopenharmony_ci    call.short abs, v2, v2
34b1994897Sopenharmony_ci    sta v2
35b1994897Sopenharmony_ci    fldai 1e-6
36b1994897Sopenharmony_ci    fcmpl v2
37b1994897Sopenharmony_ci    jlez exit_failure
38b1994897Sopenharmony_ci    inci v1, -1
39b1994897Sopenharmony_ci    lda v1
40b1994897Sopenharmony_ci    jmp loop
41b1994897Sopenharmony_ciloop_exit:
42b1994897Sopenharmony_ci    ldai 0
43b1994897Sopenharmony_ci    return
44b1994897Sopenharmony_ciexit_failure:
45b1994897Sopenharmony_ci    ldai 1
46b1994897Sopenharmony_ci    return
47b1994897Sopenharmony_ci}
48b1994897Sopenharmony_ci
49b1994897Sopenharmony_ci.function f32 abs(f32 a0){
50b1994897Sopenharmony_ci    fldai 0.0
51b1994897Sopenharmony_ci    fcmpl a0
52b1994897Sopenharmony_ci    jlez label
53b1994897Sopenharmony_ci    lda a0
54b1994897Sopenharmony_ci    fneg
55b1994897Sopenharmony_ci    return
56b1994897Sopenharmony_cilabel:
57b1994897Sopenharmony_ci    lda a0
58b1994897Sopenharmony_ci    return
59b1994897Sopenharmony_ci}