debug.h 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #ifndef _PCILIB_DEBUG_H
  2. #define _PCILIB_DEBUG_H
  3. #include <stdarg.h>
  4. #include <pcilib/env.h>
  5. #include <pcilib/error.h>
  6. #define PCILIB_DEBUG
  7. #ifdef PCILIB_DEBUG
  8. # define PCILIB_DEBUG_DMA
  9. # define PCILIB_DEBUG_MISSING_EVENTS
  10. # define PCILIB_DEBUG_VIEWS
  11. #endif /* PCILIB_DEBUG */
  12. #ifdef PCILIB_DEBUG_DMA
  13. # define PCILIB_DEBUG_DMA_MESSAGE(function, ...) if (pcilib_getenv(function##_ENV, #function)) { pcilib_debug_message (#function, __FILE__, __LINE__, __VA_ARGS__); }
  14. # define PCILIB_DEBUG_DMA_BUFFER(function, ...) if (pcilib_getenv(function##_ENV, #function)) { pcilib_debug_data_buffer (#function, __VA_ARGS__); }
  15. #else /* PCILIB_DEBUG_DMA */
  16. # define PCILIB_DEBUG_DMA_MESSAGE(function, ...)
  17. # define PCILIB_DEBUG_DMA_BUFFER(function, ...)
  18. #endif /* PCILIB_DEBUG_DMA */
  19. #ifdef PCILIB_DEBUG_MISSING_EVENTS
  20. # define PCILIB_DEBUG_MISSING_EVENTS_MESSAGE(function, ...) if (pcilib_getenv(function##_ENV, #function)) { pcilib_debug_message (#function, __FILE__, __LINE__, __VA_ARGS__); }
  21. # define PCILIB_DEBUG_MISSING_EVENTS_BUFFER(function, ...) if (pcilib_getenv(function##_ENV #function)) { pcilib_debug_data_buffer (#function, __VA_ARGS__); }
  22. #else /* PCILIB_DEBUG_MISSING_EVENTS */
  23. # define PCILIB_DEBUG_MISSING_EVENTS_MESSAGE(function, ...)
  24. # define PCILIB_DEBUG_MISSING_EVENTS_BUFFER(function, ...)
  25. #endif /* PCILIB_DEBUG_MISSING_EVENTS */
  26. #ifdef PCILIB_DEBUG_VIEWS
  27. # define PCILIB_DEBUG_VIEWS_MESSAGE(function, ...) if (pcilib_getenv(function##_ENV, #function)) { pcilib_debug_message (#function, __FILE__, __LINE__, __VA_ARGS__); }
  28. # define PCILIB_DEBUG_VIEWS_BUFFER(function, ...) if (pcilib_getenv(function##_ENV #function)) { pcilib_debug_data_buffer (#function, __VA_ARGS__); }
  29. #else /* PCILIB_DEBUG_VIEWS */
  30. # define PCILIB_DEBUG_VIEWS_MESSAGE(function, ...)
  31. # define PCILIB_DEBUG_VIEWS_BUFFER(function, ...)
  32. #endif /* PCILIB_DEBUG_VIEWS */
  33. #define pcilib_debug(function, ...) \
  34. PCILIB_DEBUG_##function##_MESSAGE(PCILIB_DEBUG_##function, PCILIB_LOG_DEFAULT, __VA_ARGS__)
  35. #define pcilib_debug_buffer(function, ...) \
  36. PCILIB_DEBUG_##function##_BUFFER(PCILIB_DEBUG_##function, __VA_ARGS__)
  37. typedef enum {
  38. PCILIB_DEBUG_BUFFER_APPEND = 1,
  39. PCILIB_DEBUG_BUFFER_MKDIR = 2
  40. } pcilib_debug_buffer_flags_t;
  41. #ifdef __cplusplus
  42. extern "C" {
  43. #endif
  44. void pcilib_debug_message(const char *function, const char *file, int line, pcilib_log_flags_t flags, const char *format, ...);
  45. void pcilib_debug_data_buffer(const char *function, size_t size, void *buffer, pcilib_debug_buffer_flags_t flags, const char *file, ...);
  46. #ifdef __cplusplus
  47. }
  48. #endif
  49. #endif /* _PCILIB_DEBUG_H */