regs-mfc-v10.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. *
  4. * Copyright (c) 2017 Samsung Electronics Co., Ltd.
  5. * http://www.samsung.com/
  6. *
  7. * Register definition file for Samsung MFC V10.x Interface (FIMV) driver
  8. *
  9. */
  10. #ifndef _REGS_MFC_V10_H
  11. #define _REGS_MFC_V10_H
  12. #include <linux/sizes.h>
  13. #include "regs-mfc-v8.h"
  14. /* MFCv10 register definitions*/
  15. #define S5P_FIMV_MFC_CLOCK_OFF_V10 0x7120
  16. #define S5P_FIMV_MFC_STATE_V10 0x7124
  17. #define S5P_FIMV_D_STATIC_BUFFER_ADDR_V10 0xF570
  18. #define S5P_FIMV_D_STATIC_BUFFER_SIZE_V10 0xF574
  19. #define S5P_FIMV_E_NUM_T_LAYER_V10 0xFBAC
  20. #define S5P_FIMV_E_HIERARCHICAL_QP_LAYER0_V10 0xFBB0
  21. #define S5P_FIMV_E_HIERARCHICAL_QP_LAYER1_V10 0xFBB4
  22. #define S5P_FIMV_E_HIERARCHICAL_QP_LAYER2_V10 0xFBB8
  23. #define S5P_FIMV_E_HIERARCHICAL_QP_LAYER3_V10 0xFBBC
  24. #define S5P_FIMV_E_HIERARCHICAL_QP_LAYER4_V10 0xFBC0
  25. #define S5P_FIMV_E_HIERARCHICAL_QP_LAYER5_V10 0xFBC4
  26. #define S5P_FIMV_E_HIERARCHICAL_QP_LAYER6_V10 0xFBC8
  27. #define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER0_V10 0xFD18
  28. #define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER1_V10 0xFD1C
  29. #define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER2_V10 0xFD20
  30. #define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER3_V10 0xFD24
  31. #define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER4_V10 0xFD28
  32. #define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER5_V10 0xFD2C
  33. #define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER6_V10 0xFD30
  34. #define S5P_FIMV_E_HEVC_OPTIONS_V10 0xFDD4
  35. #define S5P_FIMV_E_HEVC_REFRESH_PERIOD_V10 0xFDD8
  36. #define S5P_FIMV_E_HEVC_CHROMA_QP_OFFSET_V10 0xFDDC
  37. #define S5P_FIMV_E_HEVC_LF_BETA_OFFSET_DIV2_V10 0xFDE0
  38. #define S5P_FIMV_E_HEVC_LF_TC_OFFSET_DIV2_V10 0xFDE4
  39. #define S5P_FIMV_E_HEVC_NAL_CONTROL_V10 0xFDE8
  40. /* MFCv10 Context buffer sizes */
  41. #define MFC_CTX_BUF_SIZE_V10 (30 * SZ_1K)
  42. #define MFC_H264_DEC_CTX_BUF_SIZE_V10 (2 * SZ_1M)
  43. #define MFC_OTHER_DEC_CTX_BUF_SIZE_V10 (20 * SZ_1K)
  44. #define MFC_H264_ENC_CTX_BUF_SIZE_V10 (100 * SZ_1K)
  45. #define MFC_HEVC_ENC_CTX_BUF_SIZE_V10 (30 * SZ_1K)
  46. #define MFC_OTHER_ENC_CTX_BUF_SIZE_V10 (15 * SZ_1K)
  47. /* MFCv10 variant defines */
  48. #define MAX_FW_SIZE_V10 (SZ_1M)
  49. #define MAX_CPB_SIZE_V10 (3 * SZ_1M)
  50. #define MFC_VERSION_V10 0xA0
  51. #define MFC_NUM_PORTS_V10 1
  52. /* MFCv10 codec defines*/
  53. #define S5P_FIMV_CODEC_HEVC_DEC 17
  54. #define S5P_FIMV_CODEC_VP9_DEC 18
  55. #define S5P_FIMV_CODEC_HEVC_ENC 26
  56. /* Decoder buffer size for MFC v10 */
  57. #define DEC_VP9_STATIC_BUFFER_SIZE 20480
  58. /* Encoder buffer size for MFC v10.0 */
  59. #define ENC_V100_BASE_SIZE(x, y) \
  60. (((x + 3) * (y + 3) * 8) \
  61. + ((y * 64) + 1280) * DIV_ROUND_UP(x, 8))
  62. #define ENC_V100_H264_ME_SIZE(x, y) \
  63. (ENC_V100_BASE_SIZE(x, y) \
  64. + (DIV_ROUND_UP(x * y, 64) * 32))
  65. #define ENC_V100_MPEG4_ME_SIZE(x, y) \
  66. (ENC_V100_BASE_SIZE(x, y) \
  67. + (DIV_ROUND_UP(x * y, 128) * 16))
  68. #define ENC_V100_VP8_ME_SIZE(x, y) \
  69. ENC_V100_BASE_SIZE(x, y)
  70. #define ENC_V100_HEVC_ME_SIZE(x, y) \
  71. (((x + 3) * (y + 3) * 32) \
  72. + ((y * 128) + 1280) * DIV_ROUND_UP(x, 4))
  73. #endif /*_REGS_MFC_V10_H*/