1473683a0SRodrigo Siqueira /* SPDX-License-Identifier: MIT */ 2473683a0SRodrigo Siqueira /* 3473683a0SRodrigo Siqueira * Copyright 2022 Advanced Micro Devices, Inc. 4473683a0SRodrigo Siqueira * 5473683a0SRodrigo Siqueira * Permission is hereby granted, free of charge, to any person obtaining a 6473683a0SRodrigo Siqueira * copy of this software and associated documentation files (the "Software"), 7473683a0SRodrigo Siqueira * to deal in the Software without restriction, including without limitation 8473683a0SRodrigo Siqueira * the rights to use, copy, modify, merge, publish, distribute, sublicense, 9473683a0SRodrigo Siqueira * and/or sell copies of the Software, and to permit persons to whom the 10473683a0SRodrigo Siqueira * Software is furnished to do so, subject to the following conditions: 11473683a0SRodrigo Siqueira * 12473683a0SRodrigo Siqueira * The above copyright notice and this permission notice shall be included in 13473683a0SRodrigo Siqueira * all copies or substantial portions of the Software. 14473683a0SRodrigo Siqueira * 15473683a0SRodrigo Siqueira * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16473683a0SRodrigo Siqueira * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17473683a0SRodrigo Siqueira * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18473683a0SRodrigo Siqueira * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 19473683a0SRodrigo Siqueira * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 20473683a0SRodrigo Siqueira * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 21473683a0SRodrigo Siqueira * OTHER DEALINGS IN THE SOFTWARE. 22473683a0SRodrigo Siqueira * 23473683a0SRodrigo Siqueira * Authors: AMD 24473683a0SRodrigo Siqueira * 25473683a0SRodrigo Siqueira */ 26473683a0SRodrigo Siqueira 27473683a0SRodrigo Siqueira #ifndef __AMDGPU_DM_CRTC_H__ 28473683a0SRodrigo Siqueira #define __AMDGPU_DM_CRTC_H__ 29473683a0SRodrigo Siqueira 306c5e25a0SDavid Tadokoro void amdgpu_dm_crtc_handle_vblank(struct amdgpu_crtc *acrtc); 31473683a0SRodrigo Siqueira 326c5e25a0SDavid Tadokoro bool amdgpu_dm_crtc_modeset_required(struct drm_crtc_state *crtc_state, 33473683a0SRodrigo Siqueira struct dc_stream_state *new_stream, 34473683a0SRodrigo Siqueira struct dc_stream_state *old_stream); 35473683a0SRodrigo Siqueira 366c5e25a0SDavid Tadokoro int amdgpu_dm_crtc_set_vupdate_irq(struct drm_crtc *crtc, bool enable); 37473683a0SRodrigo Siqueira 386c5e25a0SDavid Tadokoro bool amdgpu_dm_crtc_vrr_active_irq(struct amdgpu_crtc *acrtc); 39473683a0SRodrigo Siqueira 40*67edb81dSTom Chung bool amdgpu_dm_crtc_vrr_active(const struct dm_crtc_state *dm_state); 41473683a0SRodrigo Siqueira 426c5e25a0SDavid Tadokoro int amdgpu_dm_crtc_enable_vblank(struct drm_crtc *crtc); 43473683a0SRodrigo Siqueira 446c5e25a0SDavid Tadokoro void amdgpu_dm_crtc_disable_vblank(struct drm_crtc *crtc); 45473683a0SRodrigo Siqueira 46473683a0SRodrigo Siqueira int amdgpu_dm_crtc_init(struct amdgpu_display_manager *dm, 47473683a0SRodrigo Siqueira struct drm_plane *plane, 48473683a0SRodrigo Siqueira uint32_t link_index); 49473683a0SRodrigo Siqueira 50473683a0SRodrigo Siqueira #endif 51473683a0SRodrigo Siqueira 52