blob: 4db224d32a47c9242f7b6c8e7798545f8ecf1c3b [file] [log] [blame]
Peng Fanf6cbb452022-07-26 16:40:42 +08001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright 2022 NXP
4 */
5
6#include <dm/device.h>
7#include <dm/pinctrl.h>
8
9#include "pinctrl-imx.h"
10
11static struct imx_pinctrl_soc_info imx93_pinctrl_soc_info __section(".data") = {
12 .flags = ZERO_OFFSET_VALID,
13};
14
15static int imx93_pinctrl_probe(struct udevice *dev)
16{
17 struct imx_pinctrl_soc_info *info =
18 (struct imx_pinctrl_soc_info *)dev_get_driver_data(dev);
19
20 return imx_pinctrl_probe(dev, info);
21}
22
23static const struct udevice_id imx93_pinctrl_match[] = {
24 { .compatible = "fsl,imx93-iomuxc", .data = (ulong)&imx93_pinctrl_soc_info },
Peng Fan82ef2872024-12-03 23:42:52 +080025 { .compatible = "fsl,imx91-iomuxc", .data = (ulong)&imx93_pinctrl_soc_info },
Peng Fanf6cbb452022-07-26 16:40:42 +080026 { /* sentinel */ }
27};
28
Marek Vasut5b213c32025-01-24 15:50:51 +010029static const struct pinctrl_ops imx93_pinctrl_ops = {
Marek Vasut4646bd92025-01-24 15:50:50 +010030 .set_state = imx_pinctrl_set_state,
31};
32
Peng Fanf6cbb452022-07-26 16:40:42 +080033U_BOOT_DRIVER(imx93_pinctrl) = {
34 .name = "imx93-pinctrl",
35 .id = UCLASS_PINCTRL,
36 .of_match = of_match_ptr(imx93_pinctrl_match),
37 .probe = imx93_pinctrl_probe,
38 .remove = imx_pinctrl_remove,
39 .priv_auto = sizeof(struct imx_pinctrl_priv),
Marek Vasut5b213c32025-01-24 15:50:51 +010040 .ops = &imx93_pinctrl_ops,
Peng Fanf6cbb452022-07-26 16:40:42 +080041 .flags = DM_FLAG_PRE_RELOC,
42};