// SPDX-License-Identifier: GPL-2.0 #include #include #include #include #include #include static const struct mfd_cell mpfs_mss_top_sysreg_devs[] = { MFD_CELL_NAME("mpfs-reset"), }; static int mpfs_mss_top_sysreg_probe(struct platform_device *pdev) { struct device *dev = &pdev->dev; int ret; ret = mfd_add_devices(dev, PLATFORM_DEVID_NONE, mpfs_mss_top_sysreg_devs, ARRAY_SIZE(mpfs_mss_top_sysreg_devs) , NULL, 0, NULL); if (ret) return ret; return devm_of_platform_populate(dev); } static const struct of_device_id mpfs_mss_top_sysreg_of_match[] = { { .compatible = "microchip,mpfs-mss-top-sysreg", }, {}, }; MODULE_DEVICE_TABLE(of, mpfs_mss_top_sysreg_of_match); static struct platform_driver mpfs_mss_top_sysreg_driver = { .driver = { .name = "mpfs-mss-top-sysreg", .of_match_table = mpfs_mss_top_sysreg_of_match, }, .probe = mpfs_mss_top_sysreg_probe, }; module_platform_driver(mpfs_mss_top_sysreg_driver); MODULE_LICENSE("GPL"); MODULE_AUTHOR("Conor Dooley "); MODULE_DESCRIPTION("PolarFire SoC mss top sysreg driver");