1785b93efSDave Airlie /* 2785b93efSDave Airlie * Copyright (c) 2006-2009 Red Hat Inc. 3785b93efSDave Airlie * Copyright (c) 2006-2008 Intel Corporation 4785b93efSDave Airlie * Copyright (c) 2007 Dave Airlie <airlied@linux.ie> 5785b93efSDave Airlie * 6785b93efSDave Airlie * DRM framebuffer helper functions 7785b93efSDave Airlie * 8785b93efSDave Airlie * Permission to use, copy, modify, distribute, and sell this software and its 9785b93efSDave Airlie * documentation for any purpose is hereby granted without fee, provided that 10785b93efSDave Airlie * the above copyright notice appear in all copies and that both that copyright 11785b93efSDave Airlie * notice and this permission notice appear in supporting documentation, and 12785b93efSDave Airlie * that the name of the copyright holders not be used in advertising or 13785b93efSDave Airlie * publicity pertaining to distribution of the software without specific, 14785b93efSDave Airlie * written prior permission. The copyright holders make no representations 15785b93efSDave Airlie * about the suitability of this software for any purpose. It is provided "as 16785b93efSDave Airlie * is" without express or implied warranty. 17785b93efSDave Airlie * 18785b93efSDave Airlie * THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, 19785b93efSDave Airlie * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO 20785b93efSDave Airlie * EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY SPECIAL, INDIRECT OR 21785b93efSDave Airlie * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, 22785b93efSDave Airlie * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER 23785b93efSDave Airlie * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE 24785b93efSDave Airlie * OF THIS SOFTWARE. 25785b93efSDave Airlie * 26785b93efSDave Airlie * Authors: 27785b93efSDave Airlie * Dave Airlie <airlied@linux.ie> 28785b93efSDave Airlie * Jesse Barnes <jesse.barnes@intel.com> 29785b93efSDave Airlie */ 30785b93efSDave Airlie #ifndef DRM_FB_HELPER_H 31785b93efSDave Airlie #define DRM_FB_HELPER_H 32785b93efSDave Airlie 334abe3520SDave Airlie struct drm_fb_helper; 344abe3520SDave Airlie 351a7aba7fSJesse Barnes #include <linux/kgdb.h> 361a7aba7fSJesse Barnes 37785b93efSDave Airlie struct drm_fb_helper_crtc { 38785b93efSDave Airlie uint32_t crtc_id; 39785b93efSDave Airlie struct drm_mode_set mode_set; 408be48d92SDave Airlie struct drm_display_mode *desired_mode; 41785b93efSDave Airlie }; 42785b93efSDave Airlie 4338651674SDave Airlie struct drm_fb_helper_surface_size { 4438651674SDave Airlie u32 fb_width; 4538651674SDave Airlie u32 fb_height; 4638651674SDave Airlie u32 surface_width; 4738651674SDave Airlie u32 surface_height; 4838651674SDave Airlie u32 surface_bpp; 4938651674SDave Airlie u32 surface_depth; 5038651674SDave Airlie }; 5138651674SDave Airlie 524abe3520SDave Airlie struct drm_fb_helper_funcs { 534abe3520SDave Airlie void (*gamma_set)(struct drm_crtc *crtc, u16 red, u16 green, 544abe3520SDave Airlie u16 blue, int regno); 554abe3520SDave Airlie void (*gamma_get)(struct drm_crtc *crtc, u16 *red, u16 *green, 564abe3520SDave Airlie u16 *blue, int regno); 574abe3520SDave Airlie 584abe3520SDave Airlie int (*fb_probe)(struct drm_fb_helper *helper, 594abe3520SDave Airlie struct drm_fb_helper_surface_size *sizes); 604abe3520SDave Airlie }; 614abe3520SDave Airlie 62d50ba256SDave Airlie struct drm_fb_helper_connector { 630b4c0f3fSDave Airlie struct drm_connector *connector; 641794d257SChris Wilson struct drm_cmdline_mode cmdline_mode; 65d50ba256SDave Airlie }; 66d50ba256SDave Airlie 67785b93efSDave Airlie struct drm_fb_helper { 68785b93efSDave Airlie struct drm_framebuffer *fb; 691a7aba7fSJesse Barnes struct drm_framebuffer *saved_fb; 70785b93efSDave Airlie struct drm_device *dev; 71785b93efSDave Airlie struct drm_display_mode *mode; 72785b93efSDave Airlie int crtc_count; 73785b93efSDave Airlie struct drm_fb_helper_crtc *crtc_info; 740b4c0f3fSDave Airlie int connector_count; 750b4c0f3fSDave Airlie struct drm_fb_helper_connector **connector_info; 76785b93efSDave Airlie struct drm_fb_helper_funcs *funcs; 77785b93efSDave Airlie int conn_limit; 7838651674SDave Airlie struct fb_info *fbdev; 7938651674SDave Airlie u32 pseudo_palette[17]; 80785b93efSDave Airlie struct list_head kernel_fb_list; 818be48d92SDave Airlie 824abe3520SDave Airlie /* we got a hotplug but fbdev wasn't running the console 834abe3520SDave Airlie delay until next set_par */ 844abe3520SDave Airlie bool delayed_hotplug; 85785b93efSDave Airlie }; 86785b93efSDave Airlie 878be48d92SDave Airlie int drm_fb_helper_single_fb_probe(struct drm_fb_helper *helper, 888be48d92SDave Airlie int preferred_bpp); 898be48d92SDave Airlie 904abe3520SDave Airlie int drm_fb_helper_init(struct drm_device *dev, 918be48d92SDave Airlie struct drm_fb_helper *helper, int crtc_count, 92eb1f8e4fSDave Airlie int max_conn); 934abe3520SDave Airlie void drm_fb_helper_fini(struct drm_fb_helper *helper); 94785b93efSDave Airlie int drm_fb_helper_blank(int blank, struct fb_info *info); 95785b93efSDave Airlie int drm_fb_helper_pan_display(struct fb_var_screeninfo *var, 96785b93efSDave Airlie struct fb_info *info); 97785b93efSDave Airlie int drm_fb_helper_set_par(struct fb_info *info); 98785b93efSDave Airlie int drm_fb_helper_check_var(struct fb_var_screeninfo *var, 99785b93efSDave Airlie struct fb_info *info); 100785b93efSDave Airlie int drm_fb_helper_setcolreg(unsigned regno, 101785b93efSDave Airlie unsigned red, 102785b93efSDave Airlie unsigned green, 103785b93efSDave Airlie unsigned blue, 104785b93efSDave Airlie unsigned transp, 105785b93efSDave Airlie struct fb_info *info); 106785b93efSDave Airlie 107e8e7a2b8SDave Airlie bool drm_fb_helper_restore_fbdev_mode(struct drm_fb_helper *fb_helper); 108785b93efSDave Airlie void drm_fb_helper_restore(void); 10938651674SDave Airlie void drm_fb_helper_fill_var(struct fb_info *info, struct drm_fb_helper *fb_helper, 110785b93efSDave Airlie uint32_t fb_width, uint32_t fb_height); 1113632ef89SDave Airlie void drm_fb_helper_fill_fix(struct fb_info *info, uint32_t pitch, 1123632ef89SDave Airlie uint32_t depth); 1133632ef89SDave Airlie 114068143d3SDave Airlie int drm_fb_helper_setcmap(struct fb_cmap *cmap, struct fb_info *info); 115d50ba256SDave Airlie 1167394371dSChris Wilson int drm_fb_helper_hotplug_event(struct drm_fb_helper *fb_helper); 1174abe3520SDave Airlie bool drm_fb_helper_initial_config(struct drm_fb_helper *fb_helper, int bpp_sel); 1180b4c0f3fSDave Airlie int drm_fb_helper_single_add_all_connectors(struct drm_fb_helper *fb_helper); 1191a7aba7fSJesse Barnes int drm_fb_helper_debug_enter(struct fb_info *info); 1201a7aba7fSJesse Barnes int drm_fb_helper_debug_leave(struct fb_info *info); 1218be48d92SDave Airlie 122785b93efSDave Airlie #endif 123