debug.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. #ifndef _PCILIB_DEBUG_H
  2. #define _PCILIB_DEBUG_H
  3. #include <stdarg.h>
  4. #include <pcilib/env.h>
  5. #define PCILIB_DEBUG
  6. #ifdef PCILIB_DEBUG
  7. # define PCILIB_DEBUG_DMA
  8. # define PCILIB_DEBUG_MISSING_EVENTS
  9. #endif /* PCILIB_DEBUG */
  10. #ifdef PCILIB_DEBUG_DMA
  11. # define PCILIB_DEBUG_DMA_MESSAGE(function, ...) if (pcilib_getenv(function##_ENV, #function)) { pcilib_debug_message (#function, __FILE__, __LINE__, __VA_ARGS__); }
  12. # define PCILIB_DEBUG_DMA_BUFFER(function, ...) if (pcilib_getenv(function##_ENV, #function)) { pcilib_debug_data_buffer (#function, __VA_ARGS__); }
  13. #else /* PCILIB_DEBUG_DMA */
  14. # define PCILIB_DEBUG_DMA_MESSAGE(function, ...)
  15. # define PCILIB_DEBUG_DMA_BUFFER(function, ...)
  16. #endif /* PCILIB_DEBUG_DMA */
  17. #ifdef PCILIB_DEBUG_MISSING_EVENTS
  18. # define PCILIB_DEBUG_MISSING_EVENTS_MESSAGE(function, ...) if (pcilib_getenv(function##_ENV, #function)) { pcilib_debug_message (#function, __FILE__, __LINE__, __VA_ARGS__); }
  19. # define PCILIB_DEBUG_MISSING_EVENTS_BUFFER(function, ...) if (pcilib_getenv(function##_ENV #function)) { pcilib_debug_data_buffer (#function, __VA_ARGS__); }
  20. #else /* PCILIB_DEBUG_MISSING_EVENTS */
  21. # define PCILIB_DEBUG_MISSING_EVENTS_MESSAGE(function, ...)
  22. # define PCILIB_DEBUG_MISSING_EVENTS_BUFFER(function, ...)
  23. #endif /* PCILIB_DEBUG_MISSING_EVENTS */
  24. #define pcilib_debug(function, ...) \
  25. PCILIB_DEBUG_##function##_MESSAGE(PCILIB_DEBUG_##function, PCILIB_LOG_DEFAULT, __VA_ARGS__)
  26. #define pcilib_debug_buffer(function, ...) \
  27. PCILIB_DEBUG_##function##_BUFFER(PCILIB_DEBUG_##function, __VA_ARGS__)
  28. typedef enum {
  29. PCILIB_DEBUG_BUFFER_APPEND = 1,
  30. PCILIB_DEBUG_BUFFER_MKDIR = 2
  31. } pcilib_debug_buffer_flags_t;
  32. void pcilib_debug_message(const char *function, const char *file, int line, pcilib_log_flags_t flags, const char *format, ...);
  33. void pcilib_debug_data_buffer(const char *function, size_t size, void *buffer, pcilib_debug_buffer_flags_t flags, const char *file, ...);
  34. #endif /* _PCILIB_DEBUG_H */