xref: /linux/drivers/gpu/drm/amd/display/dc/dc_plane.h (revision e7e86d7697c6ed1dbbde18d7185c35b6967945ed)
1 /*
2  * Copyright 2023 Advanced Micro Devices, Inc.
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included in
12  * all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20  * OTHER DEALINGS IN THE SOFTWARE.
21  *
22  * Authors: AMD
23  *
24  */
25 
26 #ifndef _DC_PLANE_H_
27 #define _DC_PLANE_H_
28 
29 #include "dc_hw_types.h"
30 
31 union dc_plane_status_update_flags {
32 	struct {
33 		uint32_t address : 1;
34 	} bits;
35 	uint32_t raw;
36 };
37 
38 struct dc_plane_state *dc_create_plane_state(const struct dc *dc);
39 const struct dc_plane_status *dc_plane_get_status(
40 		const struct dc_plane_state *plane_state,
41 		union dc_plane_status_update_flags flags);
42 void dc_plane_state_retain(struct dc_plane_state *plane_state);
43 void dc_plane_state_release(struct dc_plane_state *plane_state);
44 
45 void dc_plane_force_dcc_and_tiling_disable(struct dc_plane_state *plane_state,
46 					   bool clear_tiling);
47 
48 
49 void dc_plane_copy_config(struct dc_plane_state *dst, const struct dc_plane_state *src);
50 
51 #endif /* _DC_PLANE_H_ */
52