mpc.h 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /* Copyright 2012-15 Advanced Micro Devices, Inc.
  2. *
  3. * Permission is hereby granted, free of charge, to any person obtaining a
  4. * copy of this software and associated documentation files (the "Software"),
  5. * to deal in the Software without restriction, including without limitation
  6. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  7. * and/or sell copies of the Software, and to permit persons to whom the
  8. * Software is furnished to do so, subject to the following conditions:
  9. *
  10. * The above copyright notice and this permission notice shall be included in
  11. * all copies or substantial portions of the Software.
  12. *
  13. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  14. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  15. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  16. * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
  17. * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
  18. * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
  19. * OTHER DEALINGS IN THE SOFTWARE.
  20. *
  21. * Authors: AMD
  22. *
  23. */
  24. #ifndef __DC_MPCC_H__
  25. #define __DC_MPCC_H__
  26. #include "dc_hw_types.h"
  27. #include "opp.h"
  28. enum mpc_output_csc_mode {
  29. MPC_OUTPUT_CSC_DISABLE = 0,
  30. MPC_OUTPUT_CSC_COEF_A,
  31. MPC_OUTPUT_CSC_COEF_B
  32. };
  33. struct mpcc_cfg {
  34. int dpp_id;
  35. int opp_id;
  36. struct mpc_tree_cfg *tree_cfg;
  37. unsigned int z_index;
  38. struct tg_color black_color;
  39. bool per_pixel_alpha;
  40. bool pre_multiplied_alpha;
  41. };
  42. struct mpc {
  43. const struct mpc_funcs *funcs;
  44. struct dc_context *ctx;
  45. };
  46. struct mpc_funcs {
  47. int (*add)(struct mpc *mpc, struct mpcc_cfg *cfg);
  48. void (*remove)(struct mpc *mpc,
  49. struct mpc_tree_cfg *tree_cfg,
  50. int opp_id,
  51. int mpcc_inst);
  52. void (*wait_for_idle)(struct mpc *mpc, int id);
  53. void (*update_blend_mode)(struct mpc *mpc, struct mpcc_cfg *cfg);
  54. int (*get_opp_id)(struct mpc *mpc, int mpcc_id);
  55. void (*set_output_csc)(struct mpc *mpc,
  56. int opp_id,
  57. const struct out_csc_color_matrix *tbl_entry,
  58. enum mpc_output_csc_mode ocsc_mode);
  59. void (*set_ocsc_default)(struct mpc *mpc,
  60. int opp_id,
  61. enum dc_color_space color_space,
  62. enum mpc_output_csc_mode ocsc_mode);
  63. };
  64. #endif