postprocess.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /*
  2. * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
  3. *
  4. * This file is part of FFmpeg.
  5. *
  6. * FFmpeg is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (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
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * 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. #ifndef POSTPROC_POSTPROCESS_H
  21. #define POSTPROC_POSTPROCESS_H
  22. /**
  23. * @file
  24. * @ingroup lpp
  25. * external API header
  26. */
  27. /**
  28. * @defgroup lpp libpostproc
  29. * Video postprocessing library.
  30. *
  31. * @{
  32. */
  33. #include "libpostproc/version_major.h"
  34. #ifndef HAVE_AV_CONFIG_H
  35. /* When included as part of the ffmpeg build, only include the major version
  36. * to avoid unnecessary rebuilds. When included externally, keep including
  37. * the full version information. */
  38. #include "libpostproc/version.h"
  39. #endif
  40. /**
  41. * Return the LIBPOSTPROC_VERSION_INT constant.
  42. */
  43. unsigned postproc_version(void);
  44. /**
  45. * Return the libpostproc build-time configuration.
  46. */
  47. const char *postproc_configuration(void);
  48. /**
  49. * Return the libpostproc license.
  50. */
  51. const char *postproc_license(void);
  52. #define PP_QUALITY_MAX 6
  53. #include <inttypes.h>
  54. typedef void pp_context;
  55. typedef void pp_mode;
  56. extern const char pp_help[]; ///< a simple help text
  57. void pp_postprocess(const uint8_t * src[3], const int srcStride[3],
  58. uint8_t * dst[3], const int dstStride[3],
  59. int horizontalSize, int verticalSize,
  60. const int8_t *QP_store, int QP_stride,
  61. pp_mode *mode, pp_context *ppContext, int pict_type);
  62. /**
  63. * Return a pp_mode or NULL if an error occurred.
  64. *
  65. * @param name the string after "-pp" on the command line
  66. * @param quality a number from 0 to PP_QUALITY_MAX
  67. */
  68. pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality);
  69. void pp_free_mode(pp_mode *mode);
  70. pp_context *pp_get_context(int width, int height, int flags);
  71. void pp_free_context(pp_context *ppContext);
  72. #define PP_CPU_CAPS_MMX 0x80000000
  73. #define PP_CPU_CAPS_MMX2 0x20000000
  74. #define PP_CPU_CAPS_3DNOW 0x40000000
  75. #define PP_CPU_CAPS_ALTIVEC 0x10000000
  76. #define PP_CPU_CAPS_AUTO 0x00080000
  77. #define PP_FORMAT 0x00000008
  78. #define PP_FORMAT_420 (0x00000011|PP_FORMAT)
  79. #define PP_FORMAT_422 (0x00000001|PP_FORMAT)
  80. #define PP_FORMAT_411 (0x00000002|PP_FORMAT)
  81. #define PP_FORMAT_444 (0x00000000|PP_FORMAT)
  82. #define PP_FORMAT_440 (0x00000010|PP_FORMAT)
  83. #define PP_PICT_TYPE_QP2 0x00000010 ///< MPEG2 style QScale
  84. /**
  85. * @}
  86. */
  87. #endif /* POSTPROC_POSTPROCESS_H */