trasher.c 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /*
  2. * Copyright (c) 2007 Michael Niedermayer
  3. *
  4. * This file is part of FFmpeg.
  5. *
  6. * FFmpeg is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * FFmpeg is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with FFmpeg; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  19. */
  20. #include <stdio.h>
  21. #include <stdlib.h>
  22. #include <time.h>
  23. #include <inttypes.h>
  24. int main(int argc, char** argv)
  25. {
  26. FILE *f;
  27. int count, maxburst, length;
  28. if (argc < 4){
  29. printf("USAGE: trasher <filename> <count> <maxburst>\n");
  30. return 1;
  31. }
  32. f= fopen(argv[1], "rb+");
  33. if (!f){
  34. perror(argv[1]);
  35. return 2;
  36. }
  37. count= atoi(argv[2]);
  38. maxburst= atoi(argv[3]);
  39. srandom (time (0));
  40. fseek(f, 0, SEEK_END);
  41. length= ftell(f);
  42. fseek(f, 0, SEEK_SET);
  43. while(count--){
  44. int burst= 1 + random() * (uint64_t) (abs(maxburst)-1) / RAND_MAX;
  45. int pos= random() * (uint64_t) length / RAND_MAX;
  46. fseek(f, pos, SEEK_SET);
  47. if(maxburst<0) burst= -maxburst;
  48. if(pos + burst > length)
  49. continue;
  50. while(burst--){
  51. int val= random() * 256ULL / RAND_MAX;
  52. if(maxburst<0) val=0;
  53. fwrite(&val, 1, 1, f);
  54. }
  55. }
  56. return 0;
  57. }