From 083c2048f53b5373de0fc463d4ad0787b66c8167 Mon Sep 17 00:00:00 2001 From: Mike Rapoport Date: Mon, 26 Oct 2015 09:06:03 +0200 Subject: [PATCH] staging: sm750fb: use sm750_dev with pci_{get, set}_drvdata Use sm750_dev as private driver data for the PCI device Signed-off-by: Mike Rapoport Signed-off-by: Greg Kroah-Hartman --- drivers/staging/sm750fb/sm750.c | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/drivers/staging/sm750fb/sm750.c b/drivers/staging/sm750fb/sm750.c index ac8e2a460ce8..707e91dbfc75 100644 --- a/drivers/staging/sm750fb/sm750.c +++ b/drivers/staging/sm750fb/sm750.c @@ -395,6 +395,7 @@ static inline unsigned int chan_to_field(unsigned int chan, static int lynxfb_suspend(struct pci_dev *pdev, pm_message_t mesg) { struct fb_info *info; + struct sm750_dev *sm750_dev; struct lynx_share *share; int ret; @@ -402,7 +403,8 @@ static int lynxfb_suspend(struct pci_dev *pdev, pm_message_t mesg) return 0; ret = 0; - share = pci_get_drvdata(pdev); + sm750_dev = pci_get_drvdata(pdev); + share = &sm750_dev->share; switch (mesg.event) { case PM_EVENT_FREEZE: case PM_EVENT_PRETHAW: @@ -453,8 +455,8 @@ static int lynxfb_resume(struct pci_dev *pdev) int ret; ret = 0; - share = pci_get_drvdata(pdev); - sm750_dev = container_of(share, struct sm750_dev, share); + sm750_dev = pci_get_drvdata(pdev); + share = &sm750_dev->share; console_lock(); @@ -1103,7 +1105,7 @@ static int lynxfb_pci_probe(struct pci_dev *pdev, pr_info("sm%3x mmio address = %p\n", share->devid, share->pvReg); - pci_set_drvdata(pdev, share); + pci_set_drvdata(pdev, sm750_dev); /* call chipInit routine */ hw_sm750_inithw(sm750_dev, pdev); @@ -1183,7 +1185,8 @@ static void lynxfb_pci_remove(struct pci_dev *pdev) int cnt; cnt = 2; - share = pci_get_drvdata(pdev); + sm750_dev = pci_get_drvdata(pdev); + share = &sm750_dev->share; while (cnt-- > 0) { info = share->fbinfo[cnt]; @@ -1199,7 +1202,6 @@ static void lynxfb_pci_remove(struct pci_dev *pdev) iounmap(share->pvReg); iounmap(share->pvMem); - sm750_dev = container_of(share, struct sm750_dev, share); kfree(g_settings); kfree(sm750_dev); pci_set_drvdata(pdev, NULL); -- 2.34.1