2011-11-04 01:22:04 +07:00
|
|
|
/**************************************************************************
|
|
|
|
* Copyright (c) 2007-2011, Intel Corporation.
|
|
|
|
* All Rights Reserved.
|
|
|
|
* Copyright (c) 2008, Tungsten Graphics Inc. Cedar Park, TX., USA.
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms and conditions of the GNU General Public License,
|
|
|
|
* version 2, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
* more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with
|
|
|
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
**************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _PSB_DRM_H_
|
|
|
|
#define _PSB_DRM_H_
|
|
|
|
|
|
|
|
/*
|
2011-11-17 05:38:42 +07:00
|
|
|
* Manage the LUT for an output
|
2011-11-04 01:22:04 +07:00
|
|
|
*/
|
|
|
|
struct drm_psb_dpst_lut_arg {
|
|
|
|
uint8_t lut[256];
|
|
|
|
int output_id;
|
|
|
|
};
|
|
|
|
|
2011-11-17 05:38:42 +07:00
|
|
|
/*
|
|
|
|
* Validate modes
|
|
|
|
*/
|
2011-11-04 01:22:04 +07:00
|
|
|
struct drm_psb_mode_operation_arg {
|
|
|
|
u32 obj_id;
|
|
|
|
u16 operation;
|
|
|
|
struct drm_mode_modeinfo mode;
|
2011-11-17 05:38:42 +07:00
|
|
|
u64 data;
|
2011-11-04 01:22:04 +07:00
|
|
|
};
|
|
|
|
|
2011-11-17 05:38:42 +07:00
|
|
|
/*
|
|
|
|
* Query the stolen memory for smarter management of
|
|
|
|
* memory by the server
|
|
|
|
*/
|
2011-11-04 01:22:04 +07:00
|
|
|
struct drm_psb_stolen_memory_arg {
|
|
|
|
u32 base;
|
|
|
|
u32 size;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct drm_psb_get_pipe_from_crtc_id_arg {
|
|
|
|
/** ID of CRTC being requested **/
|
|
|
|
u32 crtc_id;
|
|
|
|
/** pipe of requested CRTC **/
|
|
|
|
u32 pipe;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct drm_psb_gem_create {
|
|
|
|
__u64 size;
|
|
|
|
__u32 handle;
|
|
|
|
__u32 flags;
|
2011-11-17 05:39:18 +07:00
|
|
|
#define GMA_GEM_CREATE_STOLEN 1 /* Stolen memory can be used */
|
2011-11-04 01:22:04 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct drm_psb_gem_mmap {
|
|
|
|
__u32 handle;
|
|
|
|
__u32 pad;
|
|
|
|
/**
|
|
|
|
* Fake offset to use for subsequent mmap call
|
|
|
|
*
|
|
|
|
* This is a fixed-size type for 32/64 compatibility.
|
|
|
|
*/
|
|
|
|
__u64 offset;
|
|
|
|
};
|
|
|
|
|
2011-11-17 05:38:42 +07:00
|
|
|
/* Controlling the kernel modesetting buffers */
|
|
|
|
|
2011-11-17 05:39:18 +07:00
|
|
|
#define DRM_GMA_GEM_CREATE 0x00 /* Create a GEM object */
|
|
|
|
#define DRM_GMA_GEM_MMAP 0x01 /* Map GEM memory */
|
|
|
|
#define DRM_GMA_STOLEN_MEMORY 0x02 /* Report stolen memory */
|
|
|
|
#define DRM_GMA_2D_OP 0x03 /* Will be merged later */
|
|
|
|
#define DRM_GMA_GAMMA 0x04 /* Set gamma table */
|
|
|
|
#define DRM_GMA_ADB 0x05 /* Get backlight */
|
|
|
|
#define DRM_GMA_DPST_BL 0x06 /* Set backlight */
|
|
|
|
#define DRM_GMA_MODE_OPERATION 0x07 /* Mode validation/DC set */
|
2011-11-17 05:38:42 +07:00
|
|
|
#define PSB_MODE_OPERATION_MODE_VALID 0x01
|
2012-03-08 23:04:47 +07:00
|
|
|
#define DRM_GMA_GET_PIPE_FROM_CRTC_ID 0x08 /* CRTC to physical pipe# */
|
2011-11-17 05:38:42 +07:00
|
|
|
|
|
|
|
|
2011-11-04 01:22:04 +07:00
|
|
|
#endif
|