readspeed.c 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2010-02-10 Bernard first version
  9. * 2020-04-12 Jianjia Ma add msh cmd
  10. */
  11. #include <rtthread.h>
  12. #include <dfs_file.h>
  13. #include <unistd.h>
  14. #include <stdio.h>
  15. #include <sys/stat.h>
  16. #include <sys/statfs.h>
  17. void readspeed(const char* filename, int block_size)
  18. {
  19. int fd;
  20. char *buff_ptr;
  21. rt_size_t total_length;
  22. rt_tick_t tick;
  23. fd = open(filename, 0, O_RDONLY);
  24. if (fd < 0)
  25. {
  26. rt_kprintf("open file:%s failed\n", filename);
  27. return;
  28. }
  29. buff_ptr = rt_malloc(block_size);
  30. if (buff_ptr == RT_NULL)
  31. {
  32. rt_kprintf("no memory\n");
  33. close(fd);
  34. return;
  35. }
  36. tick = rt_tick_get();
  37. total_length = 0;
  38. while (1)
  39. {
  40. int length;
  41. length = read(fd, buff_ptr, block_size);
  42. if (length <= 0) break;
  43. total_length += length;
  44. }
  45. tick = rt_tick_get() - tick;
  46. /* close file and release memory */
  47. close(fd);
  48. rt_free(buff_ptr);
  49. /* calculate read speed */
  50. rt_kprintf("File read speed: %d byte/s\n", total_length /tick * RT_TICK_PER_SECOND);
  51. }
  52. #ifdef RT_USING_FINSH
  53. #include <finsh.h>
  54. FINSH_FUNCTION_EXPORT(readspeed, perform file read test);
  55. static void cmd_readspeed(int argc, char *argv[])
  56. {
  57. char* filename;
  58. int block_size;
  59. if(argc == 3)
  60. {
  61. filename = argv[1];
  62. block_size = atoi(argv[2]);
  63. }
  64. else if(argc == 2)
  65. {
  66. filename = argv[1];
  67. block_size = 512;
  68. }
  69. else
  70. {
  71. rt_kprintf("Usage:\nreadspeed [file_path] [block_size]\n");
  72. rt_kprintf("readspeed [file_path] with default block size 512\n");
  73. return;
  74. }
  75. readspeed(filename, block_size);
  76. }
  77. MSH_CMD_EXPORT_ALIAS(cmd_readspeed, readspeed, test file system read speed);
  78. #endif /* RT_USING_FINSH */