blob: 4488b1601126fd4849398f94e057788bcaab023a [file] [log] [blame]
Peng Fane2fd36cc2016-02-03 10:06:07 +08001
2/*
3 * Copyright (C) 2016 Peng Fan <van.freenix@gmail.com>
4 *
5 * SPDX-License-Identifier: GPL-2.0+
6 */
7
8#include <dm/device.h>
9#include <dm/pinctrl.h>
10
11#include "pinctrl-imx.h"
12
13static struct imx_pinctrl_soc_info imx6_pinctrl_soc_info;
14
Peng Fan83c8f842016-08-11 14:02:52 +080015static struct imx_pinctrl_soc_info imx6_snvs_pinctrl_soc_info = {
16 .flags = ZERO_OFFSET_VALID,
17};
18
Peng Fane2fd36cc2016-02-03 10:06:07 +080019static int imx6_pinctrl_probe(struct udevice *dev)
20{
21 struct imx_pinctrl_soc_info *info =
22 (struct imx_pinctrl_soc_info *)dev_get_driver_data(dev);
23
24 return imx_pinctrl_probe(dev, info);
25}
26
27static const struct udevice_id imx6_pinctrl_match[] = {
28 { .compatible = "fsl,imx6q-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
29 { .compatible = "fsl,imx6dl-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
30 { .compatible = "fsl,imx6sl-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
Peng Fanf75b4802016-12-11 19:24:35 +080031 { .compatible = "fsl,imx6sll-iomuxc-snvs", .data = (ulong)&imx6_snvs_pinctrl_soc_info },
32 { .compatible = "fsl,imx6sll-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
Peng Fane2fd36cc2016-02-03 10:06:07 +080033 { .compatible = "fsl,imx6sx-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
34 { .compatible = "fsl,imx6ul-iomuxc", .data = (ulong)&imx6_pinctrl_soc_info },
Peng Fan83c8f842016-08-11 14:02:52 +080035 { .compatible = "fsl,imx6ull-iomuxc-snvs", .data = (ulong)&imx6_snvs_pinctrl_soc_info },
Peng Fane2fd36cc2016-02-03 10:06:07 +080036 { /* sentinel */ }
37};
38
39U_BOOT_DRIVER(imx6_pinctrl) = {
40 .name = "imx6-pinctrl",
41 .id = UCLASS_PINCTRL,
42 .of_match = of_match_ptr(imx6_pinctrl_match),
43 .probe = imx6_pinctrl_probe,
44 .remove = imx_pinctrl_remove,
45 .priv_auto_alloc_size = sizeof(struct imx_pinctrl_priv),
46 .ops = &imx_pinctrl_ops,
47 .flags = DM_FLAG_PRE_RELOC,
48};