blob: 930de19075a73221712c4913765e253308a0e14d [file] [log] [blame]
Peng Fane84d11f2018-10-18 14:28:28 +02001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright 2018 NXP
4 */
5
Simon Glass3ba929a2020-10-30 21:38:53 -06006#include <asm/global_data.h>
Peng Fane84d11f2018-10-18 14:28:28 +02007#include <dm/device.h>
8#include <dm/pinctrl.h>
9
10#include "pinctrl-imx.h"
11
12DECLARE_GLOBAL_DATA_PTR;
13
14static struct imx_pinctrl_soc_info imx8_pinctrl_soc_info = {
15 .flags = IMX8_USE_SCU,
16};
17
18static int imx8_pinctrl_probe(struct udevice *dev)
19{
20 struct imx_pinctrl_soc_info *info =
21 (struct imx_pinctrl_soc_info *)dev_get_driver_data(dev);
22
23 return imx_pinctrl_probe(dev, info);
24}
25
26static const struct udevice_id imx8_pinctrl_match[] = {
27 { .compatible = "fsl,imx8qxp-iomuxc", .data = (ulong)&imx8_pinctrl_soc_info },
Peng Fanef867732019-03-05 02:32:13 +000028 { .compatible = "fsl,imx8qm-iomuxc", .data = (ulong)&imx8_pinctrl_soc_info },
Peng Fane84d11f2018-10-18 14:28:28 +020029 { /* sentinel */ }
30};
31
Marek Vasut4646bd92025-01-24 15:50:50 +010032static const struct pinctrl_ops imx_pinctrl_ops = {
33 .set_state = imx_pinctrl_set_state,
34};
35
Peng Fane84d11f2018-10-18 14:28:28 +020036U_BOOT_DRIVER(imx8_pinctrl) = {
37 .name = "imx8_pinctrl",
38 .id = UCLASS_PINCTRL,
39 .of_match = of_match_ptr(imx8_pinctrl_match),
40 .probe = imx8_pinctrl_probe,
41 .remove = imx_pinctrl_remove,
Simon Glass8a2b47f2020-12-03 16:55:17 -070042 .priv_auto = sizeof(struct imx_pinctrl_priv),
Peng Fane84d11f2018-10-18 14:28:28 +020043 .ops = &imx_pinctrl_ops,
44 .flags = DM_FLAG_PRE_RELOC,
45};