Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 94182
b: refs/heads/master
c: f694e53
h: refs/heads/master
v: v3
  • Loading branch information
Andres Salomon authored and Linus Torvalds committed Apr 28, 2008
1 parent 800dc6b commit 1567bd2
Show file tree
Hide file tree
Showing 4 changed files with 341 additions and 10 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: aec40532c4d1183fa1ec415bb7dae08e19fc6b01
refs/heads/master: f694e53bd0db69557ee8e0db2d1602818ff173b0
45 changes: 45 additions & 0 deletions trunk/drivers/video/geode/lxfb.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,16 @@

#include <linux/fb.h>

#define GP_REG_COUNT (0x7c / 4)
#define DC_REG_COUNT (0xf0 / 4)
#define VP_REG_COUNT (0x158 / 8)
#define FP_REG_COUNT (0x60 / 8)

#define DC_PAL_COUNT 0x104
#define DC_HFILT_COUNT 0x100
#define DC_VFILT_COUNT 0x100
#define VP_COEFF_SIZE 0x1000

#define OUTPUT_CRT 0x01
#define OUTPUT_PANEL 0x02

Expand All @@ -12,6 +22,27 @@ struct lxfb_par {
void __iomem *gp_regs;
void __iomem *dc_regs;
void __iomem *vp_regs;
#ifdef CONFIG_PM
int powered_down;

/* register state, for power mgmt functionality */
struct {
uint64_t padsel;
uint64_t dotpll;
uint64_t dfglcfg;
uint64_t dcspare;
} msr;

uint32_t gp[GP_REG_COUNT];
uint32_t dc[DC_REG_COUNT];
uint64_t vp[VP_REG_COUNT];
uint64_t fp[FP_REG_COUNT];

uint32_t pal[DC_PAL_COUNT];
uint32_t hcoeff[DC_HFILT_COUNT * 2];
uint32_t vcoeff[DC_VFILT_COUNT];
uint32_t vp_coeff[VP_COEFF_SIZE / 4];
#endif
};

static inline unsigned int lx_get_pitch(unsigned int xres, int bpp)
Expand All @@ -27,6 +58,11 @@ int lx_blank_display(struct fb_info *, int);
void lx_set_palette_reg(struct fb_info *, unsigned int, unsigned int,
unsigned int, unsigned int);

#ifdef CONFIG_PM
int lx_powerdown(struct fb_info *info);
int lx_powerup(struct fb_info *info);
#endif


/* Graphics Processor registers (table 6-29 from the data book) */
enum gp_registers {
Expand Down Expand Up @@ -182,6 +218,9 @@ enum dc_registers {
#define DC_DV_CTL_DV_LINE_SIZE_2K (1 << 10)
#define DC_DV_CTL_DV_LINE_SIZE_4K (1 << 11)
#define DC_DV_CTL_DV_LINE_SIZE_8K ((1 << 10) | (1 << 11))
#define DC_DV_CTL_CLEAR_DV_RAM (1 << 0)

#define DC_IRQ_FILT_CTL_H_FILT_SEL (1 << 10)

#define DC_CLR_KEY_CLR_KEY_EN (1 << 24)

Expand Down Expand Up @@ -267,6 +306,8 @@ enum vp_registers {
VP_A2YE,

VP_A3YE, /* 0x150 */

VP_VCR = 0x1000, /* 0x1000 - 0x1fff */
};

#define VP_VCFG_VID_EN (1 << 0)
Expand Down Expand Up @@ -319,6 +360,10 @@ enum fp_registers {
#define FP_PT2_SCRC (1 << 27) /* shfclk free */

#define FP_PM_P (1 << 24) /* panel power ctl */
#define FP_PM_PANEL_PWR_UP (1 << 3) /* r/o */
#define FP_PM_PANEL_PWR_DOWN (1 << 2) /* r/o */
#define FP_PM_PANEL_OFF (1 << 1) /* r/o */
#define FP_PM_PANEL_ON (1 << 0) /* r/o */

#define FP_DFC_BC ((1 << 4) | (1 << 5) | (1 << 6))

Expand Down
41 changes: 41 additions & 0 deletions trunk/drivers/video/geode/lxfb_core.c
Original file line number Diff line number Diff line change
Expand Up @@ -428,6 +428,45 @@ static struct fb_info * __init lxfb_init_fbinfo(struct device *dev)
return info;
}

#ifdef CONFIG_PM
static int lxfb_suspend(struct pci_dev *pdev, pm_message_t state)
{
struct fb_info *info = pci_get_drvdata(pdev);

if (state.event == PM_EVENT_SUSPEND) {
acquire_console_sem();
lx_powerdown(info);
fb_set_suspend(info, 1);
release_console_sem();
}

/* there's no point in setting PCI states; we emulate PCI, so
* we don't end up getting power savings anyways */

return 0;
}

static int lxfb_resume(struct pci_dev *pdev)
{
struct fb_info *info = pci_get_drvdata(pdev);
int ret;

acquire_console_sem();
ret = lx_powerup(info);
if (ret) {
printk(KERN_ERR "lxfb: power up failed!\n");
return ret;
}

fb_set_suspend(info, 0);
release_console_sem();
return 0;
}
#else
#define lxfb_suspend NULL
#define lxfb_resume NULL
#endif

static int __init lxfb_probe(struct pci_dev *pdev,
const struct pci_device_id *id)
{
Expand Down Expand Up @@ -553,6 +592,8 @@ static struct pci_driver lxfb_driver = {
.id_table = lxfb_id_table,
.probe = lxfb_probe,
.remove = lxfb_remove,
.suspend = lxfb_suspend,
.resume = lxfb_resume,
};

#ifndef MODULE
Expand Down
Loading

0 comments on commit 1567bd2

Please sign in to comment.