[PATCH v1] mtd: rawnand: cafe: Use generic power management'

Bjorn Helgaas helgaas at kernel.org
Tue Feb 17 07:55:25 PST 2026


On Mon, Feb 16, 2026 at 09:02:44AM +0000, Vaibhav Gupta wrote:
> Switch to the generic PCI power management framework and remove legacy
> callbacks like .resume(). With the generic framework, the standard PCI
> related work like:
> 	- pci_save/restore_state()
> 	- pci_enable/disable_device()
> 	- pci_set_power_state()
> is handled by the PCI core.
> 
> This driver should implement only cafe_nand specific operations in its
> callback function for resume.

Looks good to me, thanks for doing this!

I think the commit log is a bit overly specific since this driver
never did any of the PCI-related work it mentions.  IMO something like
this would be sufficient:

  Switch from PCI power management to the generic power management
  framework so the pci_driver hooks can eventually be retired.

Reviewed-by: Bjorn Helgaas <bhelgaas at google.com>

> Signed-off-by: Vaibhav Gupta <vaibhavgupta40 at gmail.com>
> ---
>  drivers/mtd/nand/raw/cafe_nand.c | 7 +++++--
>  1 file changed, 5 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/mtd/nand/raw/cafe_nand.c b/drivers/mtd/nand/raw/cafe_nand.c
> index 66385c4fb994..af771c379ec1 100644
> --- a/drivers/mtd/nand/raw/cafe_nand.c
> +++ b/drivers/mtd/nand/raw/cafe_nand.c
> @@ -837,9 +837,10 @@ static const struct pci_device_id cafe_nand_tbl[] = {
>  
>  MODULE_DEVICE_TABLE(pci, cafe_nand_tbl);
>  
> -static int cafe_nand_resume(struct pci_dev *pdev)
> +static int cafe_nand_resume(struct device *dev)
>  {
>  	uint32_t ctrl;
> +	struct pci_dev *pdev = to_pci_dev(dev);
>  	struct mtd_info *mtd = pci_get_drvdata(pdev);
>  	struct nand_chip *chip = mtd_to_nand(mtd);
>  	struct cafe_priv *cafe = nand_get_controller_data(chip);
> @@ -877,12 +878,14 @@ static int cafe_nand_resume(struct pci_dev *pdev)
>  	return 0;
>  }
>  
> +static DEFINE_SIMPLE_DEV_PM_OPS(cafe_nand_ops, NULL, cafe_nand_resume);
> +
>  static struct pci_driver cafe_nand_pci_driver = {
>  	.name = "CAFÉ NAND",
>  	.id_table = cafe_nand_tbl,
>  	.probe = cafe_nand_probe,
>  	.remove = cafe_nand_remove,
> -	.resume = cafe_nand_resume,
> +	.driver.pm = &cafe_nand_ops,
>  };
>  
>  module_pci_driver(cafe_nand_pci_driver);
> -- 
> 2.53.0
> 



More information about the linux-mtd mailing list