/* * Copyright (c) 2006-2021, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2011-01-02 aozima the first version. * 2011-03-17 aozima fix some bug. * 2011-03-18 aozima to dynamic thread. */ #include #include static rt_uint32_t stop_flag = 0; static rt_thread_t fsrw1_thread = RT_NULL; static rt_thread_t fsrw2_thread = RT_NULL; #define fsrw1_fn "/test1.dat" #define fsrw1_data_len 120 /* Less than 256 */ static void fsrw1_thread_entry(void* parameter) { int fd; int index,length; rt_uint32_t round; rt_uint32_t tick_start,tick_end,read_speed,write_speed; static rt_uint8_t write_data1[fsrw1_data_len]; static rt_uint8_t read_data1[fsrw1_data_len]; round = 1; while(1) { if( stop_flag ) { rt_kprintf("thread fsrw2 error,thread fsrw1 quit!\r\n"); fsrw1_thread = RT_NULL; stop_flag = 0; return; } /* creat file */ fd = open(fsrw1_fn, O_WRONLY | O_CREAT | O_TRUNC, 0); if (fd < 0) { rt_kprintf("fsrw1 open file for write failed\n"); stop_flag = 1; fsrw1_thread = RT_NULL; return; } /* plan write data */ for (index = 0; index < fsrw1_data_len; index ++) { write_data1[index] = index; } /* write 8000 times */ tick_start = rt_tick_get(); for(index=0; index<8000; index++) { length = write(fd, write_data1, fsrw1_data_len); if (length != fsrw1_data_len) { rt_kprintf("fsrw1 write data failed\n"); close(fd); fsrw1_thread = RT_NULL; stop_flag = 1; return; } } tick_end = rt_tick_get(); write_speed = fsrw1_data_len*8000UL*RT_TICK_PER_SECOND/(tick_end-tick_start); /* close file */ close(fd); /* open file read only */ fd = open(fsrw1_fn, O_RDONLY, 0); if (fd < 0) { rt_kprintf("fsrw1 open file for read failed\n"); stop_flag = 1; fsrw1_thread = RT_NULL; return; } /* verify data */ tick_start = rt_tick_get(); for(index=0; index<8000; index++) { rt_uint32_t i; length = read(fd, read_data1, fsrw1_data_len); if (length != fsrw1_data_len) { rt_kprintf("fsrw1 read file failed\r\n"); close(fd); stop_flag = 1; fsrw1_thread = RT_NULL; return; } for(i=0; i FINSH_FUNCTION_EXPORT(fs_test, file system R/W test. e.g: fs_test(3)); #endif