blob: 5c6aac56eb7bc4be61373104f4d78a3406b9231d [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Peng Fane2fd36cc2016-02-03 10:06:07 +08002
3/*
4 * Copyright (C) 2016 Peng Fan <van.freenix@gmail.com>
Peng Fane2fd36cc2016-02-03 10:06:07 +08005 */
6
Simon Glass11c89f32017-05-17 17:18:03 -06007#include <dm.h>
Peng Fane2fd36cc2016-02-03 10:06:07 +08008#include <dm/pinctrl.h>
9
10#include "pinctrl-imx.h"
11
Lukasz Majewski45bb7672019-04-23 16:44:51 +020012static struct imx_pinctrl_soc_info imx6_pinctrl_soc_info __section(".data");
Peng Fane2fd36cc2016-02-03 10:06:07 +080013
Jagan Tekib1e81ef2017-11-21 00:02:13 +053014/* FIXME Before reloaction, BSS is overlapped with DT area */
15static struct imx_pinctrl_soc_info imx6ul_pinctrl_soc_info = {
16 .flags = ZERO_OFFSET_VALID,
17};
18
Peng Fan83c8f842016-08-11 14:02:52 +080019static struct imx_pinctrl_soc_info imx6_snvs_pinctrl_soc_info = {
20 .flags = ZERO_OFFSET_VALID,
21};
22
Peng Fane2fd36cc2016-02-03 10:06:07 +080023static const struct udevice_id imx6_pinctrl_match[] = {
24 { .compatible = "fsl,imx6q-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
25 { .compatible = "fsl,imx6dl-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
26 { .compatible = "fsl,imx6sl-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
Peng Fanf75b4802016-12-11 19:24:35 +080027 { .compatible = "fsl,imx6sll-iomuxc-snvs", .data = (ulong)&imx6_snvs_pinctrl_soc_info },
28 { .compatible = "fsl,imx6sll-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
Peng Fane2fd36cc2016-02-03 10:06:07 +080029 { .compatible = "fsl,imx6sx-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
Jagan Tekib1e81ef2017-11-21 00:02:13 +053030 { .compatible = "fsl,imx6ul-iomuxc", .data = (ulong)&imx6ul_pinctrl_soc_info },
Peng Fan83c8f842016-08-11 14:02:52 +080031 { .compatible = "fsl,imx6ull-iomuxc-snvs", .data = (ulong)&imx6_snvs_pinctrl_soc_info },
Peng Fane2fd36cc2016-02-03 10:06:07 +080032 { /* sentinel */ }
33};
34
Marek Vasut5b213c32025-01-24 15:50:51 +010035static const struct pinctrl_ops imx6_pinctrl_ops = {
Marek Vasut964d87c2025-01-24 15:50:56 +010036 .set_state = imx_pinctrl_set_state_mmio,
Marek Vasut4646bd92025-01-24 15:50:50 +010037};
38
Walter Lozano35f61872020-07-29 12:31:20 -030039U_BOOT_DRIVER(fsl_imx6q_iomuxc) = {
40 .name = "fsl_imx6q_iomuxc",
Peng Fane2fd36cc2016-02-03 10:06:07 +080041 .id = UCLASS_PINCTRL,
42 .of_match = of_match_ptr(imx6_pinctrl_match),
Marek Vasutf19a47f2025-01-24 15:50:54 +010043 .probe = imx_pinctrl_probe_mmio,
Marek Vasuta81f0d62025-01-24 15:50:55 +010044 .remove = imx_pinctrl_remove_mmio,
Simon Glass8a2b47f2020-12-03 16:55:17 -070045 .priv_auto = sizeof(struct imx_pinctrl_priv),
Marek Vasut5b213c32025-01-24 15:50:51 +010046 .ops = &imx6_pinctrl_ops,
Peng Fane2fd36cc2016-02-03 10:06:07 +080047 .flags = DM_FLAG_PRE_RELOC,
Peng Fane2fd36cc2016-02-03 10:06:07 +080048};
Walter Lozano35f61872020-07-29 12:31:20 -030049
Simon Glassdf65db82020-12-28 20:34:57 -070050DM_DRIVER_ALIAS(fsl_imx6q_iomuxc, fsl_imx6dl_iomuxc)