162306a36Sopenharmony_ci// SPDX-License-Identifier: ISC
262306a36Sopenharmony_ci/* Copyright (C) 2019 MediaTek Inc.
362306a36Sopenharmony_ci *
462306a36Sopenharmony_ci * Author: Ryder Lee <ryder.lee@mediatek.com>
562306a36Sopenharmony_ci *         Felix Fietkau <nbd@nbd.name>
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#include <linux/kernel.h>
962306a36Sopenharmony_ci#include <linux/module.h>
1062306a36Sopenharmony_ci#include <linux/platform_device.h>
1162306a36Sopenharmony_ci#include <linux/regmap.h>
1262306a36Sopenharmony_ci#include <linux/mfd/syscon.h>
1362306a36Sopenharmony_ci#include <linux/of.h>
1462306a36Sopenharmony_ci#include "mt7615.h"
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ciint mt7622_wmac_init(struct mt7615_dev *dev)
1762306a36Sopenharmony_ci{
1862306a36Sopenharmony_ci	struct device_node *np = dev->mt76.dev->of_node;
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci	if (!is_mt7622(&dev->mt76))
2162306a36Sopenharmony_ci		return 0;
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci	dev->infracfg = syscon_regmap_lookup_by_phandle(np, "mediatek,infracfg");
2462306a36Sopenharmony_ci	if (IS_ERR(dev->infracfg)) {
2562306a36Sopenharmony_ci		dev_err(dev->mt76.dev, "Cannot find infracfg controller\n");
2662306a36Sopenharmony_ci		return PTR_ERR(dev->infracfg);
2762306a36Sopenharmony_ci	}
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci	return 0;
3062306a36Sopenharmony_ci}
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_cistatic int mt7622_wmac_probe(struct platform_device *pdev)
3362306a36Sopenharmony_ci{
3462306a36Sopenharmony_ci	void __iomem *mem_base;
3562306a36Sopenharmony_ci	int irq;
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci	irq = platform_get_irq(pdev, 0);
3862306a36Sopenharmony_ci	if (irq < 0)
3962306a36Sopenharmony_ci		return irq;
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci	mem_base = devm_platform_get_and_ioremap_resource(pdev, 0, NULL);
4262306a36Sopenharmony_ci	if (IS_ERR(mem_base))
4362306a36Sopenharmony_ci		return PTR_ERR(mem_base);
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci	return mt7615_mmio_probe(&pdev->dev, mem_base, irq, mt7615e_reg_map);
4662306a36Sopenharmony_ci}
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_cistatic int mt7622_wmac_remove(struct platform_device *pdev)
4962306a36Sopenharmony_ci{
5062306a36Sopenharmony_ci	struct mt7615_dev *dev = platform_get_drvdata(pdev);
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci	mt7615_unregister_device(dev);
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci	return 0;
5562306a36Sopenharmony_ci}
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_cistatic const struct of_device_id mt7622_wmac_of_match[] = {
5862306a36Sopenharmony_ci	{ .compatible = "mediatek,mt7622-wmac" },
5962306a36Sopenharmony_ci	{},
6062306a36Sopenharmony_ci};
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_cistruct platform_driver mt7622_wmac_driver = {
6362306a36Sopenharmony_ci	.driver = {
6462306a36Sopenharmony_ci		.name = "mt7622-wmac",
6562306a36Sopenharmony_ci		.of_match_table = mt7622_wmac_of_match,
6662306a36Sopenharmony_ci	},
6762306a36Sopenharmony_ci	.probe = mt7622_wmac_probe,
6862306a36Sopenharmony_ci	.remove = mt7622_wmac_remove,
6962306a36Sopenharmony_ci};
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ciMODULE_FIRMWARE(MT7622_FIRMWARE_N9);
7262306a36Sopenharmony_ciMODULE_FIRMWARE(MT7622_ROM_PATCH);
73