The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/arm/nvidia/drm2/tegra_drm.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*-
    2  * Copyright 1992-2015 Michal Meloun
    3  * All rights reserved.
    4  *
    5  * Redistribution and use in source and binary forms, with or without
    6  * modification, are permitted provided that the following conditions
    7  * are met:
    8  * 1. Redistributions of source code must retain the above copyright
    9  *    notice, this list of conditions and the following disclaimer.
   10  * 2. Redistributions in binary form must reproduce the above copyright
   11  *    notice, this list of conditions and the following disclaimer in the
   12  *    documentation and/or other materials provided with the distribution.
   13  *
   14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
   15  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   16  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   17  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
   18  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   19  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   20  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   21  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
   22  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
   23  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   24  * SUCH DAMAGE.
   25  *
   26  * $FreeBSD$
   27  */
   28 #ifndef _TEGRA_DRM_H_
   29 #define _TEGRA_DRM_H_
   30 
   31 #include <dev/gpio/gpiobusvar.h>
   32 
   33 struct tegra_bo {
   34         struct drm_gem_object   gem_obj;
   35         /* mapped memory buffer */
   36         vm_paddr_t              pbase;
   37         vm_offset_t             vbase;
   38         size_t                  npages;
   39         vm_page_t               *m;
   40         vm_object_t             cdev_pager;
   41 };
   42 
   43 struct tegra_plane {
   44         struct drm_plane        drm_plane;
   45         int                     index;          /* Window index */
   46 };
   47 
   48 struct tegra_fb {
   49         struct drm_framebuffer  drm_fb;
   50         struct drm_fb_helper    fb_helper;
   51         struct tegra_bo         **planes;       /* Attached planes */
   52         int                     nplanes;
   53 
   54         /* Surface and display geometry */
   55         bool                    block_linear;   /* Surface_kind */
   56         uint32_t                block_height;
   57         int                     rotation;       /* In degrees */
   58         bool                    flip_x;         /* Inverted X-axis */
   59         bool                    flip_y;         /* Inverted Y-axis */
   60 };
   61 
   62 struct tegra_crtc {
   63         struct drm_crtc         drm_crtc;
   64         device_t                dev;
   65         int                     nvidia_head;
   66         vm_paddr_t              cursor_pbase;   /* Cursor buffer */
   67         void                    *cursor_vbase;
   68 };
   69 
   70 struct tegra_drm_encoder {
   71         device_t                dev;
   72 
   73         void                    *panel;         /* XXX For LVDS panel */
   74         device_t                ddc;
   75         struct edid             *edid;
   76 
   77         gpio_pin_t              gpio_hpd;
   78 
   79         struct drm_encoder      encoder;
   80         struct drm_connector    connector;
   81         int                     (*setup_clock)(struct tegra_drm_encoder *output,
   82                                     clk_t clk, uint64_t pclk);
   83 };
   84 
   85 struct tegra_drm {
   86         struct drm_device       drm_dev;
   87         struct tegra_fb         *fb;            /* Prime framebuffer */
   88         int                     pitch_align;
   89 };
   90 
   91 /* tegra_drm_subr.c */
   92 int tegra_drm_encoder_attach(struct tegra_drm_encoder *output, phandle_t node);
   93 int tegra_drm_encoder_init(struct tegra_drm_encoder *output,
   94     struct tegra_drm *drm);
   95 int tegra_drm_encoder_exit(struct tegra_drm_encoder *output,
   96     struct tegra_drm *drm);
   97 enum drm_connector_status tegra_drm_connector_detect(
   98     struct drm_connector *connector, bool force);
   99 int tegra_drm_connector_get_modes(struct drm_connector *connector);
  100 struct drm_encoder *tegra_drm_connector_best_encoder(
  101     struct drm_connector *connector);
  102 
  103 /* tegra_dc.c */
  104 void tegra_dc_cancel_page_flip(struct drm_crtc *drm_crtc,
  105     struct drm_file *file);
  106 void tegra_dc_enable_vblank(struct drm_crtc *drm_crtc);
  107 void tegra_dc_disable_vblank(struct drm_crtc *drm_crtc);
  108 int tegra_dc_get_pipe(struct drm_crtc *drm_crtc);
  109 
  110 /* tegra_fb.c */
  111 struct fb_info *tegra_drm_fb_getinfo(struct drm_device *drm);
  112 struct tegra_bo *tegra_fb_get_plane(struct tegra_fb *fb, int idx);
  113 int tegra_drm_fb_create(struct drm_device *drm, struct drm_file *file,
  114     struct drm_mode_fb_cmd2 *cmd, struct drm_framebuffer **fb_res);
  115 int tegra_drm_fb_init(struct drm_device *drm);
  116 void tegra_drm_fb_destroy(struct drm_device *drm);
  117 
  118 /* tegra_bo.c */
  119 struct tegra_bo;
  120 int tegra_bo_create(struct drm_device *drm, size_t size,
  121     struct tegra_bo **res_bo);
  122 void tegra_bo_driver_register(struct drm_driver *drm_drv);
  123 
  124 #endif /* _TEGRA_DRM_H_ */

Cache object: cb1ff771c49efd639169b0269e1459c4


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.