Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 1 | #ifndef __NOUVEAU_DISPLAY_H__ |
| 2 | #define __NOUVEAU_DISPLAY_H__ |
| 3 | |
Ben Skeggs | 5ce3bf3 | 2015-01-14 09:57:36 +1000 | [diff] [blame] | 4 | #include <subdev/mmu.h> |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 5 | |
Ben Skeggs | 4dc2813 | 2016-05-20 09:22:55 +1000 | [diff] [blame] | 6 | #include "nouveau_drv.h" |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 7 | |
| 8 | struct nouveau_framebuffer { |
| 9 | struct drm_framebuffer base; |
| 10 | struct nouveau_bo *nvbo; |
Ben Skeggs | be83cd4 | 2015-01-14 15:36:34 +1000 | [diff] [blame] | 11 | struct nvkm_vma vma; |
Ben Skeggs | 8a42364 | 2014-08-10 04:10:19 +1000 | [diff] [blame] | 12 | u32 r_handle; |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 13 | u32 r_format; |
| 14 | u32 r_pitch; |
Ben Skeggs | 0ad7286 | 2014-08-10 04:10:22 +1000 | [diff] [blame] | 15 | struct nvif_object h_base[4]; |
| 16 | struct nvif_object h_core; |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 17 | }; |
| 18 | |
| 19 | static inline struct nouveau_framebuffer * |
| 20 | nouveau_framebuffer(struct drm_framebuffer *fb) |
| 21 | { |
| 22 | return container_of(fb, struct nouveau_framebuffer, base); |
| 23 | } |
| 24 | |
Ben Skeggs | 1608a0f | 2016-11-04 17:20:35 +1000 | [diff] [blame] | 25 | int nouveau_framebuffer_new(struct drm_device *, |
| 26 | const struct drm_mode_fb_cmd2 *, |
| 27 | struct nouveau_bo *, struct nouveau_framebuffer **); |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 28 | |
| 29 | struct nouveau_page_flip_state { |
| 30 | struct list_head head; |
| 31 | struct drm_pending_vblank_event *event; |
Gustavo Padovan | dc4ff11 | 2016-06-07 11:07:53 -0300 | [diff] [blame] | 32 | struct drm_crtc *crtc; |
| 33 | int bpp, pitch; |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 34 | u64 offset; |
| 35 | }; |
| 36 | |
| 37 | struct nouveau_display { |
| 38 | void *priv; |
| 39 | void (*dtor)(struct drm_device *); |
| 40 | int (*init)(struct drm_device *); |
| 41 | void (*fini)(struct drm_device *); |
| 42 | |
Ben Skeggs | 0ad7286 | 2014-08-10 04:10:22 +1000 | [diff] [blame] | 43 | struct nvif_object disp; |
Ben Skeggs | ab0af55 | 2014-08-10 04:10:19 +1000 | [diff] [blame] | 44 | |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 45 | struct drm_property *dithering_mode; |
| 46 | struct drm_property *dithering_depth; |
| 47 | struct drm_property *underscan_property; |
| 48 | struct drm_property *underscan_hborder_property; |
| 49 | struct drm_property *underscan_vborder_property; |
| 50 | /* not really hue and saturation: */ |
| 51 | struct drm_property *vibrant_hue_property; |
| 52 | struct drm_property *color_vibrance_property; |
Ben Skeggs | b167db0 | 2016-11-04 17:20:36 +1000 | [diff] [blame] | 53 | |
| 54 | struct drm_atomic_state *suspend; |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 55 | }; |
| 56 | |
| 57 | static inline struct nouveau_display * |
| 58 | nouveau_display(struct drm_device *dev) |
| 59 | { |
| 60 | return nouveau_drm(dev)->display; |
| 61 | } |
| 62 | |
| 63 | int nouveau_display_create(struct drm_device *dev); |
| 64 | void nouveau_display_destroy(struct drm_device *dev); |
| 65 | int nouveau_display_init(struct drm_device *dev); |
Ben Skeggs | 3b4c0ab | 2016-11-04 17:20:35 +1000 | [diff] [blame] | 66 | void nouveau_display_fini(struct drm_device *dev, bool suspend); |
Ben Skeggs | 6fbb702 | 2014-10-02 13:22:27 +1000 | [diff] [blame] | 67 | int nouveau_display_suspend(struct drm_device *dev, bool runtime); |
| 68 | void nouveau_display_resume(struct drm_device *dev, bool runtime); |
Thierry Reding | 88e7271 | 2015-09-24 18:35:31 +0200 | [diff] [blame] | 69 | int nouveau_display_vblank_enable(struct drm_device *, unsigned int); |
| 70 | void nouveau_display_vblank_disable(struct drm_device *, unsigned int); |
| 71 | int nouveau_display_scanoutpos(struct drm_device *, unsigned int, |
| 72 | unsigned int, int *, int *, ktime_t *, |
| 73 | ktime_t *, const struct drm_display_mode *); |
| 74 | int nouveau_display_vblstamp(struct drm_device *, unsigned int, int *, |
Ben Skeggs | d83ef85 | 2013-11-14 13:37:49 +1000 | [diff] [blame] | 75 | struct timeval *, unsigned); |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 76 | |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 77 | int nouveau_crtc_page_flip(struct drm_crtc *crtc, struct drm_framebuffer *fb, |
Keith Packard | ed8d197 | 2013-07-22 18:49:58 -0700 | [diff] [blame] | 78 | struct drm_pending_vblank_event *event, |
Daniel Vetter | 41292b1f | 2017-03-22 22:50:50 +0100 | [diff] [blame^] | 79 | uint32_t page_flip_flags, |
| 80 | struct drm_modeset_acquire_ctx *ctx); |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 81 | int nouveau_finish_page_flip(struct nouveau_channel *, |
| 82 | struct nouveau_page_flip_state *); |
| 83 | |
| 84 | int nouveau_display_dumb_create(struct drm_file *, struct drm_device *, |
| 85 | struct drm_mode_create_dumb *args); |
| 86 | int nouveau_display_dumb_map_offset(struct drm_file *, struct drm_device *, |
| 87 | u32 handle, u64 *offset); |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 88 | |
| 89 | void nouveau_hdmi_mode_set(struct drm_encoder *, struct drm_display_mode *); |
| 90 | |
Dave Airlie | 5addcf0 | 2012-09-10 14:20:51 +1000 | [diff] [blame] | 91 | int nouveau_crtc_set_config(struct drm_mode_set *set); |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 92 | #ifdef CONFIG_DRM_NOUVEAU_BACKLIGHT |
| 93 | extern int nouveau_backlight_init(struct drm_device *); |
| 94 | extern void nouveau_backlight_exit(struct drm_device *); |
Pierre Moreau | db1a0ae2 | 2016-12-08 00:57:08 +0100 | [diff] [blame] | 95 | extern void nouveau_backlight_ctor(void); |
| 96 | extern void nouveau_backlight_dtor(void); |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 97 | #else |
| 98 | static inline int |
| 99 | nouveau_backlight_init(struct drm_device *dev) |
| 100 | { |
| 101 | return 0; |
| 102 | } |
| 103 | |
| 104 | static inline void |
| 105 | nouveau_backlight_exit(struct drm_device *dev) { |
| 106 | } |
Pierre Moreau | db1a0ae2 | 2016-12-08 00:57:08 +0100 | [diff] [blame] | 107 | |
| 108 | static inline void |
| 109 | nouveau_backlight_ctor(void) { |
| 110 | } |
| 111 | |
| 112 | static inline void |
| 113 | nouveau_backlight_dtor(void) { |
| 114 | } |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 115 | #endif |
| 116 | |
Ben Skeggs | 839ca90 | 2016-11-04 17:20:36 +1000 | [diff] [blame] | 117 | struct drm_framebuffer * |
| 118 | nouveau_user_framebuffer_create(struct drm_device *, struct drm_file *, |
| 119 | const struct drm_mode_fb_cmd2 *); |
Ben Skeggs | 77145f1 | 2012-07-31 16:16:21 +1000 | [diff] [blame] | 120 | #endif |