Commit 487e873d authored by Alan Cox's avatar Alan Cox Committed by Greg Kroah-Hartman

staging: gma500: Resync the patch queue with GregKH's space cleanup.

Remove all sorts of bits we can get rid of. We are now a very simple KMS
driver relying on the stolen memory for our framebuffer base (which is for
the moment hardcoded).

To support multiple frame buffers and some accel bits we will need some kind
of memory allocator, possibly a minimal use of GEM.
Signed-off-by: default avatarAlan Cox <alan@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 2145cff5
/* /*
* psb backlight using HAL * psb backlight interface
* *
* Copyright (c) 2009, Intel Corporation. * Copyright (c) 2009, Intel Corporation.
* *
...@@ -73,6 +73,8 @@ int psb_get_brightness(struct backlight_device *bd) ...@@ -73,6 +73,8 @@ int psb_get_brightness(struct backlight_device *bd)
DRM_DEBUG_DRIVER("brightness = 0x%x\n", psb_brightness); DRM_DEBUG_DRIVER("brightness = 0x%x\n", psb_brightness);
/* return locally cached var instead of HW read (due to DPST etc.) */ /* return locally cached var instead of HW read (due to DPST etc.) */
/* FIXME: ideally return actual value in case firmware fiddled with
it */
return psb_brightness; return psb_brightness;
} }
...@@ -83,7 +85,7 @@ static const struct backlight_ops psb_ops = { ...@@ -83,7 +85,7 @@ static const struct backlight_ops psb_ops = {
static int device_backlight_init(struct drm_device *dev) static int device_backlight_init(struct drm_device *dev)
{ {
unsigned long CoreClock; unsigned long core_clock;
/* u32 bl_max_freq; */ /* u32 bl_max_freq; */
/* unsigned long value; */ /* unsigned long value; */
u16 bl_max_freq; u16 bl_max_freq;
...@@ -102,9 +104,9 @@ static int device_backlight_init(struct drm_device *dev) ...@@ -102,9 +104,9 @@ static int device_backlight_init(struct drm_device *dev)
blc_brightnesscmd = dev_priv->lvds_bl->brightnesscmd; blc_brightnesscmd = dev_priv->lvds_bl->brightnesscmd;
blc_type = dev_priv->lvds_bl->type; blc_type = dev_priv->lvds_bl->type;
CoreClock = dev_priv->core_freq; core_clock = dev_priv->core_freq;
value = (CoreClock * MHz) / BLC_PWM_FREQ_CALC_CONSTANT; value = (core_clock * MHz) / BLC_PWM_FREQ_CALC_CONSTANT;
value *= blc_pwm_precision_factor; value *= blc_pwm_precision_factor;
value /= bl_max_freq; value /= bl_max_freq;
value /= blc_pwm_precision_factor; value /= blc_pwm_precision_factor;
......
This diff is collapsed.
...@@ -33,14 +33,13 @@ ...@@ -33,14 +33,13 @@
#include <linux/notifier.h> #include <linux/notifier.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <acpi/video.h>
int drm_psb_debug; int drm_psb_debug;
static int drm_psb_trap_pagefaults; static int drm_psb_trap_pagefaults;
int drm_psb_disable_vsync = 1; int drm_psb_disable_vsync = 1;
int drm_psb_no_fb; int drm_psb_no_fb;
int drm_psb_force_pipeb;
int drm_idle_check_interval = 5;
int gfxrtdelay = 2 * 1000; int gfxrtdelay = 2 * 1000;
static int psb_probe(struct pci_dev *pdev, const struct pci_device_id *ent); static int psb_probe(struct pci_dev *pdev, const struct pci_device_id *ent);
...@@ -57,7 +56,6 @@ MODULE_PARM_DESC(hdmi_edid, "EDID info for HDMI monitor"); ...@@ -57,7 +56,6 @@ MODULE_PARM_DESC(hdmi_edid, "EDID info for HDMI monitor");
module_param_named(debug, drm_psb_debug, int, 0600); module_param_named(debug, drm_psb_debug, int, 0600);
module_param_named(no_fb, drm_psb_no_fb, int, 0600); module_param_named(no_fb, drm_psb_no_fb, int, 0600);
module_param_named(trap_pagefaults, drm_psb_trap_pagefaults, int, 0600); module_param_named(trap_pagefaults, drm_psb_trap_pagefaults, int, 0600);
module_param_named(force_pipeb, drm_psb_force_pipeb, int, 0600);
module_param_named(rtpm, gfxrtdelay, int, 0600); module_param_named(rtpm, gfxrtdelay, int, 0600);
...@@ -108,12 +106,6 @@ MODULE_DEVICE_TABLE(pci, pciidlist); ...@@ -108,12 +106,6 @@ MODULE_DEVICE_TABLE(pci, pciidlist);
#define DRM_IOCTL_PSB_GETPAGEADDRS \ #define DRM_IOCTL_PSB_GETPAGEADDRS \
DRM_IOWR(DRM_COMMAND_BASE + DRM_PSB_GETPAGEADDRS,\ DRM_IOWR(DRM_COMMAND_BASE + DRM_PSB_GETPAGEADDRS,\
struct drm_psb_getpageaddrs_arg) struct drm_psb_getpageaddrs_arg)
#define DRM_IOCTL_PSB_HIST_ENABLE \
DRM_IOWR(DRM_PSB_HIST_ENABLE + DRM_COMMAND_BASE, \
uint32_t)
#define DRM_IOCTL_PSB_HIST_STATUS \
DRM_IOWR(DRM_PSB_HIST_STATUS + DRM_COMMAND_BASE, \
struct drm_psb_hist_status_arg)
#define DRM_IOCTL_PSB_UPDATE_GUARD \ #define DRM_IOCTL_PSB_UPDATE_GUARD \
DRM_IOWR(DRM_PSB_UPDATE_GUARD + DRM_COMMAND_BASE, \ DRM_IOWR(DRM_PSB_UPDATE_GUARD + DRM_COMMAND_BASE, \
uint32_t) uint32_t)
...@@ -133,15 +125,9 @@ MODULE_DEVICE_TABLE(pci, pciidlist); ...@@ -133,15 +125,9 @@ MODULE_DEVICE_TABLE(pci, pciidlist);
/* /*
* TTM execbuf extension. * TTM execbuf extension.
*/ */
#define DRM_PSB_CMDBUF (DRM_PSB_DPU_DSR_OFF + 1)
#define DRM_PSB_CMDBUF 0x23
#define DRM_PSB_SCENE_UNREF (DRM_PSB_CMDBUF + 1) #define DRM_PSB_SCENE_UNREF 0x24
#define DRM_IOCTL_PSB_CMDBUF \
DRM_IOW(DRM_PSB_CMDBUF + DRM_COMMAND_BASE, \
struct drm_psb_cmdbuf_arg)
#define DRM_IOCTL_PSB_SCENE_UNREF \
DRM_IOW(DRM_PSB_SCENE_UNREF + DRM_COMMAND_BASE, \
struct drm_psb_scene)
#define DRM_IOCTL_PSB_KMS_OFF DRM_IO(DRM_PSB_KMS_OFF + DRM_COMMAND_BASE) #define DRM_IOCTL_PSB_KMS_OFF DRM_IO(DRM_PSB_KMS_OFF + DRM_COMMAND_BASE)
#define DRM_IOCTL_PSB_KMS_ON DRM_IO(DRM_PSB_KMS_ON + DRM_COMMAND_BASE) #define DRM_IOCTL_PSB_KMS_ON DRM_IO(DRM_PSB_KMS_ON + DRM_COMMAND_BASE)
/* /*
...@@ -168,8 +154,6 @@ MODULE_DEVICE_TABLE(pci, pciidlist); ...@@ -168,8 +154,6 @@ MODULE_DEVICE_TABLE(pci, pciidlist);
#define DRM_PSB_TTM_FENCE_UNREF (TTM_FENCE_UNREF + DRM_PSB_FENCE_OFFSET) #define DRM_PSB_TTM_FENCE_UNREF (TTM_FENCE_UNREF + DRM_PSB_FENCE_OFFSET)
#define DRM_PSB_FLIP (DRM_PSB_TTM_FENCE_UNREF + 1) /*20*/ #define DRM_PSB_FLIP (DRM_PSB_TTM_FENCE_UNREF + 1) /*20*/
/* PSB video extension */
#define DRM_LNC_VIDEO_GETPARAM (DRM_PSB_FLIP + 1)
#define DRM_IOCTL_PSB_TTM_PL_CREATE \ #define DRM_IOCTL_PSB_TTM_PL_CREATE \
DRM_IOWR(DRM_COMMAND_BASE + DRM_PSB_TTM_PL_CREATE,\ DRM_IOWR(DRM_COMMAND_BASE + DRM_PSB_TTM_PL_CREATE,\
...@@ -201,12 +185,6 @@ MODULE_DEVICE_TABLE(pci, pciidlist); ...@@ -201,12 +185,6 @@ MODULE_DEVICE_TABLE(pci, pciidlist);
#define DRM_IOCTL_PSB_TTM_FENCE_UNREF \ #define DRM_IOCTL_PSB_TTM_FENCE_UNREF \
DRM_IOW(DRM_COMMAND_BASE + DRM_PSB_TTM_FENCE_UNREF, \ DRM_IOW(DRM_COMMAND_BASE + DRM_PSB_TTM_FENCE_UNREF, \
struct ttm_fence_unref_arg) struct ttm_fence_unref_arg)
#define DRM_IOCTL_PSB_FLIP \
DRM_IOWR(DRM_COMMAND_BASE + DRM_PSB_FLIP, \
struct drm_psb_pageflip_arg)
#define DRM_IOCTL_LNC_VIDEO_GETPARAM \
DRM_IOWR(DRM_COMMAND_BASE + DRM_LNC_VIDEO_GETPARAM, \
struct drm_lnc_video_getparam_arg)
static int psb_vt_leave_ioctl(struct drm_device *dev, void *data, static int psb_vt_leave_ioctl(struct drm_device *dev, void *data,
struct drm_file *file_priv); struct drm_file *file_priv);
...@@ -268,9 +246,6 @@ static struct drm_ioctl_desc psb_ioctls[] = { ...@@ -268,9 +246,6 @@ static struct drm_ioctl_desc psb_ioctls[] = {
PSB_IOCTL_DEF(DRM_IOCTL_PSB_DPST_BL, psb_dpst_bl_ioctl, DRM_AUTH), PSB_IOCTL_DEF(DRM_IOCTL_PSB_DPST_BL, psb_dpst_bl_ioctl, DRM_AUTH),
PSB_IOCTL_DEF(DRM_IOCTL_PSB_GET_PIPE_FROM_CRTC_ID, PSB_IOCTL_DEF(DRM_IOCTL_PSB_GET_PIPE_FROM_CRTC_ID,
psb_intel_get_pipe_from_crtc_id, 0), psb_intel_get_pipe_from_crtc_id, 0),
/*to be removed later*/
/*PSB_IOCTL_DEF(DRM_IOCTL_PSB_SCENE_UNREF, drm_psb_scene_unref_ioctl,
DRM_AUTH),*/
PSB_IOCTL_DEF(DRM_IOCTL_PSB_TTM_PL_CREATE, psb_pl_create_ioctl, PSB_IOCTL_DEF(DRM_IOCTL_PSB_TTM_PL_CREATE, psb_pl_create_ioctl,
DRM_AUTH), DRM_AUTH),
...@@ -392,15 +367,6 @@ static void psb_get_core_freq(struct drm_device *dev) ...@@ -392,15 +367,6 @@ static void psb_get_core_freq(struct drm_device *dev)
#define FB_SKU_100 0 #define FB_SKU_100 0
#define FB_SKU_100L 1 #define FB_SKU_100L 1
#define FB_SKU_83 2 #define FB_SKU_83 2
#if 1 /* FIXME remove it after PO */
#define FB_GFX_CLK_DIVIDE_MASK (BIT20|BIT21|BIT22)
#define FB_GFX_CLK_DIVIDE_SHIFT 20
#define FB_VED_CLK_DIVIDE_MASK (BIT23|BIT24)
#define FB_VED_CLK_DIVIDE_SHIFT 23
#define FB_VEC_CLK_DIVIDE_MASK (BIT25|BIT26)
#define FB_VEC_CLK_DIVIDE_SHIFT 25
#endif /* FIXME remove it after PO */
bool mid_get_pci_revID(struct drm_psb_private *dev_priv) bool mid_get_pci_revID(struct drm_psb_private *dev_priv)
{ {
...@@ -596,7 +562,7 @@ static int psb_driver_unload(struct drm_device *dev) ...@@ -596,7 +562,7 @@ static int psb_driver_unload(struct drm_device *dev)
dev->dev_private = NULL; dev->dev_private = NULL;
/*destory VBT data*/ /*destory VBT data*/
psb_intel_destory_bios(dev); psb_intel_destroy_bios(dev);
} }
ospm_power_uninit(); ospm_power_uninit();
...@@ -615,10 +581,6 @@ static int psb_driver_load(struct drm_device *dev, unsigned long chipset) ...@@ -615,10 +581,6 @@ static int psb_driver_load(struct drm_device *dev, unsigned long chipset)
int ret = -ENOMEM; int ret = -ENOMEM;
uint32_t tt_pages; uint32_t tt_pages;
DRM_INFO("psb - %s\n", PSB_PACKAGE_VERSION);
DRM_INFO("Run drivers on Poulsbo platform!\n");
dev_priv = kzalloc(sizeof(*dev_priv), GFP_KERNEL); dev_priv = kzalloc(sizeof(*dev_priv), GFP_KERNEL);
if (dev_priv == NULL) if (dev_priv == NULL)
return -ENOMEM; return -ENOMEM;
...@@ -774,11 +736,8 @@ static int psb_driver_load(struct drm_device *dev, unsigned long chipset) ...@@ -774,11 +736,8 @@ static int psb_driver_load(struct drm_device *dev, unsigned long chipset)
if (ret) if (ret)
return ret; return ret;
/** /* igd_opregion_init(&dev_priv->opregion_dev); */
* Init lid switch timer. acpi_video_register();
* NOTE: must do this after psb_intel_opregion_init
* and psb_backlight_init
*/
if (dev_priv->lid_state) if (dev_priv->lid_state)
psb_lid_timer_init(dev_priv); psb_lid_timer_init(dev_priv);
......
...@@ -368,7 +368,6 @@ struct drm_psb_private { ...@@ -368,7 +368,6 @@ struct drm_psb_private {
unsigned long chipset; unsigned long chipset;
struct drm_psb_dev_info_arg dev_info;
struct drm_psb_uopt uopt; struct drm_psb_uopt uopt;
struct psb_gtt *pg; struct psb_gtt *pg;
......
...@@ -273,7 +273,7 @@ bool psb_intel_init_bios(struct drm_device *dev) ...@@ -273,7 +273,7 @@ bool psb_intel_init_bios(struct drm_device *dev)
/** /**
* Destory and free VBT data * Destory and free VBT data
*/ */
void psb_intel_destory_bios(struct drm_device *dev) void psb_intel_destroy_bios(struct drm_device *dev)
{ {
struct drm_psb_private *dev_priv = dev->dev_private; struct drm_psb_private *dev_priv = dev->dev_private;
struct drm_display_mode *sdvo_lvds_vbt_mode = struct drm_display_mode *sdvo_lvds_vbt_mode =
......
...@@ -304,7 +304,7 @@ struct bdb_sdvo_lvds_options { ...@@ -304,7 +304,7 @@ struct bdb_sdvo_lvds_options {
extern bool psb_intel_init_bios(struct drm_device *dev); extern bool psb_intel_init_bios(struct drm_device *dev);
extern void psb_intel_destory_bios(struct drm_device *dev); extern void psb_intel_destroy_bios(struct drm_device *dev);
/* /*
* Driver<->VBIOS interaction occurs through scratch bits in * Driver<->VBIOS interaction occurs through scratch bits in
......
This diff is collapsed.
...@@ -422,9 +422,9 @@ void psb_irq_turn_on_dpst(struct drm_device *dev) ...@@ -422,9 +422,9 @@ void psb_irq_turn_on_dpst(struct drm_device *dev)
if (ospm_power_using_hw_begin(OSPM_DISPLAY_ISLAND, if (ospm_power_using_hw_begin(OSPM_DISPLAY_ISLAND,
OSPM_UHB_ONLY_IF_ON)) { OSPM_UHB_ONLY_IF_ON)) {
PSB_WVDC32(BIT31, HISTOGRAM_LOGIC_CONTROL); PSB_WVDC32(1 << 31, HISTOGRAM_LOGIC_CONTROL);
hist_reg = PSB_RVDC32(HISTOGRAM_LOGIC_CONTROL); hist_reg = PSB_RVDC32(HISTOGRAM_LOGIC_CONTROL);
PSB_WVDC32(BIT31, HISTOGRAM_INT_CONTROL); PSB_WVDC32(1 << 31, HISTOGRAM_INT_CONTROL);
hist_reg = PSB_RVDC32(HISTOGRAM_INT_CONTROL); hist_reg = PSB_RVDC32(HISTOGRAM_INT_CONTROL);
PSB_WVDC32(0x80010100, PWM_CONTROL_LOGIC); PSB_WVDC32(0x80010100, PWM_CONTROL_LOGIC);
......
...@@ -287,11 +287,6 @@ static void ospm_suspend_pci(struct pci_dev *pdev) ...@@ -287,11 +287,6 @@ static void ospm_suspend_pci(struct pci_dev *pdev)
printk(KERN_ALERT "ospm_suspend_pci\n"); printk(KERN_ALERT "ospm_suspend_pci\n");
#endif #endif
#ifdef CONFIG_MDFD_GL3
// Power off GL3 after all GFX sub-systems are powered off.
ospm_power_island_down(OSPM_GL3_CACHE_ISLAND);
#endif
pci_save_state(pdev); pci_save_state(pdev);
pci_read_config_dword(pdev, 0x5C, &bsm); pci_read_config_dword(pdev, 0x5C, &bsm);
dev_priv->saveBSM = bsm; dev_priv->saveBSM = bsm;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment