18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Driver for Altera Partial Reconfiguration IP Core 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 2016-2017 Intel Corporation 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * Based on socfpga-a10.c Copyright (C) 2015-2016 Altera Corporation 88c2ecf20Sopenharmony_ci * by Alan Tull <atull@opensource.altera.com> 98c2ecf20Sopenharmony_ci */ 108c2ecf20Sopenharmony_ci#include <linux/fpga/altera-pr-ip-core.h> 118c2ecf20Sopenharmony_ci#include <linux/module.h> 128c2ecf20Sopenharmony_ci#include <linux/of_device.h> 138c2ecf20Sopenharmony_ci 148c2ecf20Sopenharmony_cistatic int alt_pr_platform_probe(struct platform_device *pdev) 158c2ecf20Sopenharmony_ci{ 168c2ecf20Sopenharmony_ci struct device *dev = &pdev->dev; 178c2ecf20Sopenharmony_ci void __iomem *reg_base; 188c2ecf20Sopenharmony_ci struct resource *res; 198c2ecf20Sopenharmony_ci 208c2ecf20Sopenharmony_ci /* First mmio base is for register access */ 218c2ecf20Sopenharmony_ci res = platform_get_resource(pdev, IORESOURCE_MEM, 0); 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_ci reg_base = devm_ioremap_resource(dev, res); 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci if (IS_ERR(reg_base)) 268c2ecf20Sopenharmony_ci return PTR_ERR(reg_base); 278c2ecf20Sopenharmony_ci 288c2ecf20Sopenharmony_ci return alt_pr_register(dev, reg_base); 298c2ecf20Sopenharmony_ci} 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_cistatic int alt_pr_platform_remove(struct platform_device *pdev) 328c2ecf20Sopenharmony_ci{ 338c2ecf20Sopenharmony_ci struct device *dev = &pdev->dev; 348c2ecf20Sopenharmony_ci 358c2ecf20Sopenharmony_ci alt_pr_unregister(dev); 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_ci return 0; 388c2ecf20Sopenharmony_ci} 398c2ecf20Sopenharmony_ci 408c2ecf20Sopenharmony_cistatic const struct of_device_id alt_pr_of_match[] = { 418c2ecf20Sopenharmony_ci { .compatible = "altr,a10-pr-ip", }, 428c2ecf20Sopenharmony_ci {}, 438c2ecf20Sopenharmony_ci}; 448c2ecf20Sopenharmony_ci 458c2ecf20Sopenharmony_ciMODULE_DEVICE_TABLE(of, alt_pr_of_match); 468c2ecf20Sopenharmony_ci 478c2ecf20Sopenharmony_cistatic struct platform_driver alt_pr_platform_driver = { 488c2ecf20Sopenharmony_ci .probe = alt_pr_platform_probe, 498c2ecf20Sopenharmony_ci .remove = alt_pr_platform_remove, 508c2ecf20Sopenharmony_ci .driver = { 518c2ecf20Sopenharmony_ci .name = "alt_a10_pr_ip", 528c2ecf20Sopenharmony_ci .of_match_table = alt_pr_of_match, 538c2ecf20Sopenharmony_ci }, 548c2ecf20Sopenharmony_ci}; 558c2ecf20Sopenharmony_ci 568c2ecf20Sopenharmony_cimodule_platform_driver(alt_pr_platform_driver); 578c2ecf20Sopenharmony_ciMODULE_AUTHOR("Matthew Gerlach <matthew.gerlach@linux.intel.com>"); 588c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Altera Partial Reconfiguration IP Platform Driver"); 598c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL v2"); 60