pinctrl-anorak.c 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
  4. */
  5. #include <linux/module.h>
  6. #include <linux/of.h>
  7. #include <linux/platform_device.h>
  8. #include <linux/pinctrl/pinctrl.h>
  9. #include "pinctrl-msm.h"
  10. #include "pinctrl-anorak.h"
  11. static const struct msm_pinctrl_soc_data anorak_pinctrl = {
  12. .pins = anorak_pins,
  13. .npins = ARRAY_SIZE(anorak_pins),
  14. .functions = anorak_functions,
  15. .nfunctions = ARRAY_SIZE(anorak_functions),
  16. .groups = anorak_groups,
  17. .ngroups = ARRAY_SIZE(anorak_groups),
  18. .ngpios = 225,
  19. .qup_regs = anorak_qup_regs,
  20. .nqup_regs = ARRAY_SIZE(anorak_qup_regs),
  21. .wakeirq_map = anorak_pdc_map,
  22. .nwakeirq_map = ARRAY_SIZE(anorak_pdc_map),
  23. };
  24. static int anorak_pinctrl_probe(struct platform_device *pdev)
  25. {
  26. return msm_pinctrl_probe(pdev, &anorak_pinctrl);
  27. }
  28. static const struct of_device_id anorak_pinctrl_of_match[] = {
  29. { .compatible = "qcom,anorak-pinctrl", },
  30. { },
  31. };
  32. static struct platform_driver anorak_pinctrl_driver = {
  33. .driver = {
  34. .name = "anorak-pinctrl",
  35. .of_match_table = anorak_pinctrl_of_match,
  36. },
  37. .probe = anorak_pinctrl_probe,
  38. .remove = msm_pinctrl_remove,
  39. };
  40. static int __init anorak_pinctrl_init(void)
  41. {
  42. return platform_driver_register(&anorak_pinctrl_driver);
  43. }
  44. arch_initcall(anorak_pinctrl_init);
  45. static void __exit anorak_pinctrl_exit(void)
  46. {
  47. platform_driver_unregister(&anorak_pinctrl_driver);
  48. }
  49. module_exit(anorak_pinctrl_exit);
  50. MODULE_DESCRIPTION("QTI anorak pinctrl driver");
  51. MODULE_LICENSE("GPL");
  52. MODULE_DEVICE_TABLE(of, anorak_pinctrl_of_match);