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# The following comment until the empty line must be a valid YAML document 15b1994897Sopenharmony_ci# containing exact copy of ISA specification assertions relevant to this test. 16b1994897Sopenharmony_ci#--- 17b1994897Sopenharmony_ci# - title: Store to array 18b1994897Sopenharmony_ci# description: > 19b1994897Sopenharmony_ci# Store accumulator content into array slot pointed by index. 20b1994897Sopenharmony_ci# instructions: 21b1994897Sopenharmony_ci# - sig: starr vs1, vs2 22b1994897Sopenharmony_ci# format: [op_vs1_4_vs2_4] 23b1994897Sopenharmony_ci# type: i32 24b1994897Sopenharmony_ci# dtype: none 25b1994897Sopenharmony_ci# etype: i32 26b1994897Sopenharmony_ci# - title: Load from array 27b1994897Sopenharmony_ci# description: > 28b1994897Sopenharmony_ci# Load an element from array using accumulator as an index and puts it into accumulator. 29b1994897Sopenharmony_ci# instructions: 30b1994897Sopenharmony_ci# - sig: ldarr vs 31b1994897Sopenharmony_ci# format: [op_vs_8] 32b1994897Sopenharmony_ci# type: obj 33b1994897Sopenharmony_ci# dtype: i32 34b1994897Sopenharmony_ci# etype: i32 35b1994897Sopenharmony_ci 36b1994897Sopenharmony_ci#assert that operations with array of i32 works fine 37b1994897Sopenharmony_ci#i32 i; 38b1994897Sopenharmony_ci#for(i=0; i<5; i++) array[i]=i; 39b1994897Sopenharmony_ci#for(i=4; i>=0; i--) assert_eq(i, array[i]); 40b1994897Sopenharmony_ci 41b1994897Sopenharmony_ci.function i32 main(){ 42b1994897Sopenharmony_ci movi v0, 5 43b1994897Sopenharmony_ci newarr v1, v0, i32[] 44b1994897Sopenharmony_ci movi v2, 0 45b1994897Sopenharmony_ci ldai 0 46b1994897Sopenharmony_ciloop: 47b1994897Sopenharmony_ci jeq v0, loop_exit 48b1994897Sopenharmony_ci starr v1, v2 49b1994897Sopenharmony_ci inci v2, 1 50b1994897Sopenharmony_ci lda v2 51b1994897Sopenharmony_ci jmp loop 52b1994897Sopenharmony_ciloop_exit: 53b1994897Sopenharmony_ci subi 1 54b1994897Sopenharmony_ci sta v2 55b1994897Sopenharmony_ciloop2: 56b1994897Sopenharmony_ci jltz loop2_exit 57b1994897Sopenharmony_ci ldarr v1 58b1994897Sopenharmony_ci jne v2, exit_failure 59b1994897Sopenharmony_ci inci v2, -1 60b1994897Sopenharmony_ci lda v2 61b1994897Sopenharmony_ci jmp loop2 62b1994897Sopenharmony_ciloop2_exit: 63b1994897Sopenharmony_ci ldai 0 64b1994897Sopenharmony_ci return 65b1994897Sopenharmony_ciexit_failure: 66b1994897Sopenharmony_ci ldai 1 67b1994897Sopenharmony_ci return 68b1994897Sopenharmony_ci} 69b1994897Sopenharmony_ci 70