1 // SPDX-License-Identifier: GPL-2.0+
3 // pin-controller/pin-mux/pin-config/gpio-driver for Samsung's SoC's.
5 // Copyright (c) 2012 Samsung Electronics Co., Ltd.
6 // http://www.samsung.com
7 // Copyright (c) 2012 Linaro Ltd
8 // http://www.linaro.org
10 // Author: Thomas Abraham <thomas.ab@samsung.com>
12 // This driver implements the Samsung pinctrl driver. It supports setting up of
13 // pinmux and pinconf configurations. The gpiolib interface is also included.
14 // External interrupt (gpio and wakeup) support are not included in this driver
15 // but provides extensions to which platform specific implementation of the gpio
16 // and wakeup interrupts can be hooked to.
18 #include <linux/clk.h>
19 #include <linux/err.h>
20 #include <linux/gpio/driver.h>
21 #include <linux/init.h>
23 #include <linux/irqdomain.h>
25 #include <linux/platform_device.h>
26 #include <linux/property.h>
27 #include <linux/seq_file.h>
28 #include <linux/slab.h>
29 #include <linux/spinlock.h>
32 #include "pinctrl-samsung.h"
34 /* maximum number of the memory resources */
35 #define SAMSUNG_PINCTRL_NUM_RESOURCES 2
37 /* list of all possible config options supported */
38 static struct pin_config
{
40 enum pincfg_type param
;
42 { "samsung,pin-pud", PINCFG_TYPE_PUD
},
43 { "samsung,pin-drv", PINCFG_TYPE_DRV
},
44 { "samsung,pin-con-pdn", PINCFG_TYPE_CON_PDN
},
45 { "samsung,pin-pud-pdn", PINCFG_TYPE_PUD_PDN
},
46 { "samsung,pin-val", PINCFG_TYPE_DAT
},
49 static int samsung_get_group_count(struct pinctrl_dev
*pctldev
)
51 struct samsung_pinctrl_drv_data
*pmx
= pinctrl_dev_get_drvdata(pctldev
);
53 return pmx
->nr_groups
;
56 static const char *samsung_get_group_name(struct pinctrl_dev
*pctldev
,
59 struct samsung_pinctrl_drv_data
*pmx
= pinctrl_dev_get_drvdata(pctldev
);
61 return pmx
->pin_groups
[group
].name
;
64 static int samsung_get_group_pins(struct pinctrl_dev
*pctldev
,
66 const unsigned **pins
,
69 struct samsung_pinctrl_drv_data
*pmx
= pinctrl_dev_get_drvdata(pctldev
);
71 *pins
= pmx
->pin_groups
[group
].pins
;
72 *num_pins
= pmx
->pin_groups
[group
].num_pins
;
77 static int reserve_map(struct device
*dev
, struct pinctrl_map
**map
,
78 unsigned *reserved_maps
, unsigned *num_maps
,
81 unsigned old_num
= *reserved_maps
;
82 unsigned new_num
= *num_maps
+ reserve
;
83 struct pinctrl_map
*new_map
;
85 if (old_num
>= new_num
)
88 new_map
= krealloc(*map
, sizeof(*new_map
) * new_num
, GFP_KERNEL
);
92 memset(new_map
+ old_num
, 0, (new_num
- old_num
) * sizeof(*new_map
));
95 *reserved_maps
= new_num
;
100 static int add_map_mux(struct pinctrl_map
**map
, unsigned *reserved_maps
,
101 unsigned *num_maps
, const char *group
,
102 const char *function
)
104 if (WARN_ON(*num_maps
== *reserved_maps
))
107 (*map
)[*num_maps
].type
= PIN_MAP_TYPE_MUX_GROUP
;
108 (*map
)[*num_maps
].data
.mux
.group
= group
;
109 (*map
)[*num_maps
].data
.mux
.function
= function
;
115 static int add_map_configs(struct device
*dev
, struct pinctrl_map
**map
,
116 unsigned *reserved_maps
, unsigned *num_maps
,
117 const char *group
, unsigned long *configs
,
118 unsigned num_configs
)
120 unsigned long *dup_configs
;
122 if (WARN_ON(*num_maps
== *reserved_maps
))
125 dup_configs
= kmemdup_array(configs
, num_configs
, sizeof(*dup_configs
),
130 (*map
)[*num_maps
].type
= PIN_MAP_TYPE_CONFIGS_GROUP
;
131 (*map
)[*num_maps
].data
.configs
.group_or_pin
= group
;
132 (*map
)[*num_maps
].data
.configs
.configs
= dup_configs
;
133 (*map
)[*num_maps
].data
.configs
.num_configs
= num_configs
;
139 static int add_config(struct device
*dev
, unsigned long **configs
,
140 unsigned *num_configs
, unsigned long config
)
142 unsigned old_num
= *num_configs
;
143 unsigned new_num
= old_num
+ 1;
144 unsigned long *new_configs
;
146 new_configs
= krealloc(*configs
, sizeof(*new_configs
) * new_num
,
151 new_configs
[old_num
] = config
;
153 *configs
= new_configs
;
154 *num_configs
= new_num
;
159 static void samsung_dt_free_map(struct pinctrl_dev
*pctldev
,
160 struct pinctrl_map
*map
,
165 for (i
= 0; i
< num_maps
; i
++)
166 if (map
[i
].type
== PIN_MAP_TYPE_CONFIGS_GROUP
)
167 kfree(map
[i
].data
.configs
.configs
);
172 static int samsung_dt_subnode_to_map(struct samsung_pinctrl_drv_data
*drvdata
,
174 struct device_node
*np
,
175 struct pinctrl_map
**map
,
176 unsigned *reserved_maps
,
181 unsigned long config
;
182 unsigned long *configs
= NULL
;
183 unsigned num_configs
= 0;
185 struct property
*prop
;
187 bool has_func
= false;
189 ret
= of_property_read_u32(np
, "samsung,pin-function", &val
);
193 for (i
= 0; i
< ARRAY_SIZE(cfg_params
); i
++) {
194 ret
= of_property_read_u32(np
, cfg_params
[i
].property
, &val
);
196 config
= PINCFG_PACK(cfg_params
[i
].param
, val
);
197 ret
= add_config(dev
, &configs
, &num_configs
, config
);
200 /* EINVAL=missing, which is fine since it's optional */
201 } else if (ret
!= -EINVAL
) {
202 dev_err(dev
, "could not parse property %s\n",
203 cfg_params
[i
].property
);
212 ret
= of_property_count_strings(np
, "samsung,pins");
214 dev_err(dev
, "could not parse property samsung,pins\n");
219 ret
= reserve_map(dev
, map
, reserved_maps
, num_maps
, reserve
);
223 of_property_for_each_string(np
, "samsung,pins", prop
, group
) {
225 ret
= add_map_mux(map
, reserved_maps
,
226 num_maps
, group
, np
->full_name
);
232 ret
= add_map_configs(dev
, map
, reserved_maps
,
233 num_maps
, group
, configs
,
247 static int samsung_dt_node_to_map(struct pinctrl_dev
*pctldev
,
248 struct device_node
*np_config
,
249 struct pinctrl_map
**map
,
252 struct samsung_pinctrl_drv_data
*drvdata
;
253 unsigned reserved_maps
;
256 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
262 if (!of_get_child_count(np_config
))
263 return samsung_dt_subnode_to_map(drvdata
, pctldev
->dev
,
268 for_each_child_of_node_scoped(np_config
, np
) {
269 ret
= samsung_dt_subnode_to_map(drvdata
, pctldev
->dev
, np
, map
,
270 &reserved_maps
, num_maps
);
272 samsung_dt_free_map(pctldev
, *map
, *num_maps
);
280 #ifdef CONFIG_DEBUG_FS
281 /* Forward declaration which can be used by samsung_pin_dbg_show */
282 static int samsung_pinconf_get(struct pinctrl_dev
*pctldev
, unsigned int pin
,
283 unsigned long *config
);
284 static const char * const reg_names
[] = {"CON", "DAT", "PUD", "DRV", "CON_PDN",
287 static void samsung_pin_dbg_show(struct pinctrl_dev
*pctldev
,
288 struct seq_file
*s
, unsigned int pin
)
290 enum pincfg_type cfg_type
;
291 unsigned long config
;
294 for (cfg_type
= 0; cfg_type
< PINCFG_TYPE_NUM
; cfg_type
++) {
295 config
= PINCFG_PACK(cfg_type
, 0);
296 ret
= samsung_pinconf_get(pctldev
, pin
, &config
);
300 seq_printf(s
, " %s(0x%lx)", reg_names
[cfg_type
],
301 PINCFG_UNPACK_VALUE(config
));
306 /* list of pinctrl callbacks for the pinctrl core */
307 static const struct pinctrl_ops samsung_pctrl_ops
= {
308 .get_groups_count
= samsung_get_group_count
,
309 .get_group_name
= samsung_get_group_name
,
310 .get_group_pins
= samsung_get_group_pins
,
311 .dt_node_to_map
= samsung_dt_node_to_map
,
312 .dt_free_map
= samsung_dt_free_map
,
313 #ifdef CONFIG_DEBUG_FS
314 .pin_dbg_show
= samsung_pin_dbg_show
,
318 /* check if the selector is a valid pin function selector */
319 static int samsung_get_functions_count(struct pinctrl_dev
*pctldev
)
321 struct samsung_pinctrl_drv_data
*drvdata
;
323 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
324 return drvdata
->nr_functions
;
327 /* return the name of the pin function specified */
328 static const char *samsung_pinmux_get_fname(struct pinctrl_dev
*pctldev
,
331 struct samsung_pinctrl_drv_data
*drvdata
;
333 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
334 return drvdata
->pmx_functions
[selector
].name
;
337 /* return the groups associated for the specified function selector */
338 static int samsung_pinmux_get_groups(struct pinctrl_dev
*pctldev
,
339 unsigned selector
, const char * const **groups
,
340 unsigned * const num_groups
)
342 struct samsung_pinctrl_drv_data
*drvdata
;
344 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
345 *groups
= drvdata
->pmx_functions
[selector
].groups
;
346 *num_groups
= drvdata
->pmx_functions
[selector
].num_groups
;
351 * given a pin number that is local to a pin controller, find out the pin bank
352 * and the register base of the pin bank.
354 static void pin_to_reg_bank(struct samsung_pinctrl_drv_data
*drvdata
,
355 unsigned pin
, void __iomem
**reg
, u32
*offset
,
356 struct samsung_pin_bank
**bank
)
358 struct samsung_pin_bank
*b
;
360 b
= drvdata
->pin_banks
;
362 while ((pin
>= b
->pin_base
) &&
363 ((b
->pin_base
+ b
->nr_pins
- 1) < pin
))
366 *reg
= b
->pctl_base
+ b
->pctl_offset
;
367 *offset
= pin
- b
->pin_base
;
372 /* enable or disable a pinmux function */
373 static int samsung_pinmux_setup(struct pinctrl_dev
*pctldev
, unsigned selector
,
376 struct samsung_pinctrl_drv_data
*drvdata
;
377 const struct samsung_pin_bank_type
*type
;
378 struct samsung_pin_bank
*bank
;
380 u32 mask
, shift
, data
, pin_offset
;
382 const struct samsung_pmx_func
*func
;
383 const struct samsung_pin_group
*grp
;
386 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
387 func
= &drvdata
->pmx_functions
[selector
];
388 grp
= &drvdata
->pin_groups
[group
];
390 pin_to_reg_bank(drvdata
, grp
->pins
[0], ®
, &pin_offset
, &bank
);
392 mask
= (1 << type
->fld_width
[PINCFG_TYPE_FUNC
]) - 1;
393 shift
= pin_offset
* type
->fld_width
[PINCFG_TYPE_FUNC
];
395 /* Some banks have two config registers */
400 ret
= clk_enable(drvdata
->pclk
);
402 dev_err(pctldev
->dev
, "failed to enable clock for setup\n");
406 raw_spin_lock_irqsave(&bank
->slock
, flags
);
408 data
= readl(reg
+ type
->reg_offset
[PINCFG_TYPE_FUNC
]);
409 data
&= ~(mask
<< shift
);
410 data
|= func
->val
<< shift
;
411 writel(data
, reg
+ type
->reg_offset
[PINCFG_TYPE_FUNC
]);
413 raw_spin_unlock_irqrestore(&bank
->slock
, flags
);
415 clk_disable(drvdata
->pclk
);
420 /* enable a specified pinmux by writing to registers */
421 static int samsung_pinmux_set_mux(struct pinctrl_dev
*pctldev
,
425 return samsung_pinmux_setup(pctldev
, selector
, group
);
428 /* list of pinmux callbacks for the pinmux vertical in pinctrl core */
429 static const struct pinmux_ops samsung_pinmux_ops
= {
430 .get_functions_count
= samsung_get_functions_count
,
431 .get_function_name
= samsung_pinmux_get_fname
,
432 .get_function_groups
= samsung_pinmux_get_groups
,
433 .set_mux
= samsung_pinmux_set_mux
,
436 /* set or get the pin config settings for a specified pin */
437 static int samsung_pinconf_rw(struct pinctrl_dev
*pctldev
, unsigned int pin
,
438 unsigned long *config
, bool set
)
440 struct samsung_pinctrl_drv_data
*drvdata
;
441 const struct samsung_pin_bank_type
*type
;
442 struct samsung_pin_bank
*bank
;
443 void __iomem
*reg_base
;
444 enum pincfg_type cfg_type
= PINCFG_UNPACK_TYPE(*config
);
445 u32 data
, width
, pin_offset
, mask
, shift
;
446 u32 cfg_value
, cfg_reg
;
450 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
451 pin_to_reg_bank(drvdata
, pin
, ®_base
, &pin_offset
, &bank
);
454 if (cfg_type
>= PINCFG_TYPE_NUM
|| !type
->fld_width
[cfg_type
])
457 width
= type
->fld_width
[cfg_type
];
458 cfg_reg
= type
->reg_offset
[cfg_type
];
460 ret
= clk_enable(drvdata
->pclk
);
462 dev_err(drvdata
->dev
, "failed to enable clock\n");
466 raw_spin_lock_irqsave(&bank
->slock
, flags
);
468 mask
= (1 << width
) - 1;
469 shift
= pin_offset
* width
;
470 data
= readl(reg_base
+ cfg_reg
);
473 cfg_value
= PINCFG_UNPACK_VALUE(*config
);
474 data
&= ~(mask
<< shift
);
475 data
|= (cfg_value
<< shift
);
476 writel(data
, reg_base
+ cfg_reg
);
480 *config
= PINCFG_PACK(cfg_type
, data
);
483 raw_spin_unlock_irqrestore(&bank
->slock
, flags
);
485 clk_disable(drvdata
->pclk
);
490 /* set the pin config settings for a specified pin */
491 static int samsung_pinconf_set(struct pinctrl_dev
*pctldev
, unsigned int pin
,
492 unsigned long *configs
, unsigned num_configs
)
496 for (i
= 0; i
< num_configs
; i
++) {
497 ret
= samsung_pinconf_rw(pctldev
, pin
, &configs
[i
], true);
500 } /* for each config */
505 /* get the pin config settings for a specified pin */
506 static int samsung_pinconf_get(struct pinctrl_dev
*pctldev
, unsigned int pin
,
507 unsigned long *config
)
509 return samsung_pinconf_rw(pctldev
, pin
, config
, false);
512 /* set the pin config settings for a specified pin group */
513 static int samsung_pinconf_group_set(struct pinctrl_dev
*pctldev
,
514 unsigned group
, unsigned long *configs
,
515 unsigned num_configs
)
517 struct samsung_pinctrl_drv_data
*drvdata
;
518 const unsigned int *pins
;
521 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
522 pins
= drvdata
->pin_groups
[group
].pins
;
524 for (cnt
= 0; cnt
< drvdata
->pin_groups
[group
].num_pins
; cnt
++)
525 samsung_pinconf_set(pctldev
, pins
[cnt
], configs
, num_configs
);
530 /* get the pin config settings for a specified pin group */
531 static int samsung_pinconf_group_get(struct pinctrl_dev
*pctldev
,
532 unsigned int group
, unsigned long *config
)
534 struct samsung_pinctrl_drv_data
*drvdata
;
535 const unsigned int *pins
;
537 drvdata
= pinctrl_dev_get_drvdata(pctldev
);
538 pins
= drvdata
->pin_groups
[group
].pins
;
539 samsung_pinconf_get(pctldev
, pins
[0], config
);
543 /* list of pinconfig callbacks for pinconfig vertical in the pinctrl code */
544 static const struct pinconf_ops samsung_pinconf_ops
= {
545 .pin_config_get
= samsung_pinconf_get
,
546 .pin_config_set
= samsung_pinconf_set
,
547 .pin_config_group_get
= samsung_pinconf_group_get
,
548 .pin_config_group_set
= samsung_pinconf_group_set
,
552 * The samsung_gpio_set_vlaue() should be called with "bank->slock" held
553 * to avoid race condition.
555 static void samsung_gpio_set_value(struct gpio_chip
*gc
,
556 unsigned offset
, int value
)
558 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
559 const struct samsung_pin_bank_type
*type
= bank
->type
;
563 reg
= bank
->pctl_base
+ bank
->pctl_offset
;
565 data
= readl(reg
+ type
->reg_offset
[PINCFG_TYPE_DAT
]);
566 data
&= ~(1 << offset
);
569 writel(data
, reg
+ type
->reg_offset
[PINCFG_TYPE_DAT
]);
572 /* gpiolib gpio_set callback function */
573 static void samsung_gpio_set(struct gpio_chip
*gc
, unsigned offset
, int value
)
575 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
576 struct samsung_pinctrl_drv_data
*drvdata
= bank
->drvdata
;
579 if (clk_enable(drvdata
->pclk
)) {
580 dev_err(drvdata
->dev
, "failed to enable clock\n");
584 raw_spin_lock_irqsave(&bank
->slock
, flags
);
585 samsung_gpio_set_value(gc
, offset
, value
);
586 raw_spin_unlock_irqrestore(&bank
->slock
, flags
);
588 clk_disable(drvdata
->pclk
);
591 /* gpiolib gpio_get callback function */
592 static int samsung_gpio_get(struct gpio_chip
*gc
, unsigned offset
)
594 const void __iomem
*reg
;
596 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
597 const struct samsung_pin_bank_type
*type
= bank
->type
;
598 struct samsung_pinctrl_drv_data
*drvdata
= bank
->drvdata
;
601 reg
= bank
->pctl_base
+ bank
->pctl_offset
;
603 ret
= clk_enable(drvdata
->pclk
);
605 dev_err(drvdata
->dev
, "failed to enable clock\n");
609 data
= readl(reg
+ type
->reg_offset
[PINCFG_TYPE_DAT
]);
613 clk_disable(drvdata
->pclk
);
619 * The samsung_gpio_set_direction() should be called with "bank->slock" held
620 * to avoid race condition.
621 * The calls to gpio_direction_output() and gpio_direction_input()
622 * leads to this function call.
624 static int samsung_gpio_set_direction(struct gpio_chip
*gc
,
625 unsigned offset
, bool input
)
627 const struct samsung_pin_bank_type
*type
;
628 struct samsung_pin_bank
*bank
;
630 u32 data
, mask
, shift
;
632 bank
= gpiochip_get_data(gc
);
635 reg
= bank
->pctl_base
+ bank
->pctl_offset
636 + type
->reg_offset
[PINCFG_TYPE_FUNC
];
638 mask
= (1 << type
->fld_width
[PINCFG_TYPE_FUNC
]) - 1;
639 shift
= offset
* type
->fld_width
[PINCFG_TYPE_FUNC
];
641 /* Some banks have two config registers */
647 data
&= ~(mask
<< shift
);
649 data
|= PIN_CON_FUNC_OUTPUT
<< shift
;
655 /* gpiolib gpio_direction_input callback function. */
656 static int samsung_gpio_direction_input(struct gpio_chip
*gc
, unsigned offset
)
658 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
659 struct samsung_pinctrl_drv_data
*drvdata
= bank
->drvdata
;
663 ret
= clk_enable(drvdata
->pclk
);
665 dev_err(drvdata
->dev
, "failed to enable clock\n");
669 raw_spin_lock_irqsave(&bank
->slock
, flags
);
670 ret
= samsung_gpio_set_direction(gc
, offset
, true);
671 raw_spin_unlock_irqrestore(&bank
->slock
, flags
);
673 clk_disable(drvdata
->pclk
);
678 /* gpiolib gpio_direction_output callback function. */
679 static int samsung_gpio_direction_output(struct gpio_chip
*gc
, unsigned offset
,
682 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
683 struct samsung_pinctrl_drv_data
*drvdata
= bank
->drvdata
;
687 ret
= clk_enable(drvdata
->pclk
);
689 dev_err(drvdata
->dev
, "failed to enable clock\n");
693 raw_spin_lock_irqsave(&bank
->slock
, flags
);
694 samsung_gpio_set_value(gc
, offset
, value
);
695 ret
= samsung_gpio_set_direction(gc
, offset
, false);
696 raw_spin_unlock_irqrestore(&bank
->slock
, flags
);
698 clk_disable(drvdata
->pclk
);
704 * gpiod_to_irq() callback function. Creates a mapping between a GPIO pin
705 * and a virtual IRQ, if not already present.
707 static int samsung_gpio_to_irq(struct gpio_chip
*gc
, unsigned offset
)
709 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
712 if (!bank
->irq_domain
)
715 virq
= irq_create_mapping(bank
->irq_domain
, offset
);
717 return (virq
) ? : -ENXIO
;
720 static int samsung_add_pin_ranges(struct gpio_chip
*gc
)
722 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
724 bank
->grange
.name
= bank
->name
;
725 bank
->grange
.id
= bank
->id
;
726 bank
->grange
.pin_base
= bank
->pin_base
;
727 bank
->grange
.base
= gc
->base
;
728 bank
->grange
.npins
= bank
->nr_pins
;
729 bank
->grange
.gc
= &bank
->gpio_chip
;
730 pinctrl_add_gpio_range(bank
->drvdata
->pctl_dev
, &bank
->grange
);
735 static struct samsung_pin_group
*samsung_pinctrl_create_groups(
737 struct samsung_pinctrl_drv_data
*drvdata
,
740 struct pinctrl_desc
*ctrldesc
= &drvdata
->pctl
;
741 struct samsung_pin_group
*groups
, *grp
;
742 const struct pinctrl_pin_desc
*pdesc
;
745 groups
= devm_kcalloc(dev
, ctrldesc
->npins
, sizeof(*groups
),
748 return ERR_PTR(-EINVAL
);
751 pdesc
= ctrldesc
->pins
;
752 for (i
= 0; i
< ctrldesc
->npins
; ++i
, ++pdesc
, ++grp
) {
753 grp
->name
= pdesc
->name
;
754 grp
->pins
= &pdesc
->number
;
758 *cnt
= ctrldesc
->npins
;
762 static int samsung_pinctrl_create_function(struct device
*dev
,
763 struct samsung_pinctrl_drv_data
*drvdata
,
764 struct device_node
*func_np
,
765 struct samsung_pmx_func
*func
)
771 if (of_property_read_u32(func_np
, "samsung,pin-function", &func
->val
))
774 npins
= of_property_count_strings(func_np
, "samsung,pins");
776 dev_err(dev
, "invalid pin list in %pOFn node", func_np
);
780 func
->name
= func_np
->full_name
;
782 func
->groups
= devm_kcalloc(dev
, npins
, sizeof(char *), GFP_KERNEL
);
786 for (i
= 0; i
< npins
; ++i
) {
789 ret
= of_property_read_string_index(func_np
, "samsung,pins",
793 "failed to read pin name %d from %pOFn node\n",
798 func
->groups
[i
] = gname
;
801 func
->num_groups
= npins
;
805 static struct samsung_pmx_func
*samsung_pinctrl_create_functions(
807 struct samsung_pinctrl_drv_data
*drvdata
,
810 struct samsung_pmx_func
*functions
, *func
;
811 struct device_node
*dev_np
= dev
->of_node
;
812 struct device_node
*cfg_np
;
813 unsigned int func_cnt
= 0;
817 * Iterate over all the child nodes of the pin controller node
818 * and create pin groups and pin function lists.
820 for_each_child_of_node(dev_np
, cfg_np
) {
821 struct device_node
*func_np
;
823 if (!of_get_child_count(cfg_np
)) {
824 if (!of_property_present(cfg_np
,
825 "samsung,pin-function"))
831 for_each_child_of_node(cfg_np
, func_np
) {
832 if (!of_property_present(func_np
,
833 "samsung,pin-function"))
839 functions
= devm_kcalloc(dev
, func_cnt
, sizeof(*functions
),
842 return ERR_PTR(-ENOMEM
);
846 * Iterate over all the child nodes of the pin controller node
847 * and create pin groups and pin function lists.
850 for_each_child_of_node_scoped(dev_np
, cfg_np
) {
851 if (!of_get_child_count(cfg_np
)) {
852 ret
= samsung_pinctrl_create_function(dev
, drvdata
,
863 for_each_child_of_node_scoped(cfg_np
, func_np
) {
864 ret
= samsung_pinctrl_create_function(dev
, drvdata
,
880 * Parse the information about all the available pin groups and pin functions
881 * from device node of the pin-controller. A pin group is formed with all
882 * the pins listed in the "samsung,pins" property.
885 static int samsung_pinctrl_parse_dt(struct platform_device
*pdev
,
886 struct samsung_pinctrl_drv_data
*drvdata
)
888 struct device
*dev
= &pdev
->dev
;
889 struct samsung_pin_group
*groups
;
890 struct samsung_pmx_func
*functions
;
891 unsigned int grp_cnt
= 0, func_cnt
= 0;
893 groups
= samsung_pinctrl_create_groups(dev
, drvdata
, &grp_cnt
);
894 if (IS_ERR(groups
)) {
895 dev_err(dev
, "failed to parse pin groups\n");
896 return PTR_ERR(groups
);
899 functions
= samsung_pinctrl_create_functions(dev
, drvdata
, &func_cnt
);
900 if (IS_ERR(functions
)) {
901 dev_err(dev
, "failed to parse pin functions\n");
902 return PTR_ERR(functions
);
905 drvdata
->pin_groups
= groups
;
906 drvdata
->nr_groups
= grp_cnt
;
907 drvdata
->pmx_functions
= functions
;
908 drvdata
->nr_functions
= func_cnt
;
913 /* register the pinctrl interface with the pinctrl subsystem */
914 static int samsung_pinctrl_register(struct platform_device
*pdev
,
915 struct samsung_pinctrl_drv_data
*drvdata
)
917 struct pinctrl_desc
*ctrldesc
= &drvdata
->pctl
;
918 struct pinctrl_pin_desc
*pindesc
, *pdesc
;
919 struct samsung_pin_bank
*pin_bank
;
923 ctrldesc
->name
= "samsung-pinctrl";
924 ctrldesc
->owner
= THIS_MODULE
;
925 ctrldesc
->pctlops
= &samsung_pctrl_ops
;
926 ctrldesc
->pmxops
= &samsung_pinmux_ops
;
927 ctrldesc
->confops
= &samsung_pinconf_ops
;
929 pindesc
= devm_kcalloc(&pdev
->dev
,
930 drvdata
->nr_pins
, sizeof(*pindesc
),
934 ctrldesc
->pins
= pindesc
;
935 ctrldesc
->npins
= drvdata
->nr_pins
;
937 /* dynamically populate the pin number and pin name for pindesc */
938 for (pin
= 0, pdesc
= pindesc
; pin
< ctrldesc
->npins
; pin
++, pdesc
++)
942 * allocate space for storing the dynamically generated names for all
943 * the pins which belong to this pin-controller.
945 pin_names
= devm_kzalloc(&pdev
->dev
,
946 array3_size(sizeof(char), PIN_NAME_LENGTH
,
952 /* for each pin, the name of the pin is pin-bank name + pin number */
953 for (bank
= 0; bank
< drvdata
->nr_banks
; bank
++) {
954 pin_bank
= &drvdata
->pin_banks
[bank
];
956 for (pin
= 0; pin
< pin_bank
->nr_pins
; pin
++) {
957 sprintf(pin_names
, "%s-%d", pin_bank
->name
, pin
);
958 pdesc
= pindesc
+ pin_bank
->pin_base
+ pin
;
959 pdesc
->name
= pin_names
;
960 pin_names
+= PIN_NAME_LENGTH
;
964 ret
= samsung_pinctrl_parse_dt(pdev
, drvdata
);
968 ret
= devm_pinctrl_register_and_init(&pdev
->dev
, ctrldesc
, drvdata
,
971 dev_err(&pdev
->dev
, "could not register pinctrl driver\n");
978 /* unregister the pinctrl interface with the pinctrl subsystem */
979 static int samsung_pinctrl_unregister(struct platform_device
*pdev
,
980 struct samsung_pinctrl_drv_data
*drvdata
)
982 struct samsung_pin_bank
*bank
= drvdata
->pin_banks
;
985 for (i
= 0; i
< drvdata
->nr_banks
; ++i
, ++bank
)
986 pinctrl_remove_gpio_range(drvdata
->pctl_dev
, &bank
->grange
);
991 static void samsung_pud_value_init(struct samsung_pinctrl_drv_data
*drvdata
)
993 unsigned int *pud_val
= drvdata
->pud_val
;
995 pud_val
[PUD_PULL_DISABLE
] = EXYNOS_PIN_PUD_PULL_DISABLE
;
996 pud_val
[PUD_PULL_DOWN
] = EXYNOS_PIN_PID_PULL_DOWN
;
997 pud_val
[PUD_PULL_UP
] = EXYNOS_PIN_PID_PULL_UP
;
1001 * Enable or Disable the pull-down and pull-up for the gpio pins in the
1004 static void samsung_gpio_set_pud(struct gpio_chip
*gc
, unsigned int offset
,
1007 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
1008 const struct samsung_pin_bank_type
*type
= bank
->type
;
1010 unsigned int data
, mask
;
1012 reg
= bank
->pctl_base
+ bank
->pctl_offset
;
1013 data
= readl(reg
+ type
->reg_offset
[PINCFG_TYPE_PUD
]);
1014 mask
= (1 << type
->fld_width
[PINCFG_TYPE_PUD
]) - 1;
1015 data
&= ~(mask
<< (offset
* type
->fld_width
[PINCFG_TYPE_PUD
]));
1016 data
|= value
<< (offset
* type
->fld_width
[PINCFG_TYPE_PUD
]);
1017 writel(data
, reg
+ type
->reg_offset
[PINCFG_TYPE_PUD
]);
1021 * Identify the type of PUD config based on the gpiolib request to enable
1022 * or disable the PUD config.
1024 static int samsung_gpio_set_config(struct gpio_chip
*gc
, unsigned int offset
,
1025 unsigned long config
)
1027 struct samsung_pin_bank
*bank
= gpiochip_get_data(gc
);
1028 struct samsung_pinctrl_drv_data
*drvdata
= bank
->drvdata
;
1031 unsigned long flags
;
1033 switch (pinconf_to_config_param(config
)) {
1034 case PIN_CONFIG_BIAS_DISABLE
:
1035 value
= drvdata
->pud_val
[PUD_PULL_DISABLE
];
1037 case PIN_CONFIG_BIAS_PULL_DOWN
:
1038 value
= drvdata
->pud_val
[PUD_PULL_DOWN
];
1040 case PIN_CONFIG_BIAS_PULL_UP
:
1041 value
= drvdata
->pud_val
[PUD_PULL_UP
];
1047 ret
= clk_enable(drvdata
->pclk
);
1049 dev_err(drvdata
->dev
, "failed to enable clock\n");
1053 raw_spin_lock_irqsave(&bank
->slock
, flags
);
1054 samsung_gpio_set_pud(gc
, offset
, value
);
1055 raw_spin_unlock_irqrestore(&bank
->slock
, flags
);
1057 clk_disable(drvdata
->pclk
);
1062 static const struct gpio_chip samsung_gpiolib_chip
= {
1063 .request
= gpiochip_generic_request
,
1064 .free
= gpiochip_generic_free
,
1065 .set
= samsung_gpio_set
,
1066 .get
= samsung_gpio_get
,
1067 .direction_input
= samsung_gpio_direction_input
,
1068 .direction_output
= samsung_gpio_direction_output
,
1069 .to_irq
= samsung_gpio_to_irq
,
1070 .add_pin_ranges
= samsung_add_pin_ranges
,
1071 .set_config
= samsung_gpio_set_config
,
1072 .owner
= THIS_MODULE
,
1075 /* register the gpiolib interface with the gpiolib subsystem */
1076 static int samsung_gpiolib_register(struct platform_device
*pdev
,
1077 struct samsung_pinctrl_drv_data
*drvdata
)
1079 struct samsung_pin_bank
*bank
= drvdata
->pin_banks
;
1080 struct gpio_chip
*gc
;
1084 for (i
= 0; i
< drvdata
->nr_banks
; ++i
, ++bank
) {
1085 bank
->gpio_chip
= samsung_gpiolib_chip
;
1087 gc
= &bank
->gpio_chip
;
1088 gc
->base
= -1; /* Dynamic allocation */
1089 gc
->ngpio
= bank
->nr_pins
;
1090 gc
->parent
= &pdev
->dev
;
1091 gc
->fwnode
= bank
->fwnode
;
1092 gc
->label
= bank
->name
;
1094 ret
= devm_gpiochip_add_data(&pdev
->dev
, gc
, bank
);
1096 dev_err(&pdev
->dev
, "failed to register gpio_chip %s, error code: %d\n",
1105 static const struct samsung_pin_ctrl
*
1106 samsung_pinctrl_get_soc_data_for_of_alias(struct platform_device
*pdev
)
1108 struct device_node
*node
= pdev
->dev
.of_node
;
1109 const struct samsung_pinctrl_of_match_data
*of_data
;
1112 id
= of_alias_get_id(node
, "pinctrl");
1114 dev_err(&pdev
->dev
, "failed to get alias id\n");
1118 of_data
= of_device_get_match_data(&pdev
->dev
);
1119 if (id
>= of_data
->num_ctrl
) {
1120 dev_err(&pdev
->dev
, "invalid alias id %d\n", id
);
1124 return &(of_data
->ctrl
[id
]);
1127 static void samsung_banks_node_put(struct samsung_pinctrl_drv_data
*d
)
1129 struct samsung_pin_bank
*bank
;
1132 bank
= d
->pin_banks
;
1133 for (i
= 0; i
< d
->nr_banks
; ++i
, ++bank
)
1134 fwnode_handle_put(bank
->fwnode
);
1138 * Iterate over all driver pin banks to find one matching the name of node,
1139 * skipping optional "-gpio" node suffix. When found, assign node to the bank.
1141 static void samsung_banks_node_get(struct device
*dev
, struct samsung_pinctrl_drv_data
*d
)
1143 const char *suffix
= "-gpio-bank";
1144 struct samsung_pin_bank
*bank
;
1145 struct fwnode_handle
*child
;
1146 /* Pin bank names are up to 4 characters */
1151 bank
= d
->pin_banks
;
1152 for (i
= 0; i
< d
->nr_banks
; ++i
, ++bank
) {
1153 strscpy(node_name
, bank
->name
, sizeof(node_name
));
1154 len
= strlcat(node_name
, suffix
, sizeof(node_name
));
1155 if (len
>= sizeof(node_name
)) {
1156 dev_err(dev
, "Too long pin bank name '%s', ignoring\n",
1161 for_each_gpiochip_node(dev
, child
) {
1162 struct device_node
*np
= to_of_node(child
);
1164 if (of_node_name_eq(np
, node_name
))
1166 if (of_node_name_eq(np
, bank
->name
))
1171 bank
->fwnode
= child
;
1173 dev_warn(dev
, "Missing node for bank %s - invalid DTB\n",
1175 /* child reference dropped in samsung_drop_banks_of_node() */
1179 /* retrieve the soc specific data */
1180 static const struct samsung_pin_ctrl
*
1181 samsung_pinctrl_get_soc_data(struct samsung_pinctrl_drv_data
*d
,
1182 struct platform_device
*pdev
)
1184 const struct samsung_pin_bank_data
*bdata
;
1185 const struct samsung_pin_ctrl
*ctrl
;
1186 struct samsung_pin_bank
*bank
;
1187 struct resource
*res
;
1188 void __iomem
*virt_base
[SAMSUNG_PINCTRL_NUM_RESOURCES
];
1191 ctrl
= samsung_pinctrl_get_soc_data_for_of_alias(pdev
);
1193 return ERR_PTR(-ENOENT
);
1195 d
->suspend
= ctrl
->suspend
;
1196 d
->resume
= ctrl
->resume
;
1197 d
->nr_banks
= ctrl
->nr_banks
;
1198 d
->pin_banks
= devm_kcalloc(&pdev
->dev
, d
->nr_banks
,
1199 sizeof(*d
->pin_banks
), GFP_KERNEL
);
1201 return ERR_PTR(-ENOMEM
);
1203 if (ctrl
->nr_ext_resources
+ 1 > SAMSUNG_PINCTRL_NUM_RESOURCES
)
1204 return ERR_PTR(-EINVAL
);
1206 for (i
= 0; i
< ctrl
->nr_ext_resources
+ 1; i
++) {
1207 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, i
);
1209 dev_err(&pdev
->dev
, "failed to get mem%d resource\n", i
);
1210 return ERR_PTR(-EINVAL
);
1212 virt_base
[i
] = devm_ioremap(&pdev
->dev
, res
->start
,
1213 resource_size(res
));
1214 if (!virt_base
[i
]) {
1215 dev_err(&pdev
->dev
, "failed to ioremap %pR\n", res
);
1216 return ERR_PTR(-EIO
);
1220 bank
= d
->pin_banks
;
1221 bdata
= ctrl
->pin_banks
;
1222 for (i
= 0; i
< ctrl
->nr_banks
; ++i
, ++bdata
, ++bank
) {
1223 bank
->type
= bdata
->type
;
1224 bank
->pctl_offset
= bdata
->pctl_offset
;
1225 bank
->nr_pins
= bdata
->nr_pins
;
1226 bank
->eint_func
= bdata
->eint_func
;
1227 bank
->eint_type
= bdata
->eint_type
;
1228 bank
->eint_mask
= bdata
->eint_mask
;
1229 bank
->eint_offset
= bdata
->eint_offset
;
1230 bank
->eint_con_offset
= bdata
->eint_con_offset
;
1231 bank
->eint_mask_offset
= bdata
->eint_mask_offset
;
1232 bank
->eint_pend_offset
= bdata
->eint_pend_offset
;
1233 bank
->name
= bdata
->name
;
1235 raw_spin_lock_init(&bank
->slock
);
1237 bank
->pin_base
= d
->nr_pins
;
1238 d
->nr_pins
+= bank
->nr_pins
;
1240 bank
->eint_base
= virt_base
[0];
1241 bank
->pctl_base
= virt_base
[bdata
->pctl_res_idx
];
1244 * Legacy platforms should provide only one resource with IO memory.
1245 * Store it as virt_base because legacy driver needs to access it
1246 * through samsung_pinctrl_drv_data.
1248 d
->virt_base
= virt_base
[0];
1250 samsung_banks_node_get(&pdev
->dev
, d
);
1255 static int samsung_pinctrl_probe(struct platform_device
*pdev
)
1257 struct samsung_pinctrl_drv_data
*drvdata
;
1258 const struct samsung_pin_ctrl
*ctrl
;
1259 struct device
*dev
= &pdev
->dev
;
1262 drvdata
= devm_kzalloc(dev
, sizeof(*drvdata
), GFP_KERNEL
);
1266 ctrl
= samsung_pinctrl_get_soc_data(drvdata
, pdev
);
1268 dev_err(&pdev
->dev
, "driver data not available\n");
1269 return PTR_ERR(ctrl
);
1273 ret
= platform_get_irq_optional(pdev
, 0);
1274 if (ret
< 0 && ret
!= -ENXIO
)
1279 if (ctrl
->retention_data
) {
1280 drvdata
->retention_ctrl
= ctrl
->retention_data
->init(drvdata
,
1281 ctrl
->retention_data
);
1282 if (IS_ERR(drvdata
->retention_ctrl
)) {
1283 ret
= PTR_ERR(drvdata
->retention_ctrl
);
1288 drvdata
->pclk
= devm_clk_get_optional_prepared(dev
, "pclk");
1289 if (IS_ERR(drvdata
->pclk
)) {
1290 ret
= PTR_ERR(drvdata
->pclk
);
1294 ret
= samsung_pinctrl_register(pdev
, drvdata
);
1298 if (ctrl
->eint_gpio_init
)
1299 ctrl
->eint_gpio_init(drvdata
);
1300 if (ctrl
->eint_wkup_init
)
1301 ctrl
->eint_wkup_init(drvdata
);
1303 if (ctrl
->pud_value_init
)
1304 ctrl
->pud_value_init(drvdata
);
1306 samsung_pud_value_init(drvdata
);
1308 ret
= samsung_gpiolib_register(pdev
, drvdata
);
1310 goto err_unregister
;
1312 ret
= pinctrl_enable(drvdata
->pctl_dev
);
1314 goto err_unregister
;
1316 platform_set_drvdata(pdev
, drvdata
);
1321 samsung_pinctrl_unregister(pdev
, drvdata
);
1323 samsung_banks_node_put(drvdata
);
1328 * samsung_pinctrl_suspend - save pinctrl state for suspend
1330 * Save data for all banks handled by this device.
1332 static int __maybe_unused
samsung_pinctrl_suspend(struct device
*dev
)
1334 struct samsung_pinctrl_drv_data
*drvdata
= dev_get_drvdata(dev
);
1337 i
= clk_enable(drvdata
->pclk
);
1339 dev_err(drvdata
->dev
,
1340 "failed to enable clock for saving state\n");
1344 for (i
= 0; i
< drvdata
->nr_banks
; i
++) {
1345 struct samsung_pin_bank
*bank
= &drvdata
->pin_banks
[i
];
1346 const void __iomem
*reg
= bank
->pctl_base
+ bank
->pctl_offset
;
1347 const u8
*offs
= bank
->type
->reg_offset
;
1348 const u8
*widths
= bank
->type
->fld_width
;
1349 enum pincfg_type type
;
1351 /* Registers without a powerdown config aren't lost */
1352 if (!widths
[PINCFG_TYPE_CON_PDN
])
1355 for (type
= 0; type
< PINCFG_TYPE_NUM
; type
++)
1357 bank
->pm_save
[type
] = readl(reg
+ offs
[type
]);
1359 if (widths
[PINCFG_TYPE_FUNC
] * bank
->nr_pins
> 32) {
1360 /* Some banks have two config registers */
1361 bank
->pm_save
[PINCFG_TYPE_NUM
] =
1362 readl(reg
+ offs
[PINCFG_TYPE_FUNC
] + 4);
1363 pr_debug("Save %s @ %p (con %#010x %08x)\n",
1365 bank
->pm_save
[PINCFG_TYPE_FUNC
],
1366 bank
->pm_save
[PINCFG_TYPE_NUM
]);
1368 pr_debug("Save %s @ %p (con %#010x)\n", bank
->name
,
1369 reg
, bank
->pm_save
[PINCFG_TYPE_FUNC
]);
1373 clk_disable(drvdata
->pclk
);
1375 if (drvdata
->suspend
)
1376 drvdata
->suspend(drvdata
);
1377 if (drvdata
->retention_ctrl
&& drvdata
->retention_ctrl
->enable
)
1378 drvdata
->retention_ctrl
->enable(drvdata
);
1384 * samsung_pinctrl_resume - restore pinctrl state from suspend
1386 * Restore one of the banks that was saved during suspend.
1388 * We don't bother doing anything complicated to avoid glitching lines since
1389 * we're called before pad retention is turned off.
1391 static int __maybe_unused
samsung_pinctrl_resume(struct device
*dev
)
1393 struct samsung_pinctrl_drv_data
*drvdata
= dev_get_drvdata(dev
);
1398 * enable clock before the callback, as we don't want to have to deal
1399 * with callback cleanup on clock failures.
1401 ret
= clk_enable(drvdata
->pclk
);
1403 dev_err(drvdata
->dev
,
1404 "failed to enable clock for restoring state\n");
1408 if (drvdata
->resume
)
1409 drvdata
->resume(drvdata
);
1411 for (i
= 0; i
< drvdata
->nr_banks
; i
++) {
1412 struct samsung_pin_bank
*bank
= &drvdata
->pin_banks
[i
];
1413 void __iomem
*reg
= bank
->pctl_base
+ bank
->pctl_offset
;
1414 const u8
*offs
= bank
->type
->reg_offset
;
1415 const u8
*widths
= bank
->type
->fld_width
;
1416 enum pincfg_type type
;
1418 /* Registers without a powerdown config aren't lost */
1419 if (!widths
[PINCFG_TYPE_CON_PDN
])
1422 if (widths
[PINCFG_TYPE_FUNC
] * bank
->nr_pins
> 32) {
1423 /* Some banks have two config registers */
1424 pr_debug("%s @ %p (con %#010x %08x => %#010x %08x)\n",
1426 readl(reg
+ offs
[PINCFG_TYPE_FUNC
]),
1427 readl(reg
+ offs
[PINCFG_TYPE_FUNC
] + 4),
1428 bank
->pm_save
[PINCFG_TYPE_FUNC
],
1429 bank
->pm_save
[PINCFG_TYPE_NUM
]);
1430 writel(bank
->pm_save
[PINCFG_TYPE_NUM
],
1431 reg
+ offs
[PINCFG_TYPE_FUNC
] + 4);
1433 pr_debug("%s @ %p (con %#010x => %#010x)\n", bank
->name
,
1434 reg
, readl(reg
+ offs
[PINCFG_TYPE_FUNC
]),
1435 bank
->pm_save
[PINCFG_TYPE_FUNC
]);
1437 for (type
= 0; type
< PINCFG_TYPE_NUM
; type
++)
1439 writel(bank
->pm_save
[type
], reg
+ offs
[type
]);
1442 clk_disable(drvdata
->pclk
);
1444 if (drvdata
->retention_ctrl
&& drvdata
->retention_ctrl
->disable
)
1445 drvdata
->retention_ctrl
->disable(drvdata
);
1450 static const struct of_device_id samsung_pinctrl_dt_match
[] = {
1451 #ifdef CONFIG_PINCTRL_EXYNOS_ARM
1452 { .compatible
= "samsung,exynos3250-pinctrl",
1453 .data
= &exynos3250_of_data
},
1454 { .compatible
= "samsung,exynos4210-pinctrl",
1455 .data
= &exynos4210_of_data
},
1456 { .compatible
= "samsung,exynos4x12-pinctrl",
1457 .data
= &exynos4x12_of_data
},
1458 { .compatible
= "samsung,exynos5250-pinctrl",
1459 .data
= &exynos5250_of_data
},
1460 { .compatible
= "samsung,exynos5260-pinctrl",
1461 .data
= &exynos5260_of_data
},
1462 { .compatible
= "samsung,exynos5410-pinctrl",
1463 .data
= &exynos5410_of_data
},
1464 { .compatible
= "samsung,exynos5420-pinctrl",
1465 .data
= &exynos5420_of_data
},
1466 { .compatible
= "samsung,s5pv210-pinctrl",
1467 .data
= &s5pv210_of_data
},
1469 #ifdef CONFIG_PINCTRL_EXYNOS_ARM64
1470 { .compatible
= "google,gs101-pinctrl",
1471 .data
= &gs101_of_data
},
1472 { .compatible
= "samsung,exynos5433-pinctrl",
1473 .data
= &exynos5433_of_data
},
1474 { .compatible
= "samsung,exynos7-pinctrl",
1475 .data
= &exynos7_of_data
},
1476 { .compatible
= "samsung,exynos7885-pinctrl",
1477 .data
= &exynos7885_of_data
},
1478 { .compatible
= "samsung,exynos850-pinctrl",
1479 .data
= &exynos850_of_data
},
1480 { .compatible
= "samsung,exynos8895-pinctrl",
1481 .data
= &exynos8895_of_data
},
1482 { .compatible
= "samsung,exynos9810-pinctrl",
1483 .data
= &exynos9810_of_data
},
1484 { .compatible
= "samsung,exynos990-pinctrl",
1485 .data
= &exynos990_of_data
},
1486 { .compatible
= "samsung,exynosautov9-pinctrl",
1487 .data
= &exynosautov9_of_data
},
1488 { .compatible
= "samsung,exynosautov920-pinctrl",
1489 .data
= &exynosautov920_of_data
},
1490 { .compatible
= "tesla,fsd-pinctrl",
1491 .data
= &fsd_of_data
},
1493 #ifdef CONFIG_PINCTRL_S3C64XX
1494 { .compatible
= "samsung,s3c64xx-pinctrl",
1495 .data
= &s3c64xx_of_data
},
1500 static const struct dev_pm_ops samsung_pinctrl_pm_ops
= {
1501 SET_LATE_SYSTEM_SLEEP_PM_OPS(samsung_pinctrl_suspend
,
1502 samsung_pinctrl_resume
)
1505 static struct platform_driver samsung_pinctrl_driver
= {
1506 .probe
= samsung_pinctrl_probe
,
1508 .name
= "samsung-pinctrl",
1509 .of_match_table
= samsung_pinctrl_dt_match
,
1510 .suppress_bind_attrs
= true,
1511 .pm
= &samsung_pinctrl_pm_ops
,
1515 static int __init
samsung_pinctrl_drv_register(void)
1517 return platform_driver_register(&samsung_pinctrl_driver
);
1519 postcore_initcall(samsung_pinctrl_drv_register
);