2009-12-11 19:24:15 +10:00
/*
* Copyright ( C ) 2008 Maarten Maathuis .
* All Rights Reserved .
*
* Permission is hereby granted , free of charge , to any person obtaining
* a copy of this software and associated documentation files ( the
* " Software " ) , to deal in the Software without restriction , including
* without limitation the rights to use , copy , modify , merge , publish ,
* distribute , sublicense , and / or sell copies of the Software , and to
* permit persons to whom the Software is furnished to do so , subject to
* the following conditions :
*
* The above copyright notice and this permission notice ( including the
* next paragraph ) shall be included in all copies or substantial
* portions of the Software .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND ,
* EXPRESS OR IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY , FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT .
* IN NO EVENT SHALL THE COPYRIGHT OWNER ( S ) AND / OR ITS SUPPLIERS BE
* LIABLE FOR ANY CLAIM , DAMAGES OR OTHER LIABILITY , WHETHER IN AN ACTION
* OF CONTRACT , TORT OR OTHERWISE , ARISING FROM , OUT OF OR IN CONNECTION
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE .
*
*/
# ifndef __NV50_DISPLAY_H__
# define __NV50_DISPLAY_H__
# include "drmP.h"
# include "drm.h"
# include "nouveau_drv.h"
# include "nouveau_dma.h"
# include "nouveau_reg.h"
# include "nouveau_crtc.h"
# include "nv50_evo.h"
2011-02-07 13:29:23 +10:00
struct nv50_display_crtc {
struct nouveau_channel * sync ;
struct {
struct nouveau_bo * bo ;
u32 offset ;
u16 value ;
} sem ;
} ;
2011-02-01 10:07:32 +10:00
struct nv50_display {
2011-02-01 10:24:41 +10:00
struct nouveau_channel * master ;
2011-02-03 15:46:14 +10:00
struct nouveau_gpuobj * ntfy ;
2011-02-01 10:07:32 +10:00
2011-02-07 13:29:23 +10:00
struct nv50_display_crtc crtc [ 2 ] ;
2011-02-03 20:06:14 +10:00
struct tasklet_struct tasklet ;
2011-02-01 10:07:32 +10:00
struct {
struct dcb_entry * dcb ;
u16 script ;
u32 pclk ;
} irq ;
} ;
static inline struct nv50_display *
nv50_display ( struct drm_device * dev )
{
struct drm_nouveau_private * dev_priv = dev - > dev_private ;
return dev_priv - > engine . display . priv ;
}
2010-07-24 17:37:33 +02:00
int nv50_display_early_init ( struct drm_device * dev ) ;
void nv50_display_late_takedown ( struct drm_device * dev ) ;
2009-12-11 19:24:15 +10:00
int nv50_display_create ( struct drm_device * dev ) ;
2010-07-24 17:37:33 +02:00
int nv50_display_init ( struct drm_device * dev ) ;
2011-11-09 11:36:33 +10:00
void nv50_display_fini ( struct drm_device * dev ) ;
2010-07-24 17:37:33 +02:00
void nv50_display_destroy ( struct drm_device * dev ) ;
2009-12-11 19:24:15 +10:00
int nv50_crtc_blank ( struct nouveau_crtc * , bool blank ) ;
int nv50_crtc_set_clock ( struct drm_device * , int head , int pclk ) ;
2012-01-23 13:22:58 +10:00
u32 nv50_display_active_crtcs ( struct drm_device * ) ;
2011-10-14 14:35:19 +10:00
int nv50_display_sync ( struct drm_device * ) ;
2011-02-07 13:29:23 +10:00
int nv50_display_flip_next ( struct drm_crtc * , struct drm_framebuffer * ,
struct nouveau_channel * chan ) ;
void nv50_display_flip_stop ( struct drm_crtc * ) ;
2011-11-09 15:52:43 +10:00
int nv50_evo_create ( struct drm_device * dev ) ;
void nv50_evo_destroy ( struct drm_device * dev ) ;
2011-02-07 13:08:16 +10:00
int nv50_evo_init ( struct drm_device * dev ) ;
void nv50_evo_fini ( struct drm_device * dev ) ;
void nv50_evo_dmaobj_init ( struct nouveau_gpuobj * , u32 memtype , u64 base ,
u64 size ) ;
int nv50_evo_dmaobj_new ( struct nouveau_channel * , u32 handle , u32 memtype ,
u64 base , u64 size , struct nouveau_gpuobj * * ) ;
2009-12-11 19:24:15 +10:00
# endif /* __NV50_DISPLAY_H__ */