65 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * File      : readspeed.c
 | 
						|
 * This file is part of RT-TestCase in RT-Thread RTOS
 | 
						|
 * COPYRIGHT (C) 2010, RT-Thread Development Team
 | 
						|
 *
 | 
						|
 * The license and distribution terms for this file may be
 | 
						|
 * found in the file LICENSE in this distribution or at
 | 
						|
 * http://www.rt-thread.org/license/LICENSE
 | 
						|
 *
 | 
						|
 * Change Logs:
 | 
						|
 * Date           Author       Notes
 | 
						|
 * 2010-02-10     Bernard      first version
 | 
						|
 */
 | 
						|
 | 
						|
#include <rtthread.h>
 | 
						|
#include <dfs_posix.h>
 | 
						|
 | 
						|
void readspeed(const char* filename, int block_size)
 | 
						|
{
 | 
						|
    int fd;
 | 
						|
    char *buff_ptr;
 | 
						|
    rt_size_t total_length;
 | 
						|
    rt_tick_t tick;
 | 
						|
 | 
						|
    fd = open(filename, 0, O_RDONLY);
 | 
						|
    if (fd < 0)
 | 
						|
    {
 | 
						|
        rt_kprintf("open file:%s failed\n", filename);
 | 
						|
        return;
 | 
						|
    }
 | 
						|
 | 
						|
    buff_ptr = rt_malloc(block_size);
 | 
						|
    if (buff_ptr == RT_NULL)
 | 
						|
    {
 | 
						|
        rt_kprintf("no memory\n");
 | 
						|
        close(fd);
 | 
						|
 | 
						|
        return;
 | 
						|
    }
 | 
						|
 | 
						|
    tick = rt_tick_get();
 | 
						|
    total_length = 0;
 | 
						|
    while (1)
 | 
						|
    {
 | 
						|
        int length;
 | 
						|
        length = read(fd, buff_ptr, block_size);
 | 
						|
 | 
						|
        if (length <= 0) break;
 | 
						|
        total_length += length;
 | 
						|
    }
 | 
						|
    tick = rt_tick_get() - tick;
 | 
						|
 | 
						|
	/* close file and release memory */
 | 
						|
    close(fd);
 | 
						|
	rt_free(buff_ptr);
 | 
						|
 | 
						|
    /* calculate read speed */
 | 
						|
    rt_kprintf("File read speed: %d byte/s\n", total_length /tick * RT_TICK_PER_SECOND);
 | 
						|
}
 | 
						|
 | 
						|
#ifdef RT_USING_FINSH
 | 
						|
#include <finsh.h>
 | 
						|
FINSH_FUNCTION_EXPORT(readspeed, perform file read test);
 | 
						|
#endif
 |