162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Platform driver for the Intel SCU.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2019, Intel Corporation
662306a36Sopenharmony_ci * Authors: Divya Sasidharan <divya.s.sasidharan@intel.com>
762306a36Sopenharmony_ci *	    Mika Westerberg <mika.westerberg@linux.intel.com>
862306a36Sopenharmony_ci *	    Rajmohan Mani <rajmohan.mani@intel.com>
962306a36Sopenharmony_ci */
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <linux/err.h>
1262306a36Sopenharmony_ci#include <linux/errno.h>
1362306a36Sopenharmony_ci#include <linux/ioport.h>
1462306a36Sopenharmony_ci#include <linux/mod_devicetable.h>
1562306a36Sopenharmony_ci#include <linux/module.h>
1662306a36Sopenharmony_ci#include <linux/platform_device.h>
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci#include <asm/intel_scu_ipc.h>
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_cistatic int intel_scu_platform_probe(struct platform_device *pdev)
2162306a36Sopenharmony_ci{
2262306a36Sopenharmony_ci	struct intel_scu_ipc_data scu_data = {};
2362306a36Sopenharmony_ci	struct intel_scu_ipc_dev *scu;
2462306a36Sopenharmony_ci	const struct resource *res;
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci	scu_data.irq = platform_get_irq_optional(pdev, 0);
2762306a36Sopenharmony_ci	res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
2862306a36Sopenharmony_ci	if (!res)
2962306a36Sopenharmony_ci		return -ENOMEM;
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci	scu_data.mem = *res;
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci	scu = devm_intel_scu_ipc_register(&pdev->dev, &scu_data);
3462306a36Sopenharmony_ci	if (IS_ERR(scu))
3562306a36Sopenharmony_ci		return PTR_ERR(scu);
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci	platform_set_drvdata(pdev, scu);
3862306a36Sopenharmony_ci	return 0;
3962306a36Sopenharmony_ci}
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_cistatic const struct acpi_device_id intel_scu_acpi_ids[] = {
4262306a36Sopenharmony_ci	{ "INTC1026" },
4362306a36Sopenharmony_ci	{}
4462306a36Sopenharmony_ci};
4562306a36Sopenharmony_ciMODULE_DEVICE_TABLE(acpi, intel_scu_acpi_ids);
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_cistatic struct platform_driver intel_scu_platform_driver = {
4862306a36Sopenharmony_ci	.probe = intel_scu_platform_probe,
4962306a36Sopenharmony_ci	.driver = {
5062306a36Sopenharmony_ci		.name = "intel_scu",
5162306a36Sopenharmony_ci		.acpi_match_table = intel_scu_acpi_ids,
5262306a36Sopenharmony_ci	},
5362306a36Sopenharmony_ci};
5462306a36Sopenharmony_cimodule_platform_driver(intel_scu_platform_driver);
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ciMODULE_AUTHOR("Divya Sasidharan <divya.s.sasidharan@intel.com>");
5762306a36Sopenharmony_ciMODULE_AUTHOR("Mika Westerberg <mika.westerberg@linux.intel.com");
5862306a36Sopenharmony_ciMODULE_AUTHOR("Rajmohan Mani <rajmohan.mani@intel.com>");
5962306a36Sopenharmony_ciMODULE_DESCRIPTION("Intel SCU platform driver");
6062306a36Sopenharmony_ciMODULE_LICENSE("GPL v2");
61