From 7af3914228edbda49ef1946c5efdf1bf8127314d Mon Sep 17 00:00:00 2001 From: wuyangyong Date: Sun, 9 Oct 2011 16:14:45 +0000 Subject: [PATCH] add calculate_speed_print for device_test git-svn-id: https://rt-thread.googlecode.com/svn/trunk@1747 bbd45198-f89e-11dd-88c7-29a3b14d5316 --- examples/test/device_test.c | 628 +++++++++++++++++++----------------- 1 file changed, 327 insertions(+), 301 deletions(-) diff --git a/examples/test/device_test.c b/examples/test/device_test.c index 153b9714ec..32094aee54 100644 --- a/examples/test/device_test.c +++ b/examples/test/device_test.c @@ -1,301 +1,327 @@ -/* - * File : device_test.c - * This file is part of RT-Thread RTOS - * COPYRIGHT (C) 2011, 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://openlab.rt-thread.com/license/LICENSE. - * - * Change Logs: - * Date Author Notes - * 2011-01-01 aozima the first version - */ - -#include - -static rt_err_t _block_device_test(rt_device_t device) -{ - rt_err_t result; - struct rt_device_blk_geometry geometry; - rt_uint8_t * read_buffer = RT_NULL; - rt_uint8_t * write_buffer = RT_NULL; - - rt_kprintf("\r\n"); - - if( (device->flag & RT_DEVICE_FLAG_RDWR) == RT_DEVICE_FLAG_RDWR ) - { - // device can read and write. - // step 1: open device - result = device->open(device,RT_DEVICE_FLAG_RDWR); - if( result == RT_EOK ) - { - device->open_flag |= RT_DEVICE_OFLAG_RDWR | RT_DEVICE_OFLAG_OPEN; - } - else - { - return result; - } - - // step 2: get device info - rt_memset(&geometry, 0, sizeof(geometry)); - result = rt_device_control(device, RT_DEVICE_CTRL_BLK_GETGEOME, &geometry); - if( result != RT_EOK ) - { - rt_kprintf("device : %s cmd RT_DEVICE_CTRL_BLK_GETGEOME failed.\r\n"); - return result; - } - rt_kprintf("device info:\r\n"); - rt_kprintf("sector size : %d byte\r\n",geometry.bytes_per_sector); - rt_kprintf("sector count : %d \r\n",geometry.sector_count); - rt_kprintf("block size : %d byte\r\n",geometry.block_size); - - rt_kprintf("\r\n"); - read_buffer = rt_malloc(geometry.bytes_per_sector); - if( read_buffer == RT_NULL ) - { - rt_kprintf("no memory for read_buffer!\r\n"); - goto __return; - } - write_buffer = rt_malloc(geometry.bytes_per_sector); - if( write_buffer == RT_NULL ) - { - rt_kprintf("no memory for write_buffer!\r\n"); - goto __return; - } - - //step 3: I/O R/W test - { - rt_uint32_t i,err_count,sector_no; - rt_uint8_t * data_point; - - // the first sector - sector_no = 0; - data_point = write_buffer; - *data_point++ = (rt_uint8_t)sector_no; - for(i=1; iwrite(device,sector_no,write_buffer,1); - if( i != 1 ) - { - rt_kprintf("write device :%s ",device->parent.name); - rt_kprintf("the first sector failed.\r\n"); - goto __return; - } - i = device->read(device,sector_no,read_buffer,1); - if( i != 1 ) - { - rt_kprintf("read device :%s ",device->parent.name); - rt_kprintf("the first sector failed.\r\n"); - goto __return; - } - err_count = 0; - data_point = read_buffer; - if( (*data_point++) != (rt_uint8_t)sector_no) - { - err_count++; - } - for(i=1; i 0 ) - { - rt_kprintf("verify device :%s ",device->parent.name); - rt_kprintf("the first sector failed.\r\n"); - goto __return; - } - // the second sector - sector_no = 1; - data_point = write_buffer; - *data_point++ = (rt_uint8_t)sector_no; - for(i=1; iwrite(device,sector_no,write_buffer,1); - if( i != 1 ) - { - rt_kprintf("write device :%s ",device->parent.name); - rt_kprintf("the second sector failed.\r\n"); - goto __return; - } - i = device->read(device,sector_no,read_buffer,1); - if( i != 1 ) - { - rt_kprintf("read device :%s ",device->parent.name); - rt_kprintf("the second sector failed.\r\n"); - goto __return; - } - err_count = 0; - data_point = read_buffer; - if( (*data_point++) != (rt_uint8_t)sector_no) - { - err_count++; - } - for(i=1; i 0 ) - { - rt_kprintf("verify device :%s ",device->parent.name); - rt_kprintf("the second sector failed.\r\n"); - goto __return; - } - // the end sector - sector_no = geometry.sector_count-1; - data_point = write_buffer; - *data_point++ = (rt_uint8_t)sector_no; - for(i=1; iwrite(device,sector_no,write_buffer,1); - if( i != 1 ) - { - rt_kprintf("write device :%s ",device->parent.name); - rt_kprintf("the end sector failed.\r\n"); - goto __return; - } - i = device->read(device,sector_no,read_buffer,1); - if( i != 1 ) - { - rt_kprintf("read device :%s ",device->parent.name); - rt_kprintf("the end sector failed.\r\n"); - goto __return; - } - err_count = 0; - data_point = read_buffer; - if( (*data_point++) != (rt_uint8_t)sector_no) - { - err_count++; - } - for(i=1; i 0 ) - { - rt_kprintf("verify device :%s ",device->parent.name); - rt_kprintf("the end sector failed.\r\n"); - goto __return; - } - rt_kprintf("device I/O R/W test pass!\r\n"); - - }//step 3: I/O R/W test - - // step 4: speed test - { - rt_uint32_t tick_start,tick_end; - rt_uint32_t i; - - rt_kprintf("\r\n"); - rt_kprintf("device I/O speed test.\r\n"); - rt_kprintf("RT_TICK_PER_SECOND:%d\r\n",RT_TICK_PER_SECOND); - - if( geometry.sector_count < 10 ) - { - rt_kprintf("device sector_count < 10,speed test abort!\r\n"); - } - else - { - // sign sector read - tick_start = rt_tick_get(); - for(i=0; i<200; i++) - { - device->read(device,i%10,read_buffer,1); - } - tick_end = rt_tick_get(); - rt_kprintf("read 200 sector from %d to %d,",tick_start,tick_end); - rt_kprintf("%d byte/s\r\n",(geometry.bytes_per_sector*200UL*RT_TICK_PER_SECOND)/(tick_end-tick_start) ); - - // sign sector write - tick_start = rt_tick_get(); - for(i=0; i<200; i++) - { - device->write(device,i%10,read_buffer,1); - } - tick_end = rt_tick_get(); - rt_kprintf("write 200 sector from %d to %d,",tick_start,tick_end); - rt_kprintf("%d byte/s\r\n",(geometry.bytes_per_sector*200UL*RT_TICK_PER_SECOND)/(tick_end-tick_start) ); - } - }// step 4: speed test - - return RT_EOK; - }// device can read and write. - else - { - // device read only - return RT_EOK; - }// device read only - -__return: - if( read_buffer != RT_NULL ) - { - rt_free(read_buffer); - } - if( write_buffer != RT_NULL ) - { - rt_free(write_buffer); - } - return RT_ERROR; -} - -int device_test(const char * device_name) -{ - rt_device_t device = RT_NULL; - - // step 1:find device - device = rt_device_find(device_name); - if( device == RT_NULL) - { - rt_kprintf("device %s: not found!\r\n"); - return RT_ERROR; - } - - // step 2:init device - if (!(device->flag & RT_DEVICE_FLAG_ACTIVATED)) - { - rt_err_t result; - result = device->init(device); - if (result != RT_EOK) - { - rt_kprintf("To initialize device:%s failed. The error code is %d\r\n", - device->parent.name, result); - return result; - } - else - { - device->flag |= RT_DEVICE_FLAG_ACTIVATED; - } - } - - // step 3: device test - switch( device->type ) - { - case RT_Device_Class_Block : - rt_kprintf("block device!\r\n"); - return _block_device_test(device); - default: - rt_kprintf("unkown device type : %02X",device->type); - return RT_ERROR; - } -} - -#ifdef RT_USING_FINSH -#include -FINSH_FUNCTION_EXPORT(device_test, e.g:device_test("sd0")); -#endif - +/* + * File : device_test.c + * This file is part of RT-Thread RTOS + * COPYRIGHT (C) 2011, 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://openlab.rt-thread.com/license/LICENSE. + * + * Change Logs: + * Date Author Notes + * 2011-01-01 aozima the first version + */ + +#include + +/* calculate speed */ +static void calculate_speed_print(rt_uint32_t speed) +{ + rt_uint32_t k,m; + + k = speed/1024UL; + if( k ) + { + m = k/1024UL; + if( m ) + { + rt_kprintf("%d.%dMbyte/s",m,k%1024UL*100/1024UL); + } + else + { + rt_kprintf("%d.%dKbyte/s",k,speed%1024UL*100/1024UL); + } + } + else + { + rt_kprintf("%dbyte/s",speed); + } +} + +static rt_err_t _block_device_test(rt_device_t device) +{ + rt_err_t result; + struct rt_device_blk_geometry geometry; + rt_uint8_t * read_buffer = RT_NULL; + rt_uint8_t * write_buffer = RT_NULL; + + rt_kprintf("\r\n"); + + if( (device->flag & RT_DEVICE_FLAG_RDWR) == RT_DEVICE_FLAG_RDWR ) + { + // device can read and write. + // step 1: open device + result = device->open(device,RT_DEVICE_FLAG_RDWR); + if( result == RT_EOK ) + { + device->open_flag |= RT_DEVICE_OFLAG_RDWR | RT_DEVICE_OFLAG_OPEN; + } + else + { + return result; + } + + // step 2: get device info + rt_memset(&geometry, 0, sizeof(geometry)); + result = rt_device_control(device, RT_DEVICE_CTRL_BLK_GETGEOME, &geometry); + if( result != RT_EOK ) + { + rt_kprintf("device : %s cmd RT_DEVICE_CTRL_BLK_GETGEOME failed.\r\n"); + return result; + } + rt_kprintf("device info:\r\n"); + rt_kprintf("sector size : %d byte\r\n",geometry.bytes_per_sector); + rt_kprintf("sector count : %d \r\n",geometry.sector_count); + rt_kprintf("block size : %d byte\r\n",geometry.block_size); + + rt_kprintf("\r\n"); + read_buffer = rt_malloc(geometry.bytes_per_sector); + if( read_buffer == RT_NULL ) + { + rt_kprintf("no memory for read_buffer!\r\n"); + goto __return; + } + write_buffer = rt_malloc(geometry.bytes_per_sector); + if( write_buffer == RT_NULL ) + { + rt_kprintf("no memory for write_buffer!\r\n"); + goto __return; + } + + //step 3: I/O R/W test + { + rt_uint32_t i,err_count,sector_no; + rt_uint8_t * data_point; + + // the first sector + sector_no = 0; + data_point = write_buffer; + *data_point++ = (rt_uint8_t)sector_no; + for(i=1; iwrite(device,sector_no,write_buffer,1); + if( i != 1 ) + { + rt_kprintf("write device :%s ",device->parent.name); + rt_kprintf("the first sector failed.\r\n"); + goto __return; + } + i = device->read(device,sector_no,read_buffer,1); + if( i != 1 ) + { + rt_kprintf("read device :%s ",device->parent.name); + rt_kprintf("the first sector failed.\r\n"); + goto __return; + } + err_count = 0; + data_point = read_buffer; + if( (*data_point++) != (rt_uint8_t)sector_no) + { + err_count++; + } + for(i=1; i 0 ) + { + rt_kprintf("verify device :%s ",device->parent.name); + rt_kprintf("the first sector failed.\r\n"); + goto __return; + } + // the second sector + sector_no = 1; + data_point = write_buffer; + *data_point++ = (rt_uint8_t)sector_no; + for(i=1; iwrite(device,sector_no,write_buffer,1); + if( i != 1 ) + { + rt_kprintf("write device :%s ",device->parent.name); + rt_kprintf("the second sector failed.\r\n"); + goto __return; + } + i = device->read(device,sector_no,read_buffer,1); + if( i != 1 ) + { + rt_kprintf("read device :%s ",device->parent.name); + rt_kprintf("the second sector failed.\r\n"); + goto __return; + } + err_count = 0; + data_point = read_buffer; + if( (*data_point++) != (rt_uint8_t)sector_no) + { + err_count++; + } + for(i=1; i 0 ) + { + rt_kprintf("verify device :%s ",device->parent.name); + rt_kprintf("the second sector failed.\r\n"); + goto __return; + } + // the end sector + sector_no = geometry.sector_count-1; + data_point = write_buffer; + *data_point++ = (rt_uint8_t)sector_no; + for(i=1; iwrite(device,sector_no,write_buffer,1); + if( i != 1 ) + { + rt_kprintf("write device :%s ",device->parent.name); + rt_kprintf("the end sector failed.\r\n"); + goto __return; + } + i = device->read(device,sector_no,read_buffer,1); + if( i != 1 ) + { + rt_kprintf("read device :%s ",device->parent.name); + rt_kprintf("the end sector failed.\r\n"); + goto __return; + } + err_count = 0; + data_point = read_buffer; + if( (*data_point++) != (rt_uint8_t)sector_no) + { + err_count++; + } + for(i=1; i 0 ) + { + rt_kprintf("verify device :%s ",device->parent.name); + rt_kprintf("the end sector failed.\r\n"); + goto __return; + } + rt_kprintf("device I/O R/W test pass!\r\n"); + + }//step 3: I/O R/W test + + // step 4: speed test + { + rt_uint32_t tick_start,tick_end; + rt_uint32_t i; + + rt_kprintf("\r\n"); + rt_kprintf("device I/O speed test.\r\n"); + rt_kprintf("RT_TICK_PER_SECOND:%d\r\n",RT_TICK_PER_SECOND); + + if( geometry.sector_count < 10 ) + { + rt_kprintf("device sector_count < 10,speed test abort!\r\n"); + } + else + { + // sign sector read + tick_start = rt_tick_get(); + for(i=0; i<200; i++) + { + device->read(device,i%10,read_buffer,1); + } + tick_end = rt_tick_get(); + rt_kprintf("read 200 sector from %d to %d, ",tick_start,tick_end); + calculate_speed_print( (geometry.bytes_per_sector*200UL*RT_TICK_PER_SECOND)/(tick_end-tick_start) ); + rt_kprintf("\r\n"); + + // sign sector write + tick_start = rt_tick_get(); + for(i=0; i<200; i++) + { + device->write(device,i%10,read_buffer,1); + } + tick_end = rt_tick_get(); + rt_kprintf("write 200 sector from %d to %d, ",tick_start,tick_end); + calculate_speed_print( (geometry.bytes_per_sector*200UL*RT_TICK_PER_SECOND)/(tick_end-tick_start) ); + rt_kprintf("\r\n"); + } + }// step 4: speed test + + return RT_EOK; + }// device can read and write. + else + { + // device read only + return RT_EOK; + }// device read only + +__return: + if( read_buffer != RT_NULL ) + { + rt_free(read_buffer); + } + if( write_buffer != RT_NULL ) + { + rt_free(write_buffer); + } + return RT_ERROR; +} + +int device_test(const char * device_name) +{ + rt_device_t device = RT_NULL; + + // step 1:find device + device = rt_device_find(device_name); + if( device == RT_NULL) + { + rt_kprintf("device %s: not found!\r\n"); + return RT_ERROR; + } + + // step 2:init device + if (!(device->flag & RT_DEVICE_FLAG_ACTIVATED)) + { + rt_err_t result; + result = device->init(device); + if (result != RT_EOK) + { + rt_kprintf("To initialize device:%s failed. The error code is %d\r\n", + device->parent.name, result); + return result; + } + else + { + device->flag |= RT_DEVICE_FLAG_ACTIVATED; + } + } + + // step 3: device test + switch( device->type ) + { + case RT_Device_Class_Block : + rt_kprintf("block device!\r\n"); + return _block_device_test(device); + default: + rt_kprintf("unkown device type : %02X",device->type); + return RT_ERROR; + } +} + +#ifdef RT_USING_FINSH +#include +FINSH_FUNCTION_EXPORT(device_test, e.g:device_test("sd0")); +#endif + -- GitLab