_info 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include "config.h"
  4. /**
  5. * jbitset - variable-length bitset (based on libJudy)
  6. *
  7. * This provides a convenient wrapper for using Judy bitsets; using
  8. * integers or pointers as an index, Judy arrays provide an efficient
  9. * bit array or bit map of variable size.
  10. *
  11. * jbitset.h simply contains wrappers for a size_t-indexed bitset, and
  12. * jbitset_type.h contain a wrapper macro for pointer bitsets.
  13. *
  14. * Example:
  15. * // Simple analysis of one-byte mallocs.
  16. * #include <stdlib.h>
  17. * #include <stdio.h>
  18. * #include <err.h>
  19. * #include <ccan/jbitset/jbitset_type.h>
  20. *
  21. * // Define jbit_char_<op> and jbitset_char, for char * bitset.
  22. * JBIT_DEFINE_TYPE(char, char);
  23. *
  24. * int main(int argc, char *argv[])
  25. * {
  26. * unsigned int i, runs, reuse;
  27. * size_t mindist = -1;
  28. * struct jbitset_char *set = jbit_char_new();
  29. * char *p, *prev;
  30. *
  31. * runs = (argc == 1 ? 1000 : atoi(argv[1]));
  32. * if (!runs)
  33. * errx(1, "Invalid number of allocations '%s'", argv[1]);
  34. *
  35. * for (i = 0; i < runs; i++)
  36. * if (!jbit_char_set(set, malloc(1)))
  37. * errx(1, "same pointer allocated twice!");
  38. *
  39. * // Calculate minimum distance
  40. * prev = jbit_char_first(set)+1;
  41. * for (p = jbit_char_first(set); p; prev = p, p = jbit_char_next(set,p))
  42. * if (p - prev < mindist)
  43. * mindist = p - prev;
  44. *
  45. * // Free them all, see how many we reallocate.
  46. * for (p = jbit_char_first(set); p; p = jbit_char_next(set, p))
  47. * free(p);
  48. * for (reuse = 0, i = 0; i < runs; i++)
  49. * reuse += jbit_char_test(set, malloc(1));
  50. *
  51. * printf("Allocation density (bytes): %zu\n"
  52. * "Minimum inter-pointer distance: %zu\n"
  53. * "Reuse rate: %.0f%%\n",
  54. * (jbit_char_last(set) - jbit_char_first(set)) / runs,
  55. * mindist,
  56. * 100.0 * reuse / runs);
  57. * return 0;
  58. * }
  59. *
  60. * License: LGPL (2 or any later version)
  61. * Author: Rusty Russell <rusty@rustcorp.com.au>
  62. */
  63. int main(int argc, char *argv[])
  64. {
  65. if (argc != 2)
  66. return 1;
  67. if (strcmp(argv[1], "depends") == 0) {
  68. printf("ccan/build_assert\n");
  69. printf("ccan/compiler\n");
  70. printf("Judy\n");
  71. return 0;
  72. }
  73. if (strcmp(argv[1], "libs") == 0) {
  74. printf("Judy\n");
  75. return 0;
  76. }
  77. return 1;
  78. }