// SPDX-License-Identifier: GPL-2.0-only /* * Copyright (c) 2020-2021, The Linux Foundation. All rights reserved. */ #include #include #include #include #include #include "pinctrl-msm.h" #include "pinctrl-waipio.h" static const struct msm_pinctrl_soc_data waipio_pinctrl = { .pins = waipio_pins, .npins = ARRAY_SIZE(waipio_pins), .functions = waipio_functions, .nfunctions = ARRAY_SIZE(waipio_functions), .groups = waipio_groups, .ngroups = ARRAY_SIZE(waipio_groups), .ngpios = 211, .wakeirq_map = waipio_pdc_map, .nwakeirq_map = ARRAY_SIZE(waipio_pdc_map), .qup_regs = waipio_qup_regs, .nqup_regs = ARRAY_SIZE(waipio_qup_regs), }; static const struct msm_pinctrl_soc_data waipio_vm_pinctrl = { .pins = waipio_pins, .npins = ARRAY_SIZE(waipio_pins), .functions = waipio_functions, .nfunctions = ARRAY_SIZE(waipio_functions), .groups = waipio_groups, .ngroups = ARRAY_SIZE(waipio_groups), .ngpios = 211, }; static int qcom_msm_pinctrl_probe(struct platform_device *pdev) { const struct msm_pinctrl_soc_data *pinctrl_data; pinctrl_data = of_device_get_match_data(&pdev->dev); if (!pinctrl_data) return -EINVAL; return msm_pinctrl_probe(pdev, pinctrl_data); } static const struct of_device_id qcom_pinctrl_of_match[] = { { .compatible = "qcom,waipio-pinctrl", .data = &waipio_pinctrl}, { .compatible = "qcom,waipio-vm-pinctrl", .data = &waipio_vm_pinctrl}, { }, }; static struct platform_driver qcom_msm_pinctrl_driver = { .driver = { .name = "qcom_msm_pinctrl", .of_match_table = qcom_pinctrl_of_match, }, .probe = qcom_msm_pinctrl_probe, .remove = msm_pinctrl_remove, }; static int __init qcom_msm_pinctrl_init(void) { return platform_driver_register(&qcom_msm_pinctrl_driver); } arch_initcall(qcom_msm_pinctrl_init); static void __exit qcom_msm_pinctrl_exit(void) { platform_driver_unregister(&qcom_msm_pinctrl_driver); } module_exit(qcom_msm_pinctrl_exit); MODULE_DESCRIPTION("QTI pinctrl driver"); MODULE_LICENSE("GPL v2"); MODULE_DEVICE_TABLE(of, qcom_pinctrl_of_match); MODULE_SOFTDEP("pre: qcom_tlmm_vm_irqchip");