Commit df7a9ec3 authored by Vaibhav Gupta's avatar Vaibhav Gupta Committed by Bartlomiej Zolnierkiewicz

fbdev: lxfb: use generic power management

Switch to the new generic framework by updating function signatures and
define a "struct dev_pm_ops" variable to bind PM callbacks. This way we can
remove the legacy .suspend & .resume bindings from "lxfb_driver".

The lxfb_suspend() is designed to function only in the case of Suspend.
Thus, the code was kept inside "if (state.event == PM_EVENT_SUSPEND)"
container. This is because, in the legacy framework, this callback was
invoked even in the event of Freeze and Hibernate. Hence, added the load of
unnecessary function-calls.

The goal can be achieved by binding the callback with only
"lxfb_pm_ops.suspend" in the new framework. This also avoids the step of
checking "if (state.event == PM_EVENT_SUSPEND)" every time the callback is
invoked.
Signed-off-by: default avatarVaibhav Gupta <vaibhavgupta40@gmail.com>
Cc: Bjorn Helgaas <helgaas@kernel.org>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Cc: Bjorn Helgaas <bjorn@helgaas.com>
Cc: Vaibhav Gupta <vaibhav.varodek@gmail.com>
Cc: Sam Ravnborg <sam@ravnborg.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Russell King <linux@armlinux.org.uk>
Cc: Andres Salomon <dilinger@queued.net>
CC: Antonino Daplas <adaplas@gmail.com>
Cc: Shuah Khan <skhan@linuxfoundation.org>
Signed-off-by: default avatarBartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200819185654.151170-3-vaibhavgupta40@gmail.com
parent fa41f287
...@@ -29,7 +29,6 @@ struct lxfb_par { ...@@ -29,7 +29,6 @@ struct lxfb_par {
void __iomem *gp_regs; void __iomem *gp_regs;
void __iomem *dc_regs; void __iomem *dc_regs;
void __iomem *vp_regs; void __iomem *vp_regs;
#ifdef CONFIG_PM
int powered_down; int powered_down;
/* register state, for power mgmt functionality */ /* register state, for power mgmt functionality */
...@@ -50,7 +49,6 @@ struct lxfb_par { ...@@ -50,7 +49,6 @@ struct lxfb_par {
uint32_t hcoeff[DC_HFILT_COUNT * 2]; uint32_t hcoeff[DC_HFILT_COUNT * 2];
uint32_t vcoeff[DC_VFILT_COUNT]; uint32_t vcoeff[DC_VFILT_COUNT];
uint32_t vp_coeff[VP_COEFF_SIZE / 4]; uint32_t vp_coeff[VP_COEFF_SIZE / 4];
#endif
}; };
static inline unsigned int lx_get_pitch(unsigned int xres, int bpp) static inline unsigned int lx_get_pitch(unsigned int xres, int bpp)
...@@ -64,11 +62,8 @@ int lx_blank_display(struct fb_info *, int); ...@@ -64,11 +62,8 @@ int lx_blank_display(struct fb_info *, int);
void lx_set_palette_reg(struct fb_info *, unsigned int, unsigned int, void lx_set_palette_reg(struct fb_info *, unsigned int, unsigned int,
unsigned int, unsigned int); unsigned int, unsigned int);
#ifdef CONFIG_PM
int lx_powerdown(struct fb_info *info); int lx_powerdown(struct fb_info *info);
int lx_powerup(struct fb_info *info); int lx_powerup(struct fb_info *info);
#endif
/* Graphics Processor registers (table 6-29 from the data book) */ /* Graphics Processor registers (table 6-29 from the data book) */
enum gp_registers { enum gp_registers {
......
...@@ -443,17 +443,14 @@ static struct fb_info *lxfb_init_fbinfo(struct device *dev) ...@@ -443,17 +443,14 @@ static struct fb_info *lxfb_init_fbinfo(struct device *dev)
return info; return info;
} }
#ifdef CONFIG_PM static int __maybe_unused lxfb_suspend(struct device *dev)
static int lxfb_suspend(struct pci_dev *pdev, pm_message_t state)
{ {
struct fb_info *info = pci_get_drvdata(pdev); struct fb_info *info = dev_get_drvdata(dev);
if (state.event == PM_EVENT_SUSPEND) {
console_lock(); console_lock();
lx_powerdown(info); lx_powerdown(info);
fb_set_suspend(info, 1); fb_set_suspend(info, 1);
console_unlock(); console_unlock();
}
/* there's no point in setting PCI states; we emulate PCI, so /* there's no point in setting PCI states; we emulate PCI, so
* we don't end up getting power savings anyways */ * we don't end up getting power savings anyways */
...@@ -461,9 +458,9 @@ static int lxfb_suspend(struct pci_dev *pdev, pm_message_t state) ...@@ -461,9 +458,9 @@ static int lxfb_suspend(struct pci_dev *pdev, pm_message_t state)
return 0; return 0;
} }
static int lxfb_resume(struct pci_dev *pdev) static int __maybe_unused lxfb_resume(struct device *dev)
{ {
struct fb_info *info = pci_get_drvdata(pdev); struct fb_info *info = dev_get_drvdata(dev);
int ret; int ret;
console_lock(); console_lock();
...@@ -477,10 +474,6 @@ static int lxfb_resume(struct pci_dev *pdev) ...@@ -477,10 +474,6 @@ static int lxfb_resume(struct pci_dev *pdev)
console_unlock(); console_unlock();
return 0; return 0;
} }
#else
#define lxfb_suspend NULL
#define lxfb_resume NULL
#endif
static int lxfb_probe(struct pci_dev *pdev, const struct pci_device_id *id) static int lxfb_probe(struct pci_dev *pdev, const struct pci_device_id *id)
{ {
...@@ -600,13 +593,23 @@ static struct pci_device_id lxfb_id_table[] = { ...@@ -600,13 +593,23 @@ static struct pci_device_id lxfb_id_table[] = {
MODULE_DEVICE_TABLE(pci, lxfb_id_table); MODULE_DEVICE_TABLE(pci, lxfb_id_table);
static const struct dev_pm_ops lxfb_pm_ops = {
#ifdef CONFIG_PM_SLEEP
.suspend = lxfb_suspend,
.resume = lxfb_resume,
.freeze = NULL,
.thaw = lxfb_resume,
.poweroff = NULL,
.restore = lxfb_resume,
#endif
};
static struct pci_driver lxfb_driver = { static struct pci_driver lxfb_driver = {
.name = "lxfb", .name = "lxfb",
.id_table = lxfb_id_table, .id_table = lxfb_id_table,
.probe = lxfb_probe, .probe = lxfb_probe,
.remove = lxfb_remove, .remove = lxfb_remove,
.suspend = lxfb_suspend, .driver.pm = &lxfb_pm_ops,
.resume = lxfb_resume,
}; };
#ifndef MODULE #ifndef MODULE
......
...@@ -580,8 +580,6 @@ int lx_blank_display(struct fb_info *info, int blank_mode) ...@@ -580,8 +580,6 @@ int lx_blank_display(struct fb_info *info, int blank_mode)
return 0; return 0;
} }
#ifdef CONFIG_PM
static void lx_save_regs(struct lxfb_par *par) static void lx_save_regs(struct lxfb_par *par)
{ {
uint32_t filt; uint32_t filt;
...@@ -837,5 +835,3 @@ int lx_powerup(struct fb_info *info) ...@@ -837,5 +835,3 @@ int lx_powerup(struct fb_info *info)
par->powered_down = 0; par->powered_down = 0;
return 0; return 0;
} }
#endif
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