73 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * File      : writespeed.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 writespeed(const char* filename, int total_length, int block_size)
 | |
| {
 | |
|     int fd, index, length;
 | |
|     char *buff_ptr;
 | |
|     rt_tick_t tick;
 | |
| 
 | |
|     fd = open(filename, O_WRONLY | O_CREAT | O_TRUNC, 0);
 | |
|     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;
 | |
|     }
 | |
| 
 | |
| 	/* prepare write data */
 | |
| 	for (index = 0; index < block_size; index++)
 | |
| 	{
 | |
| 		buff_ptr[index] = index;
 | |
| 	}
 | |
| 	index = 0;
 | |
| 
 | |
| 	/* get the beginning tick */
 | |
|     tick = rt_tick_get();
 | |
| 	while (index < total_length / block_size)
 | |
| 	{
 | |
| 		length = write(fd, buff_ptr, block_size);
 | |
| 		if (length != block_size)
 | |
| 		{
 | |
| 			rt_kprintf("write failed\n");
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		index ++;
 | |
| 	}
 | |
|     tick = rt_tick_get() - tick;
 | |
| 
 | |
| 	/* close file and release memory */
 | |
|     close(fd);
 | |
| 	rt_free(buff_ptr);
 | |
| 
 | |
|     /* calculate write speed */
 | |
|     rt_kprintf("File write speed: %d byte/s\n", total_length / tick * RT_TICK_PER_SECOND);
 | |
| }
 | |
| 
 | |
| #ifdef RT_USING_FINSH
 | |
| #include <finsh.h>
 | |
| FINSH_FUNCTION_EXPORT(writespeed, perform file write test);
 | |
| #endif
 |