162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Intel Elkhart Lake PSE GPIO driver 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (c) 2023 Intel Corporation. 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Authors: Pandith N <pandith.n@intel.com> 862306a36Sopenharmony_ci * Raag Jadav <raag.jadav@intel.com> 962306a36Sopenharmony_ci */ 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include <linux/device.h> 1262306a36Sopenharmony_ci#include <linux/err.h> 1362306a36Sopenharmony_ci#include <linux/module.h> 1462306a36Sopenharmony_ci#include <linux/platform_device.h> 1562306a36Sopenharmony_ci#include <linux/pm.h> 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci#include "gpio-tangier.h" 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci/* Each Intel EHL PSE GPIO Controller has 30 GPIO pins */ 2062306a36Sopenharmony_ci#define EHL_PSE_NGPIO 30 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_cistatic int ehl_gpio_probe(struct platform_device *pdev) 2362306a36Sopenharmony_ci{ 2462306a36Sopenharmony_ci struct device *dev = &pdev->dev; 2562306a36Sopenharmony_ci struct tng_gpio *priv; 2662306a36Sopenharmony_ci int irq, ret; 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci irq = platform_get_irq(pdev, 0); 2962306a36Sopenharmony_ci if (irq < 0) 3062306a36Sopenharmony_ci return irq; 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_ci priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL); 3362306a36Sopenharmony_ci if (!priv) 3462306a36Sopenharmony_ci return -ENOMEM; 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci priv->reg_base = devm_platform_ioremap_resource(pdev, 0); 3762306a36Sopenharmony_ci if (IS_ERR(priv->reg_base)) 3862306a36Sopenharmony_ci return PTR_ERR(priv->reg_base); 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci priv->dev = dev; 4162306a36Sopenharmony_ci priv->irq = irq; 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci priv->info.base = -1; 4462306a36Sopenharmony_ci priv->info.ngpio = EHL_PSE_NGPIO; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci priv->wake_regs.gwmr = GWMR_EHL; 4762306a36Sopenharmony_ci priv->wake_regs.gwsr = GWSR_EHL; 4862306a36Sopenharmony_ci priv->wake_regs.gsir = GSIR_EHL; 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_ci ret = devm_tng_gpio_probe(dev, priv); 5162306a36Sopenharmony_ci if (ret) 5262306a36Sopenharmony_ci return dev_err_probe(dev, ret, "tng_gpio_probe error\n"); 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_ci platform_set_drvdata(pdev, priv); 5562306a36Sopenharmony_ci return 0; 5662306a36Sopenharmony_ci} 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_cistatic int ehl_gpio_suspend(struct device *dev) 5962306a36Sopenharmony_ci{ 6062306a36Sopenharmony_ci return tng_gpio_suspend(dev); 6162306a36Sopenharmony_ci} 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_cistatic int ehl_gpio_resume(struct device *dev) 6462306a36Sopenharmony_ci{ 6562306a36Sopenharmony_ci return tng_gpio_resume(dev); 6662306a36Sopenharmony_ci} 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_cistatic DEFINE_SIMPLE_DEV_PM_OPS(ehl_gpio_pm_ops, ehl_gpio_suspend, ehl_gpio_resume); 6962306a36Sopenharmony_ci 7062306a36Sopenharmony_cistatic const struct platform_device_id ehl_gpio_ids[] = { 7162306a36Sopenharmony_ci { "gpio-elkhartlake" }, 7262306a36Sopenharmony_ci { } 7362306a36Sopenharmony_ci}; 7462306a36Sopenharmony_ciMODULE_DEVICE_TABLE(platform, ehl_gpio_ids); 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_cistatic struct platform_driver ehl_gpio_driver = { 7762306a36Sopenharmony_ci .driver = { 7862306a36Sopenharmony_ci .name = "gpio-elkhartlake", 7962306a36Sopenharmony_ci .pm = pm_sleep_ptr(&ehl_gpio_pm_ops), 8062306a36Sopenharmony_ci }, 8162306a36Sopenharmony_ci .probe = ehl_gpio_probe, 8262306a36Sopenharmony_ci .id_table = ehl_gpio_ids, 8362306a36Sopenharmony_ci}; 8462306a36Sopenharmony_cimodule_platform_driver(ehl_gpio_driver); 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_ciMODULE_AUTHOR("Pandith N <pandith.n@intel.com>"); 8762306a36Sopenharmony_ciMODULE_AUTHOR("Raag Jadav <raag.jadav@intel.com>"); 8862306a36Sopenharmony_ciMODULE_DESCRIPTION("Intel Elkhart Lake PSE GPIO driver"); 8962306a36Sopenharmony_ciMODULE_LICENSE("GPL"); 9062306a36Sopenharmony_ciMODULE_IMPORT_NS(GPIO_TANGIER); 91