135da599fSFelix Fietkau // SPDX-License-Identifier: ISC
235da599fSFelix Fietkau /* Copyright (C) 2019 MediaTek Inc.
335da599fSFelix Fietkau *
435da599fSFelix Fietkau * Author: Ryder Lee <ryder.lee@mediatek.com>
535da599fSFelix Fietkau * Felix Fietkau <nbd@nbd.name>
635da599fSFelix Fietkau */
735da599fSFelix Fietkau
835da599fSFelix Fietkau #include <linux/kernel.h>
935da599fSFelix Fietkau #include <linux/module.h>
1035da599fSFelix Fietkau #include <linux/platform_device.h>
1135da599fSFelix Fietkau #include <linux/regmap.h>
1235da599fSFelix Fietkau #include <linux/mfd/syscon.h>
1335da599fSFelix Fietkau #include <linux/of.h>
1435da599fSFelix Fietkau #include "mt7615.h"
1535da599fSFelix Fietkau
mt7622_wmac_init(struct mt7615_dev * dev)1635da599fSFelix Fietkau int mt7622_wmac_init(struct mt7615_dev *dev)
1735da599fSFelix Fietkau {
1835da599fSFelix Fietkau struct device_node *np = dev->mt76.dev->of_node;
1935da599fSFelix Fietkau
2035da599fSFelix Fietkau if (!is_mt7622(&dev->mt76))
2135da599fSFelix Fietkau return 0;
2235da599fSFelix Fietkau
2335da599fSFelix Fietkau dev->infracfg = syscon_regmap_lookup_by_phandle(np, "mediatek,infracfg");
2435da599fSFelix Fietkau if (IS_ERR(dev->infracfg)) {
2535da599fSFelix Fietkau dev_err(dev->mt76.dev, "Cannot find infracfg controller\n");
2635da599fSFelix Fietkau return PTR_ERR(dev->infracfg);
2735da599fSFelix Fietkau }
2835da599fSFelix Fietkau
2935da599fSFelix Fietkau return 0;
3035da599fSFelix Fietkau }
3135da599fSFelix Fietkau
mt7622_wmac_probe(struct platform_device * pdev)3235da599fSFelix Fietkau static int mt7622_wmac_probe(struct platform_device *pdev)
3335da599fSFelix Fietkau {
3435da599fSFelix Fietkau void __iomem *mem_base;
3535da599fSFelix Fietkau int irq;
3635da599fSFelix Fietkau
3735da599fSFelix Fietkau irq = platform_get_irq(pdev, 0);
38373ab334SMarkus Elfring if (irq < 0)
3935da599fSFelix Fietkau return irq;
4035da599fSFelix Fietkau
41*9e2b7b04SYang Yingliang mem_base = devm_platform_get_and_ioremap_resource(pdev, 0, NULL);
428e99ca3fSGuobin Huang if (IS_ERR(mem_base))
4335da599fSFelix Fietkau return PTR_ERR(mem_base);
4435da599fSFelix Fietkau
4594f83b66SLorenzo Bianconi return mt7615_mmio_probe(&pdev->dev, mem_base, irq, mt7615e_reg_map);
4635da599fSFelix Fietkau }
4735da599fSFelix Fietkau
mt7622_wmac_remove(struct platform_device * pdev)4835da599fSFelix Fietkau static int mt7622_wmac_remove(struct platform_device *pdev)
4935da599fSFelix Fietkau {
5035da599fSFelix Fietkau struct mt7615_dev *dev = platform_get_drvdata(pdev);
5135da599fSFelix Fietkau
5235da599fSFelix Fietkau mt7615_unregister_device(dev);
5335da599fSFelix Fietkau
5435da599fSFelix Fietkau return 0;
5535da599fSFelix Fietkau }
5635da599fSFelix Fietkau
5735da599fSFelix Fietkau static const struct of_device_id mt7622_wmac_of_match[] = {
5835da599fSFelix Fietkau { .compatible = "mediatek,mt7622-wmac" },
5935da599fSFelix Fietkau {},
6035da599fSFelix Fietkau };
6135da599fSFelix Fietkau
6235da599fSFelix Fietkau struct platform_driver mt7622_wmac_driver = {
6335da599fSFelix Fietkau .driver = {
6435da599fSFelix Fietkau .name = "mt7622-wmac",
6535da599fSFelix Fietkau .of_match_table = mt7622_wmac_of_match,
6635da599fSFelix Fietkau },
6735da599fSFelix Fietkau .probe = mt7622_wmac_probe,
6835da599fSFelix Fietkau .remove = mt7622_wmac_remove,
6935da599fSFelix Fietkau };
7035da599fSFelix Fietkau
7135da599fSFelix Fietkau MODULE_FIRMWARE(MT7622_FIRMWARE_N9);
7235da599fSFelix Fietkau MODULE_FIRMWARE(MT7622_ROM_PATCH);
73